mirror of
				https://bitbucket.org/chromiumembedded/cef
				synced 2025-06-05 21:39:12 +02:00 
			
		
		
		
	
		
			
				
	
	
		
			144 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
			
		
		
	
	
			144 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			Diff
		
	
	
	
	
	
| diff --git chrome/app/chrome_main_delegate.cc chrome/app/chrome_main_delegate.cc
 | |
| index d9a02faddd91..09a349fcf2b8 100644
 | |
| --- chrome/app/chrome_main_delegate.cc
 | |
| +++ chrome/app/chrome_main_delegate.cc
 | |
| @@ -27,6 +27,7 @@
 | |
|  #include "base/time/time.h"
 | |
|  #include "base/trace_event/trace_event_impl.h"
 | |
|  #include "build/build_config.h"
 | |
| +#include "cef/libcef/features/runtime.h"
 | |
|  #include "chrome/browser/chrome_content_browser_client.h"
 | |
|  #include "chrome/browser/chrome_resource_bundle_helper.h"
 | |
|  #include "chrome/browser/defaults.h"
 | |
| @@ -378,6 +379,8 @@ struct MainFunction {
 | |
|  
 | |
|  // Initializes the user data dir. Must be called before InitializeLocalState().
 | |
|  void InitializeUserDataDir(base::CommandLine* command_line) {
 | |
| +  if (cef::IsChromeRuntimeEnabled())
 | |
| +    return;
 | |
|  #if defined(OS_WIN)
 | |
|    // Reach out to chrome_elf for the truth on the user data directory.
 | |
|    // Note that in tests, this links to chrome_elf_test_stubs.
 | |
| @@ -644,7 +647,9 @@ void ChromeMainDelegate::PostFieldTrialInitialization() {
 | |
|    }
 | |
|  
 | |
|  #if defined(OS_WIN)
 | |
| +  if (!cef::IsChromeRuntimeEnabled()) {
 | |
|    SetUpExtendedCrashReporting(is_browser_process);
 | |
| +  }
 | |
|    base::sequence_manager::internal::ThreadControllerPowerMonitor::
 | |
|        InitializeOnMainThread();
 | |
|  #endif
 | |
| @@ -926,6 +931,7 @@ void ChromeMainDelegate::PreSandboxStartup() {
 | |
|    std::string process_type =
 | |
|        command_line.GetSwitchValueASCII(switches::kProcessType);
 | |
|  
 | |
| +  if (!cef::IsChromeRuntimeEnabled()) {
 | |
|    crash_reporter::InitializeCrashKeys();
 | |
|  
 | |
|  #if defined(OS_POSIX)
 | |
| @@ -936,6 +942,7 @@ void ChromeMainDelegate::PreSandboxStartup() {
 | |
|    InitMacCrashReporter(command_line, process_type);
 | |
|    SetUpInstallerPreferences(command_line);
 | |
|  #endif
 | |
| +  }  // !cef::IsChromeRuntimeEnabled()
 | |
|  
 | |
|  #if defined(OS_WIN)
 | |
|    child_process_logging::Init();
 | |
| @@ -1058,6 +1065,7 @@ void ChromeMainDelegate::PreSandboxStartup() {
 | |
|          locale;
 | |
|    }
 | |
|  
 | |
| +  if (!cef::IsChromeRuntimeEnabled()) {
 | |
|  #if defined(OS_POSIX) && !defined(OS_MAC)
 | |
|    // Zygote needs to call InitCrashReporter() in RunZygote().
 | |
|    if (process_type != switches::kZygoteProcess) {
 | |
| @@ -1090,6 +1098,7 @@ void ChromeMainDelegate::PreSandboxStartup() {
 | |
|    // After all the platform Breakpads have been initialized, store the command
 | |
|    // line for crash reporting.
 | |
|    crash_keys::SetCrashKeysFromCommandLine(command_line);
 | |
| +  }  // !cef::IsChromeRuntimeEnabled()
 | |
|  
 | |
|  #if BUILDFLAG(ENABLE_PDF)
 | |
|    MaybeInitializeGDI();
 | |
| @@ -1188,6 +1197,7 @@ void ChromeMainDelegate::ZygoteForked() {
 | |
|      SetUpProfilingShutdownHandler();
 | |
|    }
 | |
|  
 | |
| +  if (!cef::IsChromeRuntimeEnabled()) {
 | |
|    // Needs to be called after we have chrome::DIR_USER_DATA.  BrowserMain sets
 | |
|    // this up for the browser process in a different manner.
 | |
|    const base::CommandLine* command_line =
 | |
| @@ -1204,6 +1214,7 @@ void ChromeMainDelegate::ZygoteForked() {
 | |
|  
 | |
|    // Reset the command line for the newly spawned process.
 | |
|    crash_keys::SetCrashKeysFromCommandLine(*command_line);
 | |
| +  }  // !cef::IsChromeRuntimeEnabled()
 | |
|  }
 | |
|  
 | |
|  #endif  // defined(OS_LINUX) || defined(OS_CHROMEOS)
 | |
| diff --git chrome/browser/chrome_browser_main.cc chrome/browser/chrome_browser_main.cc
 | |
| index 64da51339475..6edca9991546 100644
 | |
| --- chrome/browser/chrome_browser_main.cc
 | |
| +++ chrome/browser/chrome_browser_main.cc
 | |
| @@ -49,6 +49,7 @@
 | |
|  #include "build/build_config.h"
 | |
|  #include "build/chromeos_buildflags.h"
 | |
|  #include "cc/base/switches.h"
 | |
| +#include "cef/libcef/features/runtime.h"
 | |
|  #include "chrome/browser/about_flags.h"
 | |
|  #include "chrome/browser/active_use_util.h"
 | |
|  #include "chrome/browser/after_startup_task_utils.h"
 | |
| @@ -894,8 +895,10 @@ int ChromeBrowserMainParts::PreCreateThreadsImpl() {
 | |
|  #if !defined(OS_ANDROID)
 | |
|    // Create the RunLoop for MainMessageLoopRun() to use, and pass a copy of
 | |
|    // its QuitClosure to the BrowserProcessImpl to call when it is time to exit.
 | |
| +  // CEF with the Chrome runtime will create and manage its own RunLoop.
 | |
|    DCHECK(!g_run_loop);
 | |
| -  g_run_loop = new base::RunLoop;
 | |
| +  if (!cef::IsChromeRuntimeEnabled())
 | |
| +    g_run_loop = new base::RunLoop;
 | |
|  
 | |
|    // These members must be initialized before returning from this function.
 | |
|    // Android doesn't use StartupBrowserCreator.
 | |
| @@ -1621,11 +1624,13 @@ int ChromeBrowserMainParts::PreMainMessageLoopRunImpl() {
 | |
|    // This step is costly and is already measured in
 | |
|    // Startup.StartupBrowserCreator_Start.
 | |
|    // See the comment above for an explanation of |process_command_line|.
 | |
| +  // Bypass StartupBrowserCreator with CEF where |g_run_loop| is nullptr.
 | |
|    const bool started =
 | |
| +      !g_run_loop ||
 | |
|        !process_command_line ||
 | |
|        browser_creator_->Start(parsed_command_line(), base::FilePath(), profile_,
 | |
|                                last_opened_profiles);
 | |
| -  if (started) {
 | |
| +  if (started && g_run_loop) {
 | |
|  #if defined(OS_WIN) || (defined(OS_LINUX) && !defined(OS_CHROMEOS))
 | |
|      // Initialize autoupdate timer. Timer callback costs basically nothing
 | |
|      // when browser is not in persistent mode, so it's OK to let it ride on
 | |
| diff --git chrome/browser/notifications/notification_platform_bridge_mac.mm chrome/browser/notifications/notification_platform_bridge_mac.mm
 | |
| index 9e8fcb9f9f91..2a9eaca0fb0d 100644
 | |
| --- chrome/browser/notifications/notification_platform_bridge_mac.mm
 | |
| +++ chrome/browser/notifications/notification_platform_bridge_mac.mm
 | |
| @@ -24,6 +24,7 @@
 | |
|  #include "base/strings/sys_string_conversions.h"
 | |
|  #include "base/strings/utf_string_conversions.h"
 | |
|  #include "base/system/sys_info.h"
 | |
| +#include "cef/libcef/features/runtime.h"
 | |
|  #include "chrome/browser/browser_features.h"
 | |
|  #include "chrome/browser/notifications/notification_common.h"
 | |
|  #include "chrome/browser/notifications/notification_display_service_impl.h"
 | |
| @@ -451,6 +452,12 @@ getDisplayedAlertsForProfileId:(NSString*)profileId
 | |
|  - (id<NotificationDelivery>)serviceProxy {
 | |
|    id<NotificationDelivery> proxy = [_xpcConnection remoteObjectProxy];
 | |
|  
 | |
| +  // Skip exception port configuration when running CEF with crash reporting disabled.
 | |
| +  if (!_setExceptionPort && cef::IsChromeRuntimeEnabled() &&
 | |
| +      !cef::IsCrashReportingEnabled()) {
 | |
| +    _setExceptionPort = YES;
 | |
| +  }
 | |
| +
 | |
|    if (!_setExceptionPort) {
 | |
|      base::mac::ScopedMachSendRight exceptionPort(
 | |
|          crash_reporter::GetCrashpadClient().GetHandlerMachPort());
 |