diff --git a/atom/browser/atom_browser_main_parts.cc b/atom/browser/atom_browser_main_parts.cc index 13db661a2e6..5229b19ca9a 100644 --- a/atom/browser/atom_browser_main_parts.cc +++ b/atom/browser/atom_browser_main_parts.cc @@ -154,6 +154,14 @@ void AtomBrowserMainParts::PostEarlyInitialization() { // Wrap the uv loop with global env. node_bindings_->set_uv_env(env); + + // We already initialized the feature list in + // brightray::BrowserMainParts::PreEarlyInitialization(), but + // the user JS script would not have had a chance to alter the command-line + // switches at that point. Lets reinitialize it here to pick up the + // command-line changes. + base::FeatureList::ClearInstanceForTesting(); + brightray::BrowserMainParts::InitializeFeatureList(); } int AtomBrowserMainParts::PreCreateThreads() { diff --git a/brightray/browser/browser_main_parts.cc b/brightray/browser/browser_main_parts.cc index 9349a95ea22..8fc4c1adc99 100644 --- a/brightray/browser/browser_main_parts.cc +++ b/brightray/browser/browser_main_parts.cc @@ -268,16 +268,6 @@ void BrowserMainParts::PreMainMessageLoopStart() { } void BrowserMainParts::PreMainMessageLoopRun() { - // We already initialized the feature list in PreEarlyInitialization(), but - // the user JS script would not have had a chance to alter the command-line - // switches at that point. Lets force re-initialization here to pick up the - // command-line changes. Note that some Chromium code (e.g. - // gpu_process_host.cc) queries the feature list between - // PreEarlyInitialization() and here so the user script may not have - // control over all features. Better than nothing though! - base::FeatureList::ClearInstanceForTesting(); - InitializeFeatureList(); - content::WebUIControllerFactory::RegisterFactory( WebUIControllerFactory::GetInstance()); diff --git a/brightray/browser/browser_main_parts.h b/brightray/browser/browser_main_parts.h index f8d758d0ab0..cf8e0296585 100644 --- a/brightray/browser/browser_main_parts.h +++ b/brightray/browser/browser_main_parts.h @@ -43,14 +43,14 @@ class BrowserMainParts : public content::BrowserMainParts { int PreCreateThreads() override; void PostDestroyThreads() override; + void InitializeFeatureList(); + private: #if defined(OS_MACOSX) void InitializeMainNib(); void OverrideAppLogsPath(); #endif - void InitializeFeatureList(); - std::unique_ptr io_thread_; #if defined(USE_AURA)