|
@@ -9,6 +9,7 @@
|
|
|
#include "base/apple/bundle_locations.h"
|
|
|
#include "base/apple/scoped_nsautorelease_pool.h"
|
|
|
#include "base/at_exit.h"
|
|
|
+#include "base/command_line.h"
|
|
|
#include "base/i18n/icu_util.h"
|
|
|
#include "content/public/app/content_main.h"
|
|
|
#include "electron/fuses.h"
|
|
@@ -16,21 +17,22 @@
|
|
|
#include "shell/app/node_main.h"
|
|
|
#include "shell/common/electron_command_line.h"
|
|
|
#include "shell/common/mac/main_application_bundle.h"
|
|
|
+#include "uv.h"
|
|
|
|
|
|
int ElectronMain(int argc, char* argv[]) {
|
|
|
- electron::ElectronMainDelegate delegate;
|
|
|
- content::ContentMainParams params(&delegate);
|
|
|
- params.argc = argc;
|
|
|
- params.argv = const_cast<const char**>(argv);
|
|
|
+ argv = uv_setup_args(argc, argv);
|
|
|
+ base::CommandLine::Init(argc, argv);
|
|
|
electron::ElectronCommandLine::Init(argc, argv);
|
|
|
|
|
|
+ electron::ElectronMainDelegate delegate;
|
|
|
+
|
|
|
// Ensure that Bundle Id is set before ContentMain.
|
|
|
// Refs https://chromium-review.googlesource.com/c/chromium/src/+/5581006
|
|
|
delegate.OverrideChildProcessPath();
|
|
|
delegate.OverrideFrameworkBundlePath();
|
|
|
delegate.SetUpBundleOverrides();
|
|
|
|
|
|
- return content::ContentMain(std::move(params));
|
|
|
+ return content::ContentMain(content::ContentMainParams{&delegate});
|
|
|
}
|
|
|
|
|
|
int ElectronInitializeICUandStartNode(int argc, char* argv[]) {
|
|
@@ -39,6 +41,10 @@ int ElectronInitializeICUandStartNode(int argc, char* argv[]) {
|
|
|
return 1;
|
|
|
}
|
|
|
|
|
|
+ argv = uv_setup_args(argc, argv);
|
|
|
+ base::CommandLine::Init(argc, argv);
|
|
|
+ electron::ElectronCommandLine::Init(argc, argv);
|
|
|
+
|
|
|
base::AtExitManager atexit_manager;
|
|
|
base::apple::ScopedNSAutoreleasePool pool;
|
|
|
base::apple::SetOverrideFrameworkBundlePath(
|
|
@@ -47,5 +53,5 @@ int ElectronInitializeICUandStartNode(int argc, char* argv[]) {
|
|
|
.Append("Frameworks")
|
|
|
.Append(ELECTRON_PRODUCT_NAME " Framework.framework"));
|
|
|
base::i18n::InitializeICU();
|
|
|
- return electron::NodeMain(argc, argv);
|
|
|
+ return electron::NodeMain();
|
|
|
}
|