2757472: Reland "Reland "[LSC] Remove base::string16 alias""

https://chromium-review.googlesource.com/c/chromium/src/+/2757472
This commit is contained in:
John Kleinschmidt 2021-03-18 15:55:51 -04:00
parent 3b183854ff
commit 2d3c65beca
31 changed files with 200 additions and 152 deletions

View file

@ -33,6 +33,10 @@
#include "base/debug/dump_without_crashing.h" #include "base/debug/dump_without_crashing.h"
#endif #endif
#if defined(OS_WIN)
#include "base/strings/string_util_win.h"
#endif
namespace { namespace {
ElectronCrashReporterClient* Instance() { ElectronCrashReporterClient* Instance() {
@ -130,8 +134,8 @@ void ElectronCrashReporterClient::GetProductNameAndVersion(
std::wstring* version, std::wstring* version,
std::wstring* special_build, std::wstring* special_build,
std::wstring* channel_name) { std::wstring* channel_name) {
*product_name = base::UTF8ToUTF16(ELECTRON_PRODUCT_NAME); *product_name = base::UTF8ToWide(ELECTRON_PRODUCT_NAME);
*version = base::UTF8ToUTF16(ELECTRON_VERSION_STRING); *version = base::UTF8ToWide(ELECTRON_VERSION_STRING);
} }
#endif #endif

View file

@ -66,7 +66,7 @@ void SetNodeCliFlags() {
for (const auto& arg : argv) { for (const auto& arg : argv) {
#if defined(OS_WIN) #if defined(OS_WIN)
const auto& option = base::UTF16ToUTF8(arg); const auto& option = base::WideToUTF8(arg);
#else #else
const auto& option = arg; const auto& option = arg;
#endif #endif

View file

@ -1101,8 +1101,10 @@ void BaseWindow::SetAppDetails(const gin_helper::Dictionary& options) {
options.Get("relaunchCommand", &relaunch_command); options.Get("relaunchCommand", &relaunch_command);
options.Get("relaunchDisplayName", &relaunch_display_name); options.Get("relaunchDisplayName", &relaunch_display_name);
ui::win::SetAppDetailsForWindow(app_id, app_icon_path, app_icon_index, ui::win::SetAppDetailsForWindow(base::UTF16ToWide(app_id), app_icon_path,
relaunch_command, relaunch_display_name, app_icon_index,
base::UTF16ToWide(relaunch_command),
base::UTF16ToWide(relaunch_display_name),
window_->GetAcceleratedWidget()); window_->GetAcceleratedWidget());
} }
#endif #endif

View file

@ -175,7 +175,7 @@ void Start(const std::string& submit_url,
base::PathService::Get(DIR_USER_DATA, &user_data_dir); base::PathService::Get(DIR_USER_DATA, &user_data_dir);
::crash_reporter::InitializeCrashpadWithEmbeddedHandler( ::crash_reporter::InitializeCrashpadWithEmbeddedHandler(
process_type.empty(), process_type, process_type.empty(), process_type,
base::UTF16ToUTF8(user_data_dir.value()), base::FilePath()); base::WideToUTF8(user_data_dir.value()), base::FilePath());
#endif #endif
#endif #endif
} }

View file

@ -418,7 +418,7 @@ bool IsDeviceNameValid(const std::u16string& device_name) {
return printer_exists; return printer_exists;
#elif defined(OS_WIN) #elif defined(OS_WIN)
printing::ScopedPrinterHandle printer; printing::ScopedPrinterHandle printer;
return printer.OpenPrinterWithName(device_name.c_str()); return printer.OpenPrinterWithName(base::UTF16ToWide(device_name).c_str());
#endif #endif
return true; return true;
} }

View file

@ -112,10 +112,10 @@ class Browser : public WindowListObserver {
#if defined(OS_WIN) #if defined(OS_WIN)
struct LaunchItem { struct LaunchItem {
std::u16string name; std::wstring name;
std::u16string path; std::wstring path;
std::u16string scope; std::wstring scope;
std::vector<std::u16string> args; std::vector<std::wstring> args;
bool enabled = true; bool enabled = true;
LaunchItem(); LaunchItem();
@ -137,7 +137,7 @@ class Browser : public WindowListObserver {
#if defined(OS_WIN) #if defined(OS_WIN)
// used in browser::setLoginItemSettings // used in browser::setLoginItemSettings
bool enabled = true; bool enabled = true;
std::u16string name = std::u16string(); std::wstring name = std::wstring();
// used in browser::getLoginItemSettings // used in browser::getLoginItemSettings
bool executable_will_launch_at_login = false; bool executable_will_launch_at_login = false;
@ -237,9 +237,9 @@ class Browser : public WindowListObserver {
#if defined(OS_WIN) #if defined(OS_WIN)
struct UserTask { struct UserTask {
base::FilePath program; base::FilePath program;
std::u16string arguments; std::wstring arguments;
std::u16string title; std::wstring title;
std::u16string description; std::wstring description;
base::FilePath working_dir; base::FilePath working_dir;
base::FilePath icon_path; base::FilePath icon_path;
int icon_index; int icon_index;

View file

@ -48,7 +48,7 @@ namespace electron {
namespace { namespace {
bool GetProcessExecPath(std::u16string* exe) { bool GetProcessExecPath(std::wstring* exe) {
base::FilePath path; base::FilePath path;
if (!base::PathService::Get(base::FILE_EXE, &path)) { if (!base::PathService::Get(base::FILE_EXE, &path)) {
return false; return false;
@ -57,13 +57,13 @@ bool GetProcessExecPath(std::u16string* exe) {
return true; return true;
} }
bool GetProtocolLaunchPath(gin::Arguments* args, std::u16string* exe) { bool GetProtocolLaunchPath(gin::Arguments* args, std::wstring* exe) {
if (!args->GetNext(exe) && !GetProcessExecPath(exe)) { if (!args->GetNext(exe) && !GetProcessExecPath(exe)) {
return false; return false;
} }
// Read in optional args arg // Read in optional args arg
std::vector<std::u16string> launch_args; std::vector<std::wstring> launch_args;
if (args->GetNext(&launch_args) && !launch_args.empty()) if (args->GetNext(&launch_args) && !launch_args.empty())
*exe = base::StringPrintf(L"\"%ls\" %ls \"%%1\"", exe->c_str(), *exe = base::StringPrintf(L"\"%ls\" %ls \"%%1\"", exe->c_str(),
base::JoinString(launch_args, L" ").c_str()); base::JoinString(launch_args, L" ").c_str());
@ -75,7 +75,7 @@ bool GetProtocolLaunchPath(gin::Arguments* args, std::u16string* exe) {
// Windows treats a given scheme as an Internet scheme only if its registry // Windows treats a given scheme as an Internet scheme only if its registry
// entry has a "URL Protocol" key. Check this, otherwise we allow ProgIDs to be // entry has a "URL Protocol" key. Check this, otherwise we allow ProgIDs to be
// used as custom protocols which leads to security bugs. // used as custom protocols which leads to security bugs.
bool IsValidCustomProtocol(const std::u16string& scheme) { bool IsValidCustomProtocol(const std::wstring& scheme) {
if (scheme.empty()) if (scheme.empty())
return false; return false;
base::win::RegKey cmd_key(HKEY_CLASSES_ROOT, scheme.c_str(), KEY_QUERY_VALUE); base::win::RegKey cmd_key(HKEY_CLASSES_ROOT, scheme.c_str(), KEY_QUERY_VALUE);
@ -90,11 +90,10 @@ bool IsValidCustomProtocol(const std::u16string& scheme) {
// Windows 8 introduced a new protocol->executable binding system which cannot // Windows 8 introduced a new protocol->executable binding system which cannot
// be retrieved in the HKCR registry subkey method implemented below. We call // be retrieved in the HKCR registry subkey method implemented below. We call
// AssocQueryString with the new Win8-only flag ASSOCF_IS_PROTOCOL instead. // AssocQueryString with the new Win8-only flag ASSOCF_IS_PROTOCOL instead.
std::u16string GetAppInfoHelperForProtocol(ASSOCSTR assoc_str, std::wstring GetAppInfoHelperForProtocol(ASSOCSTR assoc_str, const GURL& url) {
const GURL& url) { const std::wstring url_scheme = base::ASCIIToWide(url.scheme());
const std::u16string url_scheme = base::ASCIIToUTF16(url.scheme());
if (!IsValidCustomProtocol(url_scheme)) if (!IsValidCustomProtocol(url_scheme))
return std::u16string(); return std::wstring();
wchar_t out_buffer[1024]; wchar_t out_buffer[1024];
DWORD buffer_size = base::size(out_buffer); DWORD buffer_size = base::size(out_buffer);
@ -103,13 +102,13 @@ std::u16string GetAppInfoHelperForProtocol(ASSOCSTR assoc_str,
out_buffer, &buffer_size); out_buffer, &buffer_size);
if (FAILED(hr)) { if (FAILED(hr)) {
DLOG(WARNING) << "AssocQueryString failed!"; DLOG(WARNING) << "AssocQueryString failed!";
return std::u16string(); return std::wstring();
} }
return std::u16string(out_buffer); return std::wstring(out_buffer);
} }
void OnIconDataAvailable(const base::FilePath& app_path, void OnIconDataAvailable(const base::FilePath& app_path,
const std::u16string& app_display_name, const std::wstring& app_display_name,
gin_helper::Promise<gin_helper::Dictionary> promise, gin_helper::Promise<gin_helper::Dictionary> promise,
gfx::Image icon) { gfx::Image icon) {
if (!icon.IsEmpty()) { if (!icon.IsEmpty()) {
@ -126,21 +125,21 @@ void OnIconDataAvailable(const base::FilePath& app_path,
} }
} }
std::u16string GetAppDisplayNameForProtocol(const GURL& url) { std::wstring GetAppDisplayNameForProtocol(const GURL& url) {
return GetAppInfoHelperForProtocol(ASSOCSTR_FRIENDLYAPPNAME, url); return GetAppInfoHelperForProtocol(ASSOCSTR_FRIENDLYAPPNAME, url);
} }
std::u16string GetAppPathForProtocol(const GURL& url) { std::wstring GetAppPathForProtocol(const GURL& url) {
return GetAppInfoHelperForProtocol(ASSOCSTR_EXECUTABLE, url); return GetAppInfoHelperForProtocol(ASSOCSTR_EXECUTABLE, url);
} }
std::u16string GetAppForProtocolUsingRegistry(const GURL& url) { std::wstring GetAppForProtocolUsingRegistry(const GURL& url) {
const std::u16string url_scheme = base::ASCIIToUTF16(url.scheme()); const std::wstring url_scheme = base::ASCIIToWide(url.scheme());
if (!IsValidCustomProtocol(url_scheme)) if (!IsValidCustomProtocol(url_scheme))
return std::u16string(); return std::wstring();
// First, try and extract the application's display name. // First, try and extract the application's display name.
std::u16string command_to_launch; std::wstring command_to_launch;
base::win::RegKey cmd_key_name(HKEY_CLASSES_ROOT, url_scheme.c_str(), base::win::RegKey cmd_key_name(HKEY_CLASSES_ROOT, url_scheme.c_str(),
KEY_READ); KEY_READ);
if (cmd_key_name.ReadValue(NULL, &command_to_launch) == ERROR_SUCCESS && if (cmd_key_name.ReadValue(NULL, &command_to_launch) == ERROR_SUCCESS &&
@ -150,7 +149,7 @@ std::u16string GetAppForProtocolUsingRegistry(const GURL& url) {
// Otherwise, parse the command line in the registry, and return the basename // Otherwise, parse the command line in the registry, and return the basename
// of the program path if it exists. // of the program path if it exists.
const std::u16string cmd_key_path = url_scheme + L"\\shell\\open\\command"; const std::wstring cmd_key_path = url_scheme + L"\\shell\\open\\command";
base::win::RegKey cmd_key_exe(HKEY_CLASSES_ROOT, cmd_key_path.c_str(), base::win::RegKey cmd_key_exe(HKEY_CLASSES_ROOT, cmd_key_path.c_str(),
KEY_READ); KEY_READ);
if (cmd_key_exe.ReadValue(NULL, &command_to_launch) == ERROR_SUCCESS) { if (cmd_key_exe.ReadValue(NULL, &command_to_launch) == ERROR_SUCCESS) {
@ -159,18 +158,20 @@ std::u16string GetAppForProtocolUsingRegistry(const GURL& url) {
return command_line.GetProgram().BaseName().value(); return command_line.GetProgram().BaseName().value();
} }
return std::u16string(); return std::wstring();
} }
bool FormatCommandLineString(std::u16string* exe, bool FormatCommandLineString(std::wstring* exe,
const std::vector<std::u16string>& launch_args) { const std::vector<std::u16string>& launch_args) {
if (exe->empty() && !GetProcessExecPath(exe)) { if (exe->empty() && !GetProcessExecPath(exe)) {
return false; return false;
} }
if (!launch_args.empty()) { if (!launch_args.empty()) {
std::u16string joined_launch_args =
base::JoinString(launch_args, base::UTF8ToUTF16(" "));
*exe = base::StringPrintf(L"%ls %ls", exe->c_str(), *exe = base::StringPrintf(L"%ls %ls", exe->c_str(),
base::JoinString(launch_args, L" ").c_str()); base::UTF16ToWide(joined_launch_args).c_str());
} }
return true; return true;
@ -184,18 +185,20 @@ bool FormatCommandLineString(std::u16string* exe,
std::vector<Browser::LaunchItem> GetLoginItemSettingsHelper( std::vector<Browser::LaunchItem> GetLoginItemSettingsHelper(
base::win::RegistryValueIterator* it, base::win::RegistryValueIterator* it,
boolean* executable_will_launch_at_login, boolean* executable_will_launch_at_login,
std::u16string scope, std::wstring scope,
const Browser::LoginItemSettings& options) { const Browser::LoginItemSettings& options) {
std::vector<Browser::LaunchItem> launch_items; std::vector<Browser::LaunchItem> launch_items;
base::FilePath lookup_exe_path; base::FilePath lookup_exe_path;
if (options.path.empty()) { if (options.path.empty()) {
std::u16string process_exe_path; std::wstring process_exe_path;
GetProcessExecPath(&process_exe_path); GetProcessExecPath(&process_exe_path);
lookup_exe_path = lookup_exe_path =
base::CommandLine::FromString(process_exe_path).GetProgram(); base::CommandLine::FromString(process_exe_path).GetProgram();
} else { } else {
lookup_exe_path = base::CommandLine::FromString(options.path).GetProgram(); lookup_exe_path =
base::CommandLine::FromString(base::UTF16ToWide(options.path))
.GetProgram();
} }
if (!lookup_exe_path.empty()) { if (!lookup_exe_path.empty()) {
@ -287,7 +290,7 @@ Browser::UserTask::~UserTask() = default;
void GetFileIcon(const base::FilePath& path, void GetFileIcon(const base::FilePath& path,
v8::Isolate* isolate, v8::Isolate* isolate,
base::CancelableTaskTracker* cancelable_task_tracker_, base::CancelableTaskTracker* cancelable_task_tracker_,
const std::u16string app_display_name, const std::wstring app_display_name,
gin_helper::Promise<gin_helper::Dictionary> promise) { gin_helper::Promise<gin_helper::Dictionary> promise) {
base::FilePath normalized_path = path.NormalizePathSeparators(); base::FilePath normalized_path = path.NormalizePathSeparators();
IconLoader::IconSize icon_size = IconLoader::IconSize::LARGE; IconLoader::IconSize icon_size = IconLoader::IconSize::LARGE;
@ -316,13 +319,13 @@ void GetApplicationInfoForProtocolUsingRegistry(
base::CancelableTaskTracker* cancelable_task_tracker_) { base::CancelableTaskTracker* cancelable_task_tracker_) {
base::FilePath app_path; base::FilePath app_path;
const std::u16string url_scheme = base::ASCIIToUTF16(url.scheme()); const std::wstring url_scheme = base::ASCIIToWide(url.scheme());
if (!IsValidCustomProtocol(url_scheme)) { if (!IsValidCustomProtocol(url_scheme)) {
promise.RejectWithErrorMessage("invalid url_scheme"); promise.RejectWithErrorMessage("invalid url_scheme");
return; return;
} }
std::u16string command_to_launch; std::wstring command_to_launch;
const std::u16string cmd_key_path = url_scheme + L"\\shell\\open\\command"; const std::wstring cmd_key_path = url_scheme + L"\\shell\\open\\command";
base::win::RegKey cmd_key_exe(HKEY_CLASSES_ROOT, cmd_key_path.c_str(), base::win::RegKey cmd_key_exe(HKEY_CLASSES_ROOT, cmd_key_path.c_str(),
KEY_READ); KEY_READ);
if (cmd_key_exe.ReadValue(NULL, &command_to_launch) == ERROR_SUCCESS) { if (cmd_key_exe.ReadValue(NULL, &command_to_launch) == ERROR_SUCCESS) {
@ -334,7 +337,7 @@ void GetApplicationInfoForProtocolUsingRegistry(
"Unable to retrieve installation path to app"); "Unable to retrieve installation path to app");
return; return;
} }
const std::u16string app_display_name = GetAppForProtocolUsingRegistry(url); const std::wstring app_display_name = GetAppForProtocolUsingRegistry(url);
if (app_display_name.empty()) { if (app_display_name.empty()) {
promise.RejectWithErrorMessage( promise.RejectWithErrorMessage(
@ -354,7 +357,7 @@ void GetApplicationInfoForProtocolUsingAssocQuery(
const GURL& url, const GURL& url,
gin_helper::Promise<gin_helper::Dictionary> promise, gin_helper::Promise<gin_helper::Dictionary> promise,
base::CancelableTaskTracker* cancelable_task_tracker_) { base::CancelableTaskTracker* cancelable_task_tracker_) {
std::u16string app_path = GetAppPathForProtocol(url); std::wstring app_path = GetAppPathForProtocol(url);
if (app_path.empty()) { if (app_path.empty()) {
promise.RejectWithErrorMessage( promise.RejectWithErrorMessage(
@ -362,7 +365,7 @@ void GetApplicationInfoForProtocolUsingAssocQuery(
return; return;
} }
std::u16string app_display_name = GetAppDisplayNameForProtocol(url); std::wstring app_display_name = GetAppDisplayNameForProtocol(url);
if (app_display_name.empty()) { if (app_display_name.empty()) {
promise.RejectWithErrorMessage("Unable to retrieve display name of app"); promise.RejectWithErrorMessage("Unable to retrieve display name of app");
@ -426,12 +429,12 @@ bool Browser::RemoveAsDefaultProtocolClient(const std::string& protocol,
// Main Registry Key // Main Registry Key
HKEY root = HKEY_CURRENT_USER; HKEY root = HKEY_CURRENT_USER;
std::u16string keyPath = L"Software\\Classes\\"; std::wstring keyPath = L"Software\\Classes\\";
// Command Key // Command Key
std::u16string wprotocol = base::UTF8ToUTF16(protocol); std::wstring wprotocol = base::UTF8ToWide(protocol);
std::u16string shellPath = wprotocol + L"\\shell"; std::wstring shellPath = wprotocol + L"\\shell";
std::u16string cmdPath = keyPath + shellPath + L"\\open\\command"; std::wstring cmdPath = keyPath + shellPath + L"\\open\\command";
base::win::RegKey classesKey; base::win::RegKey classesKey;
base::win::RegKey commandKey; base::win::RegKey commandKey;
@ -445,12 +448,12 @@ bool Browser::RemoveAsDefaultProtocolClient(const std::string& protocol,
// Key doesn't even exist, we can confirm that it is not set // Key doesn't even exist, we can confirm that it is not set
return true; return true;
std::u16string keyVal; std::wstring keyVal;
if (FAILED(commandKey.ReadValue(L"", &keyVal))) if (FAILED(commandKey.ReadValue(L"", &keyVal)))
// Default value not set, we can confirm that it is not set // Default value not set, we can confirm that it is not set
return true; return true;
std::u16string exe; std::wstring exe;
if (!GetProtocolLaunchPath(args, &exe)) if (!GetProtocolLaunchPath(args, &exe))
return false; return false;
@ -461,7 +464,7 @@ bool Browser::RemoveAsDefaultProtocolClient(const std::string& protocol,
// Let's clean up after ourselves // Let's clean up after ourselves
base::win::RegKey protocolKey; base::win::RegKey protocolKey;
std::u16string protocolPath = keyPath + wprotocol; std::wstring protocolPath = keyPath + wprotocol;
if (SUCCEEDED( if (SUCCEEDED(
protocolKey.Open(root, protocolPath.c_str(), KEY_ALL_ACCESS))) { protocolKey.Open(root, protocolPath.c_str(), KEY_ALL_ACCESS))) {
@ -500,17 +503,17 @@ bool Browser::SetAsDefaultProtocolClient(const std::string& protocol,
if (protocol.empty()) if (protocol.empty())
return false; return false;
std::u16string exe; std::wstring exe;
if (!GetProtocolLaunchPath(args, &exe)) if (!GetProtocolLaunchPath(args, &exe))
return false; return false;
// Main Registry Key // Main Registry Key
HKEY root = HKEY_CURRENT_USER; HKEY root = HKEY_CURRENT_USER;
std::u16string keyPath = base::UTF8ToUTF16("Software\\Classes\\" + protocol); std::wstring keyPath = base::UTF8ToWide("Software\\Classes\\" + protocol);
std::u16string urlDecl = base::UTF8ToUTF16("URL:" + protocol); std::wstring urlDecl = base::UTF8ToWide("URL:" + protocol);
// Command Key // Command Key
std::u16string cmdPath = keyPath + L"\\shell\\open\\command"; std::wstring cmdPath = keyPath + L"\\shell\\open\\command";
// Write information to registry // Write information to registry
base::win::RegKey key(root, keyPath.c_str(), KEY_ALL_ACCESS); base::win::RegKey key(root, keyPath.c_str(), KEY_ALL_ACCESS);
@ -530,16 +533,16 @@ bool Browser::IsDefaultProtocolClient(const std::string& protocol,
if (protocol.empty()) if (protocol.empty())
return false; return false;
std::u16string exe; std::wstring exe;
if (!GetProtocolLaunchPath(args, &exe)) if (!GetProtocolLaunchPath(args, &exe))
return false; return false;
// Main Registry Key // Main Registry Key
HKEY root = HKEY_CURRENT_USER; HKEY root = HKEY_CURRENT_USER;
std::u16string keyPath = base::UTF8ToUTF16("Software\\Classes\\" + protocol); std::wstring keyPath = base::UTF8ToWide("Software\\Classes\\" + protocol);
// Command Key // Command Key
std::u16string cmdPath = keyPath + L"\\shell\\open\\command"; std::wstring cmdPath = keyPath + L"\\shell\\open\\command";
base::win::RegKey key; base::win::RegKey key;
base::win::RegKey commandKey; base::win::RegKey commandKey;
@ -551,7 +554,7 @@ bool Browser::IsDefaultProtocolClient(const std::string& protocol,
// Key doesn't exist, we can confirm that it is not set // Key doesn't exist, we can confirm that it is not set
return false; return false;
std::u16string keyVal; std::wstring keyVal;
if (FAILED(commandKey.ReadValue(L"", &keyVal))) if (FAILED(commandKey.ReadValue(L"", &keyVal)))
// Default value not set, we can confirm that it is not set // Default value not set, we can confirm that it is not set
return false; return false;
@ -563,12 +566,12 @@ bool Browser::IsDefaultProtocolClient(const std::string& protocol,
std::u16string Browser::GetApplicationNameForProtocol(const GURL& url) { std::u16string Browser::GetApplicationNameForProtocol(const GURL& url) {
// Windows 8 or above has a new protocol association query. // Windows 8 or above has a new protocol association query.
if (base::win::GetVersion() >= base::win::Version::WIN8) { if (base::win::GetVersion() >= base::win::Version::WIN8) {
std::u16string application_name = GetAppDisplayNameForProtocol(url); std::wstring application_name = GetAppDisplayNameForProtocol(url);
if (!application_name.empty()) if (!application_name.empty())
return application_name; return base::WideToUTF16(application_name);
} }
return GetAppForProtocolUsingRegistry(url); return base::WideToUTF16(GetAppForProtocolUsingRegistry(url));
} }
v8::Local<v8::Promise> Browser::GetApplicationInfoForProtocol( v8::Local<v8::Promise> Browser::GetApplicationInfoForProtocol(
@ -686,11 +689,10 @@ void Browser::UpdateBadgeContents(
} }
void Browser::SetLoginItemSettings(LoginItemSettings settings) { void Browser::SetLoginItemSettings(LoginItemSettings settings) {
std::u16string key_path = std::wstring key_path = L"Software\\Microsoft\\Windows\\CurrentVersion\\Run";
L"Software\\Microsoft\\Windows\\CurrentVersion\\Run";
base::win::RegKey key(HKEY_CURRENT_USER, key_path.c_str(), KEY_ALL_ACCESS); base::win::RegKey key(HKEY_CURRENT_USER, key_path.c_str(), KEY_ALL_ACCESS);
std::u16string startup_approved_key_path = std::wstring startup_approved_key_path =
L"Software\\Microsoft\\Windows\\CurrentVersion\\Explorer\\StartupApproved" L"Software\\Microsoft\\Windows\\CurrentVersion\\Explorer\\StartupApproved"
L"\\Run"; L"\\Run";
base::win::RegKey startup_approved_key( base::win::RegKey startup_approved_key(
@ -699,7 +701,7 @@ void Browser::SetLoginItemSettings(LoginItemSettings settings) {
!settings.name.empty() ? settings.name.c_str() : GetAppUserModelID(); !settings.name.empty() ? settings.name.c_str() : GetAppUserModelID();
if (settings.open_at_login) { if (settings.open_at_login) {
std::u16string exe = settings.path; std::wstring exe = base::UTF16ToWide(settings.path);
if (FormatCommandLineString(&exe, settings.args)) { if (FormatCommandLineString(&exe, settings.args)) {
key.WriteValue(key_name, exe.c_str()); key.WriteValue(key_name, exe.c_str());
@ -732,13 +734,13 @@ void Browser::SetLoginItemSettings(LoginItemSettings settings) {
Browser::LoginItemSettings Browser::GetLoginItemSettings( Browser::LoginItemSettings Browser::GetLoginItemSettings(
const LoginItemSettings& options) { const LoginItemSettings& options) {
LoginItemSettings settings; LoginItemSettings settings;
std::u16string keyPath = L"Software\\Microsoft\\Windows\\CurrentVersion\\Run"; std::wstring keyPath = L"Software\\Microsoft\\Windows\\CurrentVersion\\Run";
base::win::RegKey key(HKEY_CURRENT_USER, keyPath.c_str(), KEY_ALL_ACCESS); base::win::RegKey key(HKEY_CURRENT_USER, keyPath.c_str(), KEY_ALL_ACCESS);
std::u16string keyVal; std::wstring keyVal;
// keep old openAtLogin behaviour // keep old openAtLogin behaviour
if (!FAILED(key.ReadValue(GetAppUserModelID(), &keyVal))) { if (!FAILED(key.ReadValue(GetAppUserModelID(), &keyVal))) {
std::u16string exe = options.path; std::wstring exe = base::UTF16ToWide(options.path);
if (FormatCommandLineString(&exe, options.args)) { if (FormatCommandLineString(&exe, options.args)) {
settings.open_at_login = keyVal == exe; settings.open_at_login = keyVal == exe;
} }

View file

@ -920,7 +920,7 @@ ElectronBrowserClient::CreateWindowForPictureInPicture(
content::PictureInPictureWindowController* controller) { content::PictureInPictureWindowController* controller) {
auto overlay_window = content::OverlayWindow::Create(controller); auto overlay_window = content::OverlayWindow::Create(controller);
#if defined(OS_WIN) #if defined(OS_WIN)
std::u16string app_user_model_id = Browser::Get()->GetAppUserModelID(); std::wstring app_user_model_id = Browser::Get()->GetAppUserModelID();
if (!app_user_model_id.empty()) { if (!app_user_model_id.empty()) {
auto* overlay_window_view = auto* overlay_window_view =
static_cast<OverlayWindowViews*>(overlay_window.get()); static_cast<OverlayWindowViews*>(overlay_window.get());

View file

@ -72,7 +72,7 @@ bool NotificationPresenterWin::Init() {
return temp_dir_.CreateUniqueTempDir(); return temp_dir_.CreateUniqueTempDir();
} }
std::u16string NotificationPresenterWin::SaveIconToFilesystem( std::wstring NotificationPresenterWin::SaveIconToFilesystem(
const SkBitmap& icon, const SkBitmap& icon,
const GURL& origin) { const GURL& origin) {
std::string filename; std::string filename;
@ -85,12 +85,12 @@ std::u16string NotificationPresenterWin::SaveIconToFilesystem(
} }
base::ThreadRestrictions::ScopedAllowIO allow_io; base::ThreadRestrictions::ScopedAllowIO allow_io;
base::FilePath path = temp_dir_.GetPath().Append(base::UTF8ToUTF16(filename)); base::FilePath path = temp_dir_.GetPath().Append(base::UTF8ToWide(filename));
if (base::PathExists(path)) if (base::PathExists(path))
return path.value(); return path.value();
if (SaveIconToPath(icon, path)) if (SaveIconToPath(icon, path))
return path.value(); return path.value();
return base::UTF8ToUTF16(origin.spec()); return base::UTF8ToWide(origin.spec());
} }
Notification* NotificationPresenterWin::CreateNotificationObject( Notification* NotificationPresenterWin::CreateNotificationObject(

View file

@ -38,7 +38,7 @@ class NotificationPresenterWin : public NotificationPresenter {
bool Init(); bool Init();
std::u16string SaveIconToFilesystem(const SkBitmap& icon, const GURL& origin); std::wstring SaveIconToFilesystem(const SkBitmap& icon, const GURL& origin);
private: private:
Notification* CreateNotificationObject( Notification* CreateNotificationObject(

View file

@ -13,6 +13,7 @@
#include <utility> #include <utility>
#include <vector> #include <vector>
#include "base/strings/utf_string_conversions.h"
#include "third_party/skia/include/core/SkBitmap.h" #include "third_party/skia/include/core/SkBitmap.h"
namespace electron { namespace electron {
@ -49,13 +50,15 @@ void Win32Notification::Show(const NotificationOptions& options) {
existing->tag_.clear(); existing->tag_.clear();
this->notification_ref_ = std::move(existing->notification_ref_); this->notification_ref_ = std::move(existing->notification_ref_);
this->notification_ref_.Set(options.title, options.msg, image); this->notification_ref_.Set(base::UTF16ToWide(options.title),
base::UTF16ToWide(options.msg), image);
// Need to remove the entry in the notifications set that // Need to remove the entry in the notifications set that
// NotificationPresenter is holding // NotificationPresenter is holding
existing->Destroy(); existing->Destroy();
} else { } else {
this->notification_ref_ = this->notification_ref_ =
presenter->AddNotification(options.title, options.msg, image); presenter->AddNotification(base::UTF16ToWide(options.title),
base::UTF16ToWide(options.msg), image);
} }
this->tag_ = options.tag; this->tag_ = options.tag;

View file

@ -21,7 +21,7 @@
#include "shell/browser/notifications/win/notification_presenter_win.h" #include "shell/browser/notifications/win/notification_presenter_win.h"
#include "shell/browser/win/scoped_hstring.h" #include "shell/browser/win/scoped_hstring.h"
#include "shell/common/application_info.h" #include "shell/common/application_info.h"
#include "ui/base/l10n/l10n_util.h" #include "ui/base/l10n/l10n_util_win.h"
#include "ui/strings/grit/ui_strings.h" #include "ui/strings/grit/ui_strings.h"
using ABI::Windows::Data::Xml::Dom::IXmlAttribute; using ABI::Windows::Data::Xml::Dom::IXmlAttribute;
@ -132,15 +132,18 @@ HRESULT WindowsToastNotification::ShowInternal(
// The custom xml takes priority over the preset template. // The custom xml takes priority over the preset template.
if (!options.toast_xml.empty()) { if (!options.toast_xml.empty()) {
REPORT_AND_RETURN_IF_FAILED( REPORT_AND_RETURN_IF_FAILED(
XmlDocumentFromString(options.toast_xml.c_str(), &toast_xml), XmlDocumentFromString(base::UTF16ToWide(options.toast_xml).c_str(),
&toast_xml),
"XML: Invalid XML"); "XML: Invalid XML");
} else { } else {
auto* presenter_win = static_cast<NotificationPresenterWin*>(presenter()); auto* presenter_win = static_cast<NotificationPresenterWin*>(presenter());
std::wstring icon_path = std::wstring icon_path =
presenter_win->SaveIconToFilesystem(options.icon, options.icon_url); presenter_win->SaveIconToFilesystem(options.icon, options.icon_url);
REPORT_AND_RETURN_IF_FAILED( REPORT_AND_RETURN_IF_FAILED(
GetToastXml(toast_manager_.Get(), options.title, options.msg, icon_path, GetToastXml(toast_manager_.Get(), base::UTF16ToWide(options.title),
options.timeout_type, options.silent, &toast_xml), base::UTF16ToWide(options.msg), icon_path,
base::UTF16ToWide(options.timeout_type), options.silent,
&toast_xml),
"XML: Failed to create XML document"); "XML: Failed to create XML document");
} }
@ -211,7 +214,7 @@ HRESULT WindowsToastNotification::GetToastXml(
} }
// Configure the toast's timeout settings // Configure the toast's timeout settings
if (timeout_type == base::ASCIIToUTF16("never")) { if (timeout_type == base::ASCIIToWide("never")) {
REPORT_AND_RETURN_IF_FAILED( REPORT_AND_RETURN_IF_FAILED(
(SetXmlScenarioReminder(*toast_xml)), (SetXmlScenarioReminder(*toast_xml)),
"XML: Setting \"scenario\" option on notification failed"); "XML: Setting \"scenario\" option on notification failed");
@ -379,7 +382,7 @@ HRESULT WindowsToastNotification::SetXmlScenarioReminder(IXmlDocument* doc) {
RETURN_IF_FAILED(content_attribute.As(&content_attribute_node)); RETURN_IF_FAILED(content_attribute.As(&content_attribute_node));
// Set content attribute to Dismiss // Set content attribute to Dismiss
ScopedHString content_value(l10n_util::GetStringUTF16(IDS_APP_CLOSE)); ScopedHString content_value(l10n_util::GetWideString(IDS_APP_CLOSE));
if (!content_value.success()) if (!content_value.success())
return E_FAIL; return E_FAIL;

View file

@ -118,10 +118,10 @@ static void ApplySettings(IFileDialog* dialog, const DialogSettings& settings) {
dialog->SetFileName(file_part.c_str()); dialog->SetFileName(file_part.c_str());
if (!settings.title.empty()) if (!settings.title.empty())
dialog->SetTitle(base::UTF8ToUTF16(settings.title).c_str()); dialog->SetTitle(base::UTF8ToWide(settings.title).c_str());
if (!settings.button_label.empty()) if (!settings.button_label.empty())
dialog->SetOkButtonLabel(base::UTF8ToUTF16(settings.button_label).c_str()); dialog->SetOkButtonLabel(base::UTF8ToWide(settings.button_label).c_str());
std::vector<std::wstring> buffer; std::vector<std::wstring> buffer;
std::vector<COMDLG_FILTERSPEC> filterspec; std::vector<COMDLG_FILTERSPEC> filterspec;

View file

@ -39,8 +39,8 @@ struct CommonButtonID {
int button; int button;
int id; int id;
}; };
CommonButtonID GetCommonID(const std::u16string& button) { CommonButtonID GetCommonID(const std::wstring& button) {
std::u16string lower = base::ToLowerASCII(button); std::wstring lower = base::ToLowerASCII(button);
if (lower == L"ok") if (lower == L"ok")
return {TDCBF_OK_BUTTON, IDOK}; return {TDCBF_OK_BUTTON, IDOK};
else if (lower == L"yes") else if (lower == L"yes")
@ -63,15 +63,15 @@ void MapToCommonID(const std::vector<std::u16string>& buttons,
TASKDIALOG_COMMON_BUTTON_FLAGS* button_flags, TASKDIALOG_COMMON_BUTTON_FLAGS* button_flags,
std::vector<TASKDIALOG_BUTTON>* dialog_buttons) { std::vector<TASKDIALOG_BUTTON>* dialog_buttons) {
for (size_t i = 0; i < buttons.size(); ++i) { for (size_t i = 0; i < buttons.size(); ++i) {
auto common = GetCommonID(buttons[i]); auto common = GetCommonID(base::UTF16ToWide(buttons[i]));
if (common.button != -1) { if (common.button != -1) {
// It is a common button. // It is a common button.
(*id_map)[common.id] = i; (*id_map)[common.id] = i;
(*button_flags) |= common.button; (*button_flags) |= common.button;
} else { } else {
// It is a custom button. // It is a custom button.
dialog_buttons->push_back( dialog_buttons->push_back({static_cast<int>(i + kIDStart),
{static_cast<int>(i + kIDStart), buttons[i].c_str()}); base::UTF16ToWide(buttons[i]).c_str()});
} }
} }
} }
@ -107,11 +107,11 @@ DialogResult ShowTaskDialogUTF16(NativeWindow* parent,
// TaskDialogIndirect doesn't allow empty name, if we set empty title it // TaskDialogIndirect doesn't allow empty name, if we set empty title it
// will show "electron.exe" in title. // will show "electron.exe" in title.
std::u16string app_name = base::UTF8ToUTF16(Browser::Get()->GetName()); std::wstring app_name = base::UTF8ToWide(Browser::Get()->GetName());
if (title.empty()) if (title.empty())
config.pszWindowTitle = app_name.c_str(); config.pszWindowTitle = app_name.c_str();
else else
config.pszWindowTitle = title.c_str(); config.pszWindowTitle = base::UTF16ToWide(title).c_str();
base::win::ScopedHICON hicon; base::win::ScopedHICON hicon;
if (!icon.isNull()) { if (!icon.isNull()) {
@ -138,14 +138,14 @@ DialogResult ShowTaskDialogUTF16(NativeWindow* parent,
// If "detail" is empty then don't make message highlighted. // If "detail" is empty then don't make message highlighted.
if (detail.empty()) { if (detail.empty()) {
config.pszContent = message.c_str(); config.pszContent = base::UTF16ToWide(message).c_str();
} else { } else {
config.pszMainInstruction = message.c_str(); config.pszMainInstruction = base::UTF16ToWide(message).c_str();
config.pszContent = detail.c_str(); config.pszContent = base::UTF16ToWide(detail).c_str();
} }
if (!checkbox_label.empty()) { if (!checkbox_label.empty()) {
config.pszVerificationText = checkbox_label.c_str(); config.pszVerificationText = base::UTF16ToWide(checkbox_label).c_str();
if (checkbox_checked) if (checkbox_checked)
config.dwFlags |= TDF_VERIFICATION_FLAG_CHECKED; config.dwFlags |= TDF_VERIFICATION_FLAG_CHECKED;
} }
@ -156,8 +156,8 @@ DialogResult ShowTaskDialogUTF16(NativeWindow* parent,
std::vector<TASKDIALOG_BUTTON> dialog_buttons; std::vector<TASKDIALOG_BUTTON> dialog_buttons;
if (no_link) { if (no_link) {
for (size_t i = 0; i < buttons.size(); ++i) for (size_t i = 0; i < buttons.size(); ++i)
dialog_buttons.push_back( dialog_buttons.push_back({static_cast<int>(i + kIDStart),
{static_cast<int>(i + kIDStart), buttons[i].c_str()}); base::UTF16ToWide(buttons[i]).c_str()});
} else { } else {
MapToCommonID(buttons, &id_map, &config.dwCommonButtons, &dialog_buttons); MapToCommonID(buttons, &id_map, &config.dwCommonButtons, &dialog_buttons);
} }
@ -222,7 +222,8 @@ void ShowMessageBox(const MessageBoxSettings& settings,
void ShowErrorBox(const std::u16string& title, const std::u16string& content) { void ShowErrorBox(const std::u16string& title, const std::u16string& content) {
electron::UnresponsiveSuppressor suppressor; electron::UnresponsiveSuppressor suppressor;
ShowTaskDialogUTF16(nullptr, MessageBoxType::kError, {}, -1, 0, false, ShowTaskDialogUTF16(nullptr, MessageBoxType::kError, {}, -1, 0, false,
L"Error", title, content, L"", false, gfx::ImageSkia()); base::UTF8ToUTF16("Error"), title, content,
base::UTF8ToUTF16(""), false, gfx::ImageSkia());
} }
} // namespace electron } // namespace electron

View file

@ -158,7 +158,7 @@ JumpListCategory::JumpListCategory() = default;
JumpListCategory::JumpListCategory(const JumpListCategory&) = default; JumpListCategory::JumpListCategory(const JumpListCategory&) = default;
JumpListCategory::~JumpListCategory() = default; JumpListCategory::~JumpListCategory() = default;
JumpList::JumpList(const std::u16string& app_id) : app_id_(app_id) { JumpList::JumpList(const std::wstring& app_id) : app_id_(app_id) {
destinations_.CoCreateInstance(CLSID_DestinationList); destinations_.CoCreateInstance(CLSID_DestinationList);
} }

View file

@ -46,9 +46,9 @@ struct JumpListItem {
// For tasks this is the path to the program executable, for file links this // For tasks this is the path to the program executable, for file links this
// is the full filename. // is the full filename.
base::FilePath path; base::FilePath path;
std::u16string arguments; std::wstring arguments;
std::u16string title; std::wstring title;
std::u16string description; std::wstring description;
base::FilePath working_dir; base::FilePath working_dir;
base::FilePath icon_path; base::FilePath icon_path;
int icon_index = 0; int icon_index = 0;
@ -73,7 +73,7 @@ struct JumpListCategory {
}; };
Type type = Type::kTasks; Type type = Type::kTasks;
std::u16string name; std::wstring name;
std::vector<JumpListItem> items; std::vector<JumpListItem> items;
JumpListCategory(); JumpListCategory();
@ -88,7 +88,7 @@ class JumpList {
// |app_id| must be the Application User Model ID of the app for which the // |app_id| must be the Application User Model ID of the app for which the
// custom Jump List should be created/removed, it's usually obtained by // custom Jump List should be created/removed, it's usually obtained by
// calling GetCurrentProcessExplicitAppUserModelID(). // calling GetCurrentProcessExplicitAppUserModelID().
explicit JumpList(const std::u16string& app_id); explicit JumpList(const std::wstring& app_id);
~JumpList(); ~JumpList();
// Starts a new transaction, must be called before appending any categories, // Starts a new transaction, must be called before appending any categories,
@ -111,7 +111,7 @@ class JumpList {
const std::vector<JumpListCategory>& categories); const std::vector<JumpListCategory>& categories);
private: private:
std::u16string app_id_; std::wstring app_id_;
CComPtr<ICustomDestinationList> destinations_; CComPtr<ICustomDestinationList> destinations_;
DISALLOW_COPY_AND_ASSIGN(JumpList); DISALLOW_COPY_AND_ASSIGN(JumpList);

View file

@ -141,7 +141,7 @@ void NotifyIcon::SetToolTip(const std::string& tool_tip) {
NOTIFYICONDATA icon_data; NOTIFYICONDATA icon_data;
InitIconData(&icon_data); InitIconData(&icon_data);
icon_data.uFlags |= NIF_TIP; icon_data.uFlags |= NIF_TIP;
wcsncpy_s(icon_data.szTip, base::UTF8ToUTF16(tool_tip).c_str(), _TRUNCATE); wcsncpy_s(icon_data.szTip, base::UTF8ToWide(tool_tip).c_str(), _TRUNCATE);
BOOL result = Shell_NotifyIcon(NIM_MODIFY, &icon_data); BOOL result = Shell_NotifyIcon(NIM_MODIFY, &icon_data);
if (!result) if (!result)
LOG(WARNING) << "Unable to set tooltip for status tray icon"; LOG(WARNING) << "Unable to set tooltip for status tray icon";
@ -151,8 +151,10 @@ void NotifyIcon::DisplayBalloon(const BalloonOptions& options) {
NOTIFYICONDATA icon_data; NOTIFYICONDATA icon_data;
InitIconData(&icon_data); InitIconData(&icon_data);
icon_data.uFlags |= NIF_INFO; icon_data.uFlags |= NIF_INFO;
wcsncpy_s(icon_data.szInfoTitle, options.title.c_str(), _TRUNCATE); wcsncpy_s(icon_data.szInfoTitle, base::UTF16ToWide(options.title).c_str(),
wcsncpy_s(icon_data.szInfo, options.content.c_str(), _TRUNCATE); _TRUNCATE);
wcsncpy_s(icon_data.szInfo, base::UTF16ToWide(options.content).c_str(),
_TRUNCATE);
icon_data.uTimeout = 0; icon_data.uTimeout = 0;
icon_data.hBalloonIcon = options.icon; icon_data.hBalloonIcon = options.icon;
icon_data.dwInfoFlags = ConvertIconType(options.icon_type); icon_data.dwInfoFlags = ConvertIconType(options.icon_type);

View file

@ -104,7 +104,7 @@ bool TaskbarHost::SetThumbarButtons(HWND window,
// Set tooltip. // Set tooltip.
if (!button.tooltip.empty()) { if (!button.tooltip.empty()) {
thumb_button.dwMask |= THB_TOOLTIP; thumb_button.dwMask |= THB_TOOLTIP;
wcsncpy_s(thumb_button.szTip, base::UTF8ToUTF16(button.tooltip).c_str(), wcsncpy_s(thumb_button.szTip, base::UTF8ToWide(button.tooltip).c_str(),
_TRUNCATE); _TRUNCATE);
} }
@ -173,7 +173,7 @@ bool TaskbarHost::SetOverlayIcon(HWND window,
base::win::ScopedHICON icon(IconUtil::CreateHICONFromSkBitmap(overlay)); base::win::ScopedHICON icon(IconUtil::CreateHICONFromSkBitmap(overlay));
return SUCCEEDED(taskbar_->SetOverlayIcon(window, icon.get(), return SUCCEEDED(taskbar_->SetOverlayIcon(window, icon.get(),
base::UTF8ToUTF16(text).c_str())); base::UTF8ToWide(text).c_str()));
} }
bool TaskbarHost::SetThumbnailClip(HWND window, const gfx::Rect& region) { bool TaskbarHost::SetThumbnailClip(HWND window, const gfx::Rect& region) {
@ -193,8 +193,8 @@ bool TaskbarHost::SetThumbnailToolTip(HWND window, const std::string& tooltip) {
if (!InitializeTaskbar()) if (!InitializeTaskbar())
return false; return false;
return SUCCEEDED(taskbar_->SetThumbnailTooltip( return SUCCEEDED(
window, base::UTF8ToUTF16(tooltip).c_str())); taskbar_->SetThumbnailTooltip(window, base::UTF8ToWide(tooltip).c_str()));
} }
bool TaskbarHost::HandleThumbarButtonEvent(int button_id) { bool TaskbarHost::HandleThumbarButtonEvent(int button_id) {

View file

@ -235,18 +235,24 @@ bool WebContentsPreferences::GetPreference(base::StringPiece name,
bool WebContentsPreferences::GetPreloadPath(base::FilePath* path) const { bool WebContentsPreferences::GetPreloadPath(base::FilePath* path) const {
DCHECK(path); DCHECK(path);
base::FilePath::StringType preload_path; base::FilePath::StringType preload_path;
if (GetAsString(&preference_, options::kPreloadScript, &preload_path)) { std::u16string preload_path_str;
base::FilePath preload(preload_path); if (GetAsString(&preference_, options::kPreloadScript, &preload_path_str)) {
#if defined(OS_WIN)
base::FilePath preload(base::UTF16ToWide(preload_path_str));
#else
base::FilePath preload(preload_path_str);
#endif
if (preload.IsAbsolute()) { if (preload.IsAbsolute()) {
*path = std::move(preload); *path = std::move(preload);
return true; return true;
} else { } else {
LOG(ERROR) << "preload script must have absolute path."; LOG(ERROR) << "preload script must have absolute path.";
} }
} else if (GetAsString(&preference_, options::kPreloadURL, &preload_path)) { } else if (GetAsString(&preference_, options::kPreloadURL,
&preload_path_str)) {
// Translate to file path if there is "preload-url" option. // Translate to file path if there is "preload-url" option.
base::FilePath preload; base::FilePath preload;
if (net::FileURLToFilePath(GURL(preload_path), &preload)) { if (net::FileURLToFilePath(GURL(preload_path_str), &preload)) {
*path = std::move(preload); *path = std::move(preload);
return true; return true;
} else { } else {

View file

@ -86,7 +86,7 @@ file_dialog::Filters GetFileTypesFromAcceptType(
for (const auto& extension : extensions) { for (const auto& extension : extensions) {
#if defined(OS_WIN) #if defined(OS_WIN)
filters[0].second.push_back(base::UTF16ToASCII(extension)); filters[0].second.push_back(base::WideToASCII(extension));
#else #else
filters[0].second.push_back(extension); filters[0].second.push_back(extension);
#endif #endif

View file

@ -156,7 +156,7 @@ bool NativeImage::TryConvertNativeImage(v8::Isolate* isolate,
*native_image = NativeImage::CreateFromPath(isolate, icon_path).get(); *native_image = NativeImage::CreateFromPath(isolate, icon_path).get();
if ((*native_image)->image().IsEmpty()) { if ((*native_image)->image().IsEmpty()) {
#if defined(OS_WIN) #if defined(OS_WIN)
const auto img_path = base::UTF16ToUTF8(icon_path.value()); const auto img_path = base::WideToUTF8(icon_path.value());
#else #else
const auto img_path = icon_path.value(); const auto img_path = icon_path.value();
#endif #endif

View file

@ -37,7 +37,7 @@ v8::Local<v8::Promise> NativeImage::CreateThumbnailFromPath(
// create an IShellItem // create an IShellItem
Microsoft::WRL::ComPtr<IShellItem> pItem; Microsoft::WRL::ComPtr<IShellItem> pItem;
std::wstring image_path = path.AsUTF16Unsafe(); std::wstring image_path = path.value();
hr = SHCreateItemFromParsingName(image_path.c_str(), nullptr, hr = SHCreateItemFromParsingName(image_path.c_str(), nullptr,
IID_PPV_ARGS(&pItem)); IID_PPV_ARGS(&pItem));

View file

@ -117,7 +117,7 @@ bool WriteShortcutLink(const base::FilePath& shortcut_path,
base::win::ShortcutProperties properties; base::win::ShortcutProperties properties;
base::FilePath path; base::FilePath path;
std::u16string str; std::wstring str;
UUID toastActivatorClsid; UUID toastActivatorClsid;
int index; int index;
if (options.Get("target", &path)) if (options.Get("target", &path))

View file

@ -15,6 +15,7 @@
#include "base/file_version_info.h" #include "base/file_version_info.h"
#include "base/notreached.h" #include "base/notreached.h"
#include "base/strings/string_util.h" #include "base/strings/string_util.h"
#include "base/strings/string_util_win.h"
#include "base/strings/stringprintf.h" #include "base/strings/stringprintf.h"
#include "base/strings/utf_string_conversions.h" #include "base/strings/utf_string_conversions.h"
#include "shell/browser/win/scoped_hstring.h" #include "shell/browser/win/scoped_hstring.h"
@ -23,7 +24,7 @@ namespace electron {
namespace { namespace {
std::u16string g_app_user_model_id; std::wstring g_app_user_model_id;
} }
const wchar_t kAppUserModelIDFormat[] = L"electron.app.$1"; const wchar_t kAppUserModelIDFormat[] = L"electron.app.$1";
@ -42,7 +43,7 @@ std::string GetApplicationVersion() {
return base::UTF16ToUTF8(info->product_version()); return base::UTF16ToUTF8(info->product_version());
} }
void SetAppUserModelID(const std::u16string& name) { void SetAppUserModelID(const std::wstring& name) {
g_app_user_model_id = name; g_app_user_model_id = name;
SetCurrentProcessExplicitAppUserModelID(g_app_user_model_id.c_str()); SetCurrentProcessExplicitAppUserModelID(g_app_user_model_id.c_str());
} }
@ -54,8 +55,8 @@ PCWSTR GetRawAppUserModelID() {
g_app_user_model_id = current_app_id; g_app_user_model_id = current_app_id;
} else { } else {
std::string name = GetApplicationName(); std::string name = GetApplicationName();
std::u16string generated_app_id = base::ReplaceStringPlaceholders( std::wstring generated_app_id = base::ReplaceStringPlaceholders(
kAppUserModelIDFormat, base::UTF8ToUTF16(name), nullptr); kAppUserModelIDFormat, {base::UTF8ToWide(name)}, nullptr);
SetAppUserModelID(generated_app_id); SetAppUserModelID(generated_app_id);
} }
CoTaskMemFree(current_app_id); CoTaskMemFree(current_app_id);

View file

@ -7,6 +7,7 @@
#include "base/files/file_path.h" #include "base/files/file_path.h"
#include "gin/converter.h" #include "gin/converter.h"
#include "shell/common/gin_converters/std_converter.h"
namespace gin { namespace gin {

View file

@ -11,6 +11,10 @@
#include "gin/converter.h" #include "gin/converter.h"
#if defined(OS_WIN)
#include "base/strings/string_util_win.h"
#endif
namespace gin { namespace gin {
// Make it possible to convert move-only types. // Make it possible to convert move-only types.
@ -182,6 +186,30 @@ struct Converter<std::map<K, V>> {
} }
}; };
#if defined(OS_WIN)
template <>
struct Converter<std::wstring> {
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate,
const std::wstring& val) {
return Converter<std::u16string>::ToV8(isolate, base::AsString16(val));
}
static bool FromV8(v8::Isolate* isolate,
v8::Local<v8::Value> val,
std::wstring* out) {
if (!val->IsString())
return false;
std::u16string str;
if (Converter<std::u16string>::FromV8(isolate, val, &str)) {
*out = base::AsWString(str);
return true;
} else {
return false;
}
}
};
#endif
} // namespace gin } // namespace gin
#endif // SHELL_COMMON_GIN_CONVERTERS_STD_CONVERTER_H_ #endif // SHELL_COMMON_GIN_CONVERTERS_STD_CONVERTER_H_

View file

@ -14,11 +14,6 @@ namespace electron {
// overrides from command line arguments. // overrides from command line arguments.
std::vector<std::string> GetPreferredLanguages(); std::vector<std::string> GetPreferredLanguages();
#if defined(OS_WIN)
bool GetPreferredLanguagesUsingGlobalization(
std::vector<std::u16string>* languages);
#endif
} // namespace electron } // namespace electron
#endif // SHELL_COMMON_LANGUAGE_UTIL_H_ #endif // SHELL_COMMON_LANGUAGE_UTIL_H_

View file

@ -16,24 +16,8 @@
namespace electron { namespace electron {
std::vector<std::string> GetPreferredLanguages() {
std::vector<std::u16string> languages16;
// Attempt to use API available on Windows 10 or later, which
// returns the full list of language preferences.
if (!GetPreferredLanguagesUsingGlobalization(&languages16)) {
base::win::i18n::GetThreadPreferredUILanguageList(&languages16);
}
std::vector<std::string> languages;
for (const auto& language : languages16) {
languages.push_back(base::SysWideToUTF8(language));
}
return languages;
}
bool GetPreferredLanguagesUsingGlobalization( bool GetPreferredLanguagesUsingGlobalization(
std::vector<std::u16string>* languages) { std::vector<std::wstring>* languages) {
if (base::win::GetVersion() < base::win::Version::WIN10) if (base::win::GetVersion() < base::win::Version::WIN10)
return false; return false;
if (!base::win::ResolveCoreWinRTDelayload() || if (!base::win::ResolveCoreWinRTDelayload() ||
@ -73,4 +57,20 @@ bool GetPreferredLanguagesUsingGlobalization(
return true; return true;
} }
std::vector<std::string> GetPreferredLanguages() {
std::vector<std::wstring> languages16;
// Attempt to use API available on Windows 10 or later, which
// returns the full list of language preferences.
if (!GetPreferredLanguagesUsingGlobalization(&languages16)) {
base::win::i18n::GetThreadPreferredUILanguageList(&languages16);
}
std::vector<std::string> languages;
for (const auto& language : languages16) {
languages.push_back(base::SysWideToUTF8(language));
}
return languages;
}
} // namespace electron } // namespace electron

View file

@ -214,7 +214,7 @@ void SetNodeCliFlags() {
for (const auto& arg : argv) { for (const auto& arg : argv) {
#if defined(OS_WIN) #if defined(OS_WIN)
const auto& option = base::UTF16ToUTF8(arg); const auto& option = base::WideToUTF8(arg);
#else #else
const auto& option = arg; const auto& option = arg;
#endif #endif

View file

@ -241,8 +241,8 @@ std::string OpenExternalOnWorkerThread(
// Quote the input scheme to be sure that the command does not have // Quote the input scheme to be sure that the command does not have
// parameters unexpected by the external program. This url should already // parameters unexpected by the external program. This url should already
// have been escaped. // have been escaped.
std::u16string escaped_url = L"\"" + base::UTF8ToUTF16(url.spec()) + L"\""; std::wstring escaped_url = L"\"" + base::UTF8ToWide(url.spec()) + L"\"";
std::u16string working_dir = options.working_dir.value(); std::wstring working_dir = options.working_dir.value();
if (reinterpret_cast<ULONG_PTR>( if (reinterpret_cast<ULONG_PTR>(
ShellExecuteW(nullptr, L"open", escaped_url.c_str(), nullptr, ShellExecuteW(nullptr, L"open", escaped_url.c_str(), nullptr,

View file

@ -218,7 +218,7 @@ void RendererClientBase::RenderThreadStarted() {
#if defined(OS_WIN) #if defined(OS_WIN)
// Set ApplicationUserModelID in renderer process. // Set ApplicationUserModelID in renderer process.
std::u16string app_id = std::wstring app_id =
command_line->GetSwitchValueNative(switches::kAppUserModelId); command_line->GetSwitchValueNative(switches::kAppUserModelId);
if (!app_id.empty()) { if (!app_id.empty()) {
SetCurrentProcessExplicitAppUserModelID(app_id.c_str()); SetCurrentProcessExplicitAppUserModelID(app_id.c_str());