mirror of
				https://bitbucket.org/chromiumembedded/cef
				synced 2025-06-05 21:39:12 +02:00 
			
		
		
		
	Windows: Build cef_sandbox.lib with different GN args for official binary distributions (issue #2220)
This commit is contained in:
		| @@ -329,22 +329,13 @@ if(OS_WINDOWS) | |||||||
|  |  | ||||||
|   # Configure use of the sandbox. |   # Configure use of the sandbox. | ||||||
|   option(USE_SANDBOX "Enable or disable use of the sandbox." ON) |   option(USE_SANDBOX "Enable or disable use of the sandbox." ON) | ||||||
|   if(USE_SANDBOX AND NOT MSVC_VERSION EQUAL 1900) |   if(USE_SANDBOX AND NOT MSVC_VERSION EQUAL 1900 AND NOT MSVC_VERSION EQUAL 1910) | ||||||
|     # The cef_sandbox.lib static library is currently built with VS2015. It will |     # The cef_sandbox.lib static library is currently built with VS2015, which | ||||||
|     # not link successfully with other VS versions. |     # is compatible with VS2015 and VS2017. It will not link successfully with | ||||||
|  |     # other VS versions. | ||||||
|     set(USE_SANDBOX OFF) |     set(USE_SANDBOX OFF) | ||||||
|   endif() |   endif() | ||||||
|  |  | ||||||
|   # Configure use of official build compiler settings. |  | ||||||
|   # When using an official build the "Debug" build is actually a Release build |  | ||||||
|   # with DCHECKs enabled. In order to link the sandbox the Debug build must |  | ||||||
|   # be configured with some Release-related compiler settings. |  | ||||||
|   option(USE_OFFICIAL_BUILD_SANDBOX "Enable or disable use of an official build sandbox." ON) |  | ||||||
|   if(NOT USE_SANDBOX) |  | ||||||
|     # Don't need official build settings when the sandbox is off. |  | ||||||
|     set(USE_OFFICIAL_BUILD_SANDBOX OFF) |  | ||||||
|   endif() |  | ||||||
|  |  | ||||||
|   # Consumers who run into LNK4099 warnings can pass /Z7 instead (see issue #385). |   # Consumers who run into LNK4099 warnings can pass /Z7 instead (see issue #385). | ||||||
|   set(CEF_DEBUG_INFO_FLAG "/Zi" CACHE STRING "Optional flag specifying specific /Z flag to use") |   set(CEF_DEBUG_INFO_FLAG "/Zi" CACHE STRING "Optional flag specifying specific /Z flag to use") | ||||||
|  |  | ||||||
| @@ -366,27 +357,11 @@ if(OS_WINDOWS) | |||||||
|     /wd4996       # Ignore "function or variable may be unsafe" warning |     /wd4996       # Ignore "function or variable may be unsafe" warning | ||||||
|     ${CEF_DEBUG_INFO_FLAG} |     ${CEF_DEBUG_INFO_FLAG} | ||||||
|     ) |     ) | ||||||
|   if(USE_OFFICIAL_BUILD_SANDBOX) |   list(APPEND CEF_COMPILER_FLAGS_DEBUG | ||||||
|     # CMake adds /RTC1, /D"_DEBUG" and a few other values by default for Debug |     /MTd          # Multithreaded debug runtime | ||||||
|     # builds. We can't link the sandbox with those values so clear the CMake |     /RTC1         # Disable optimizations | ||||||
|     # defaults here. |     /Od           # Enable basic run-time checks | ||||||
|     set(CMAKE_CXX_FLAGS_DEBUG "") |     ) | ||||||
|  |  | ||||||
|     # These flags are required to successfully link and run applications using |  | ||||||
|     # the sandbox library. |  | ||||||
|     list(APPEND CEF_COMPILER_FLAGS_DEBUG |  | ||||||
|       /MT           # Multithreaded release runtime |  | ||||||
|       /O2           # Maximize speed optimization |  | ||||||
|       /Zc:inline    # Remove unreferenced functions or data |  | ||||||
|       /Oy-          # Disable frame-pointer omission |  | ||||||
|       ) |  | ||||||
|   else() |  | ||||||
|     list(APPEND CEF_COMPILER_FLAGS_DEBUG |  | ||||||
|       /MTd          # Multithreaded debug runtime |  | ||||||
|       /RTC1         # Disable optimizations |  | ||||||
|       /Od           # Enable basic run-time checks |  | ||||||
|       ) |  | ||||||
|   endif() |  | ||||||
|   list(APPEND CEF_COMPILER_FLAGS_RELEASE |   list(APPEND CEF_COMPILER_FLAGS_RELEASE | ||||||
|     /MT           # Multithreaded release runtime |     /MT           # Multithreaded release runtime | ||||||
|     /O2           # Optimize for maximum speed |     /O2           # Optimize for maximum speed | ||||||
| @@ -408,12 +383,6 @@ if(OS_WINDOWS) | |||||||
|     WIN32_LEAN_AND_MEAN               # Exclude less common API declarations |     WIN32_LEAN_AND_MEAN               # Exclude less common API declarations | ||||||
|     _HAS_EXCEPTIONS=0                 # Disable exceptions |     _HAS_EXCEPTIONS=0                 # Disable exceptions | ||||||
|     ) |     ) | ||||||
|   if(USE_OFFICIAL_BUILD_SANDBOX) |  | ||||||
|     list(APPEND CEF_COMPILER_DEFINES_DEBUG |  | ||||||
|       NDEBUG _NDEBUG                    # Not a debug build |  | ||||||
|       DCHECK_ALWAYS_ON=1                # DCHECKs are enabled |  | ||||||
|       ) |  | ||||||
|   endif() |  | ||||||
|   list(APPEND CEF_COMPILER_DEFINES_RELEASE |   list(APPEND CEF_COMPILER_DEFINES_RELEASE | ||||||
|     NDEBUG _NDEBUG                    # Not a debug build |     NDEBUG _NDEBUG                    # Not a debug build | ||||||
|     ) |     ) | ||||||
| @@ -481,18 +450,25 @@ if(OS_WINDOWS) | |||||||
|   # Configure use of ATL. |   # Configure use of ATL. | ||||||
|   option(USE_ATL "Enable or disable use of ATL." ON) |   option(USE_ATL "Enable or disable use of ATL." ON) | ||||||
|   if(USE_ATL) |   if(USE_ATL) | ||||||
|     # Locate the VC directory. The cl.exe path returned by CMAKE_CXX_COMPILER |     # Locate the atlmfc directory if it exists. It may be at any depth inside | ||||||
|     # may be at different directory depths depending on the toolchain version |     # the VC directory. The cl.exe path returned by CMAKE_CXX_COMPILER may also | ||||||
|     # (e.g. "VC/bin/cl.exe", "VC/bin/amd64_x86/cl.exe", etc). |     # be at different depths depending on the toolchain version | ||||||
|  |     # (e.g. "VC/bin/cl.exe", "VC/bin/amd64_x86/cl.exe", | ||||||
|  |     # "VC/Tools/MSVC/14.10.25017/bin/HostX86/x86/cl.exe", etc). | ||||||
|  |     set(HAS_ATLMFC 0) | ||||||
|     get_filename_component(VC_DIR ${CMAKE_CXX_COMPILER} DIRECTORY) |     get_filename_component(VC_DIR ${CMAKE_CXX_COMPILER} DIRECTORY) | ||||||
|     get_filename_component(VC_DIR_NAME ${VC_DIR} NAME) |     get_filename_component(VC_DIR_NAME ${VC_DIR} NAME) | ||||||
|     while(NOT ${VC_DIR_NAME} STREQUAL "VC") |     while(NOT ${VC_DIR_NAME} STREQUAL "VC") | ||||||
|       get_filename_component(VC_DIR ${VC_DIR} DIRECTORY) |       get_filename_component(VC_DIR ${VC_DIR} DIRECTORY) | ||||||
|  |       if(IS_DIRECTORY "${VC_DIR}/atlmfc") | ||||||
|  |         set(HAS_ATLMFC 1) | ||||||
|  |         break() | ||||||
|  |       endif() | ||||||
|       get_filename_component(VC_DIR_NAME ${VC_DIR} NAME) |       get_filename_component(VC_DIR_NAME ${VC_DIR} NAME) | ||||||
|     endwhile() |     endwhile() | ||||||
|  |  | ||||||
|     # Determine if the Visual Studio install supports ATL. |     # Determine if the Visual Studio install supports ATL. | ||||||
|     if(NOT IS_DIRECTORY "${VC_DIR}/atlmfc") |     if(NOT HAS_ATLMFC) | ||||||
|       message(WARNING "ATL is not supported by your VC installation.") |       message(WARNING "ATL is not supported by your VC installation.") | ||||||
|       set(USE_ATL OFF) |       set(USE_ATL OFF) | ||||||
|     endif() |     endif() | ||||||
|   | |||||||
| @@ -312,4 +312,9 @@ patches = [ | |||||||
|     'name': 'libangle_735986', |     'name': 'libangle_735986', | ||||||
|     'path': 'third_party/angle/', |     'path': 'third_party/angle/', | ||||||
|   }, |   }, | ||||||
|  |   { | ||||||
|  |     # Windows: Disable allocator for cef_sandbox builds. | ||||||
|  |     # https://bitbucket.org/chromiumembedded/cef/issues/2220 | ||||||
|  |     'name': 'sandbox_2220', | ||||||
|  |   }, | ||||||
| ] | ] | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								patch/patches/sandbox_2220.patch
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								patch/patches/sandbox_2220.patch
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | diff --git base/allocator/BUILD.gn base/allocator/BUILD.gn | ||||||
|  | index 6ebbc11..b667064 100644 | ||||||
|  | --- base/allocator/BUILD.gn | ||||||
|  | +++ base/allocator/BUILD.gn | ||||||
|  | @@ -15,8 +15,7 @@ declare_args() { | ||||||
|  |   | ||||||
|  |  # The Windows-only allocator shim is only enabled for Release static builds, and | ||||||
|  |  # is mutually exclusive with the generalized shim. | ||||||
|  | -win_use_allocator_shim = is_win && !is_component_build && !is_debug && | ||||||
|  | -                         !use_allocator_shim && !is_asan | ||||||
|  | +win_use_allocator_shim = false | ||||||
|  |   | ||||||
|  |  # This "allocator" meta-target will forward to the default allocator according | ||||||
|  |  # to the build settings. | ||||||
| @@ -510,6 +510,18 @@ parser.add_option( | |||||||
|     dest='clientdistribonly', |     dest='clientdistribonly', | ||||||
|     default=False, |     default=False, | ||||||
|     help='Create a client CEF binary distribution only.') |     help='Create a client CEF binary distribution only.') | ||||||
|  | parser.add_option( | ||||||
|  |     '--sandbox-distrib', | ||||||
|  |     action='store_true', | ||||||
|  |     dest='sandboxdistrib', | ||||||
|  |     default=False, | ||||||
|  |     help='Create a cef_sandbox static library distribution.') | ||||||
|  | parser.add_option( | ||||||
|  |     '--sandbox-distrib-only', | ||||||
|  |     action='store_true', | ||||||
|  |     dest='sandboxdistribonly', | ||||||
|  |     default=False, | ||||||
|  |     help='Create a cef_sandbox static library distribution only.') | ||||||
| parser.add_option( | parser.add_option( | ||||||
|     '--no-distrib-docs', |     '--no-distrib-docs', | ||||||
|     action='store_true', |     action='store_true', | ||||||
| @@ -557,7 +569,7 @@ if (options.nochromiumupdate and options.forceupdate) or \ | |||||||
| if (options.noreleasebuild and \ | if (options.noreleasebuild and \ | ||||||
|      (options.minimaldistrib or options.minimaldistribonly or \ |      (options.minimaldistrib or options.minimaldistribonly or \ | ||||||
|       options.clientdistrib or options.clientdistribonly)) or \ |       options.clientdistrib or options.clientdistribonly)) or \ | ||||||
|    (options.minimaldistribonly and options.clientdistribonly): |    (options.minimaldistribonly + options.clientdistribonly + options.sandboxdistribonly > 1): | ||||||
|   print 'Invalid combination of options.' |   print 'Invalid combination of options.' | ||||||
|   parser.print_help(sys.stderr) |   parser.print_help(sys.stderr) | ||||||
|   sys.exit() |   sys.exit() | ||||||
| @@ -600,13 +612,20 @@ if options.clientdistrib or options.clientdistribonly: | |||||||
|     parser.print_help(sys.stderr) |     parser.print_help(sys.stderr) | ||||||
|     sys.exit() |     sys.exit() | ||||||
|  |  | ||||||
|  | if platform != 'windows' and (options.sandboxdistrib or | ||||||
|  |                               options.sandboxdistribonly): | ||||||
|  |   print 'The sandbox distribution is only supported on Windows.' | ||||||
|  |   sys.exit() | ||||||
|  |  | ||||||
| # CEF branch. | # CEF branch. | ||||||
| if options.branch != 'trunk' and not options.branch.isdigit(): | if options.branch != 'trunk' and not options.branch.isdigit(): | ||||||
|   print 'Invalid branch value: %s' % (options.branch) |   print 'Invalid branch value: %s' % (options.branch) | ||||||
|  |   sys.exit() | ||||||
|  |  | ||||||
| cef_branch = options.branch | cef_branch = options.branch | ||||||
|  |  | ||||||
| if cef_branch != 'trunk' and int(cef_branch) <= 1453: | if cef_branch != 'trunk' and int(cef_branch) <= 1453: | ||||||
|   print 'The requested branch is too old to build using this tool' |   print 'The requested branch is too old to build using this tool.' | ||||||
|   sys.exit() |   sys.exit() | ||||||
|  |  | ||||||
| # True if the requested branch is 2272 or newer. | # True if the requested branch is 2272 or newer. | ||||||
| @@ -1054,30 +1073,51 @@ if not options.nobuild and (chromium_checkout_changed or \ | |||||||
|     if platform == 'windows' and options.x64build: |     if platform == 'windows' and options.x64build: | ||||||
|       build_dir_suffix = '_x64' |       build_dir_suffix = '_x64' | ||||||
|  |  | ||||||
|  |   # Make a CEF Debug build. | ||||||
|   if not options.nodebugbuild: |   if not options.nodebugbuild: | ||||||
|     build_path = os.path.join('out', 'Debug' + build_dir_suffix) |     build_path = os.path.join('out', 'Debug' + build_dir_suffix) | ||||||
|     if use_gn: |     if use_gn: | ||||||
|       args_path = os.path.join(chromium_src_dir, build_path, 'args.gn') |       args_path = os.path.join(chromium_src_dir, build_path, 'args.gn') | ||||||
|       if os.path.exists(args_path): |       msg(args_path + ' contents:\n' + read_file(args_path)) | ||||||
|         msg(args_path + ' contents:\n' + read_file(args_path)) |  | ||||||
|  |  | ||||||
|     # Make a CEF Debug build. |  | ||||||
|     run(command + build_path + target, chromium_src_dir, depot_tools_dir, |     run(command + build_path + target, chromium_src_dir, depot_tools_dir, | ||||||
|         os.path.join(download_dir, 'build-%s-debug.log' % (cef_branch)) \ |         os.path.join(download_dir, 'build-%s-debug.log' % (cef_branch)) \ | ||||||
|           if options.buildlogfile else None) |           if options.buildlogfile else None) | ||||||
|  |  | ||||||
|  |     if use_gn and platform == 'windows': | ||||||
|  |       # Make the separate cef_sandbox.lib build when GN is_official_build=true. | ||||||
|  |       build_path = os.path.join('out', 'Debug' + build_dir_suffix + '_sandbox') | ||||||
|  |       if os.path.exists(os.path.join(chromium_src_dir, build_path)): | ||||||
|  |         args_path = os.path.join(chromium_src_dir, build_path, 'args.gn') | ||||||
|  |         msg(args_path + ' contents:\n' + read_file(args_path)) | ||||||
|  |  | ||||||
|  |         run(command + build_path + ' cef_sandbox', chromium_src_dir, depot_tools_dir, | ||||||
|  |             os.path.join(download_dir, 'build-%s-debug-sandbox.log' % (cef_branch)) \ | ||||||
|  |               if options.buildlogfile else None) | ||||||
|  |  | ||||||
|  |   # Make a CEF Release build. | ||||||
|   if not options.noreleasebuild: |   if not options.noreleasebuild: | ||||||
|     build_path = os.path.join('out', 'Release' + build_dir_suffix) |     build_path = os.path.join('out', 'Release' + build_dir_suffix) | ||||||
|     if use_gn: |     if use_gn: | ||||||
|       args_path = os.path.join(chromium_src_dir, build_path, 'args.gn') |       args_path = os.path.join(chromium_src_dir, build_path, 'args.gn') | ||||||
|       if os.path.exists(args_path): |       msg(args_path + ' contents:\n' + read_file(args_path)) | ||||||
|         msg(args_path + ' contents:\n' + read_file(args_path)) |  | ||||||
|  |  | ||||||
|     # Make a CEF Release build. |  | ||||||
|     run(command + build_path + target, chromium_src_dir, depot_tools_dir, |     run(command + build_path + target, chromium_src_dir, depot_tools_dir, | ||||||
|         os.path.join(download_dir, 'build-%s-release.log' % (cef_branch)) \ |         os.path.join(download_dir, 'build-%s-release.log' % (cef_branch)) \ | ||||||
|           if options.buildlogfile else None) |           if options.buildlogfile else None) | ||||||
|  |  | ||||||
|  |     if use_gn and platform == 'windows': | ||||||
|  |       # Make the separate cef_sandbox.lib build when GN is_official_build=true. | ||||||
|  |       build_path = os.path.join('out', | ||||||
|  |                                 'Release' + build_dir_suffix + '_sandbox') | ||||||
|  |       if os.path.exists(os.path.join(chromium_src_dir, build_path)): | ||||||
|  |         args_path = os.path.join(chromium_src_dir, build_path, 'args.gn') | ||||||
|  |         msg(args_path + ' contents:\n' + read_file(args_path)) | ||||||
|  |  | ||||||
|  |         run(command + build_path + ' cef_sandbox', chromium_src_dir, depot_tools_dir, | ||||||
|  |             os.path.join(download_dir, 'build-%s-release-sandbox.log' % (cef_branch)) \ | ||||||
|  |               if options.buildlogfile else None) | ||||||
|  |  | ||||||
| elif not options.nobuild: | elif not options.nobuild: | ||||||
|   msg('Not building. The source hashes have not changed and ' + |   msg('Not building. The source hashes have not changed and ' + | ||||||
|       'the output folder "%s" already exists' % (out_src_dir)) |       'the output folder "%s" already exists' % (out_src_dir)) | ||||||
| @@ -1099,12 +1139,16 @@ if not options.nodistrib and (chromium_checkout_changed or \ | |||||||
|     distrib_types.append('minimal') |     distrib_types.append('minimal') | ||||||
|   elif options.clientdistribonly: |   elif options.clientdistribonly: | ||||||
|     distrib_types.append('client') |     distrib_types.append('client') | ||||||
|  |   elif options.sandboxdistribonly: | ||||||
|  |     distrib_types.append('sandbox') | ||||||
|   else: |   else: | ||||||
|     distrib_types.append('standard') |     distrib_types.append('standard') | ||||||
|     if options.minimaldistrib: |     if options.minimaldistrib: | ||||||
|       distrib_types.append('minimal') |       distrib_types.append('minimal') | ||||||
|     if options.clientdistrib: |     if options.clientdistrib: | ||||||
|       distrib_types.append('client') |       distrib_types.append('client') | ||||||
|  |     if options.sandboxdistrib: | ||||||
|  |       distrib_types.append('sandbox') | ||||||
|  |  | ||||||
|   cef_tools_dir = os.path.join(cef_src_dir, 'tools') |   cef_tools_dir = os.path.join(cef_src_dir, 'tools') | ||||||
|  |  | ||||||
| @@ -1124,6 +1168,8 @@ if not options.nodistrib and (chromium_checkout_changed or \ | |||||||
|       path = path + ' --minimal' |       path = path + ' --minimal' | ||||||
|     elif type == 'client': |     elif type == 'client': | ||||||
|       path = path + ' --client' |       path = path + ' --client' | ||||||
|  |     elif type == 'sandbox': | ||||||
|  |       path = path + ' --sandbox' | ||||||
|  |  | ||||||
|     if first_type: |     if first_type: | ||||||
|       if options.nodistribdocs: |       if options.nodistribdocs: | ||||||
|   | |||||||
							
								
								
									
										14
									
								
								tools/distrib/win/README.sandbox.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										14
									
								
								tools/distrib/win/README.sandbox.txt
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,14 @@ | |||||||
|  | CONTENTS | ||||||
|  | -------- | ||||||
|  |  | ||||||
|  | Debug       Contains the Debug build of cef_sandbox.lib. | ||||||
|  |  | ||||||
|  | Release     Contains the Release build of cef_sandbox.lib. | ||||||
|  |  | ||||||
|  |  | ||||||
|  | USAGE | ||||||
|  | ----- | ||||||
|  |  | ||||||
|  | Please visit the CEF Website for usage information. | ||||||
|  |  | ||||||
|  | https://bitbucket.org/chromiumembedded/cef/ | ||||||
| @@ -419,6 +419,28 @@ def GetConfigArgs(args, is_debug, cpu): | |||||||
|   return result |   return result | ||||||
|  |  | ||||||
|  |  | ||||||
|  | def WinGetConfigArgsSandbox(args, is_debug, cpu): | ||||||
|  |   """ | ||||||
|  |   Return merged GN args for the Windows cef_sandbox.lib configuration and | ||||||
|  |   validate. | ||||||
|  |   """ | ||||||
|  |   add_args = { | ||||||
|  |       # Avoid libucrt.lib linker errors. | ||||||
|  |       'use_allocator_shim': False, | ||||||
|  |  | ||||||
|  |       # Avoid /LTCG linker warnings and generate smaller lib files. | ||||||
|  |       'is_official_build': False | ||||||
|  |   } | ||||||
|  |  | ||||||
|  |   result = MergeDicts(args, add_args, { | ||||||
|  |       'is_debug': is_debug, | ||||||
|  |       'target_cpu': cpu, | ||||||
|  |   }) | ||||||
|  |  | ||||||
|  |   ValidateArgs(result) | ||||||
|  |   return result | ||||||
|  |  | ||||||
|  |  | ||||||
| def LinuxSysrootExists(cpu): | def LinuxSysrootExists(cpu): | ||||||
|   """ |   """ | ||||||
|   Returns true if the sysroot for the specified |cpu| architecture exists. |   Returns true if the sysroot for the specified |cpu| architecture exists. | ||||||
| @@ -481,6 +503,14 @@ def GetAllPlatformConfigs(build_args): | |||||||
|       result['Debug_GN_' + cpu] = GetConfigArgs(args, True, cpu) |       result['Debug_GN_' + cpu] = GetConfigArgs(args, True, cpu) | ||||||
|     result['Release_GN_' + cpu] = GetConfigArgs(args, False, cpu) |     result['Release_GN_' + cpu] = GetConfigArgs(args, False, cpu) | ||||||
|  |  | ||||||
|  |     if platform == 'windows' and GetArgValue(args, 'is_official_build'): | ||||||
|  |       # Build cef_sandbox.lib with a different configuration. | ||||||
|  |       if create_debug: | ||||||
|  |         result['Debug_GN_' + cpu + '_sandbox'] = WinGetConfigArgsSandbox( | ||||||
|  |             args, True, cpu) | ||||||
|  |       result['Release_GN_' + cpu + '_sandbox'] = WinGetConfigArgsSandbox( | ||||||
|  |           args, False, cpu) | ||||||
|  |  | ||||||
|   return result |   return result | ||||||
|  |  | ||||||
|  |  | ||||||
|   | |||||||
| @@ -112,7 +112,10 @@ def create_readme(): | |||||||
|   footer_data = get_readme_component('footer') |   footer_data = get_readme_component('footer') | ||||||
|  |  | ||||||
|   # format the file |   # format the file | ||||||
|   data = header_data + '\n\n' + mode_data + '\n\n' + redistrib_data + '\n\n' + footer_data |   data = header_data + '\n\n' + mode_data | ||||||
|  |   if mode != 'sandbox': | ||||||
|  |     data += '\n\n' + redistrib_data | ||||||
|  |   data += '\n\n' + footer_data | ||||||
|   data = data.replace('$CEF_URL$', cef_url) |   data = data.replace('$CEF_URL$', cef_url) | ||||||
|   data = data.replace('$CEF_REV$', cef_rev) |   data = data.replace('$CEF_REV$', cef_rev) | ||||||
|   data = data.replace('$CEF_VER$', cef_ver) |   data = data.replace('$CEF_VER$', cef_ver) | ||||||
| @@ -149,6 +152,10 @@ def create_readme(): | |||||||
|     distrib_desc = 'This distribution contains a release build of the ' + client_app + ' sample application\n' \ |     distrib_desc = 'This distribution contains a release build of the ' + client_app + ' sample application\n' \ | ||||||
|                    'for the ' + platform_str + ' platform. Please see the LICENSING section of this document for\n' \ |                    'for the ' + platform_str + ' platform. Please see the LICENSING section of this document for\n' \ | ||||||
|                    'licensing terms and conditions.' |                    'licensing terms and conditions.' | ||||||
|  |   elif mode == 'sandbox': | ||||||
|  |     distrib_type = 'Sandbox' | ||||||
|  |     distrib_desc = 'This distribution contains only the cef_sandbox static library. Please see\n' \ | ||||||
|  |                    'the LICENSING section of this document for licensing terms and conditions.' | ||||||
|  |  | ||||||
|   data = data.replace('$DISTRIB_TYPE$', distrib_type) |   data = data.replace('$DISTRIB_TYPE$', distrib_type) | ||||||
|   data = data.replace('$DISTRIB_DESC$', distrib_desc) |   data = data.replace('$DISTRIB_DESC$', distrib_desc) | ||||||
| @@ -343,7 +350,7 @@ parser.add_option( | |||||||
|     action='store_true', |     action='store_true', | ||||||
|     dest='armbuild', |     dest='armbuild', | ||||||
|     default=False, |     default=False, | ||||||
|     help='create an ARM binary distribution') |     help='create an ARM binary distribution (Linux only)') | ||||||
| parser.add_option( | parser.add_option( | ||||||
|     '--minimal', |     '--minimal', | ||||||
|     action='store_true', |     action='store_true', | ||||||
| @@ -356,6 +363,12 @@ parser.add_option( | |||||||
|     dest='client', |     dest='client', | ||||||
|     default=False, |     default=False, | ||||||
|     help='include only the sample application') |     help='include only the sample application') | ||||||
|  | parser.add_option( | ||||||
|  |     '--sandbox', | ||||||
|  |     action='store_true', | ||||||
|  |     dest='sandbox', | ||||||
|  |     default=False, | ||||||
|  |     help='include only the cef_sandbox static library (Windows only)') | ||||||
| parser.add_option( | parser.add_option( | ||||||
|     '-q', |     '-q', | ||||||
|     '--quiet', |     '--quiet', | ||||||
| @@ -393,6 +406,10 @@ if options.armbuild and platform != 'linux': | |||||||
|   print '--arm-build is only supported on Linux.' |   print '--arm-build is only supported on Linux.' | ||||||
|   sys.exit() |   sys.exit() | ||||||
|  |  | ||||||
|  | if options.sandbox and platform != 'windows': | ||||||
|  |   print '--sandbox is only supported on Windows.' | ||||||
|  |   sys.exit() | ||||||
|  |  | ||||||
| if not options.ninjabuild: | if not options.ninjabuild: | ||||||
|   print 'Ninja build is required on all platforms' |   print 'Ninja build is required on all platforms' | ||||||
|   sys.exit() |   sys.exit() | ||||||
| @@ -456,6 +473,9 @@ if options.minimal: | |||||||
| elif options.client: | elif options.client: | ||||||
|   mode = 'client' |   mode = 'client' | ||||||
|   output_dir_name = output_dir_name + '_client' |   output_dir_name = output_dir_name + '_client' | ||||||
|  | elif options.sandbox: | ||||||
|  |   mode = 'sandbox' | ||||||
|  |   output_dir_name = output_dir_name + '_sandbox' | ||||||
| else: | else: | ||||||
|   mode = 'standard' |   mode = 'standard' | ||||||
|  |  | ||||||
| @@ -645,15 +665,31 @@ if platform == 'windows': | |||||||
|   ] |   ] | ||||||
|  |  | ||||||
|   libcef_dll_file = 'libcef.dll.lib' |   libcef_dll_file = 'libcef.dll.lib' | ||||||
|  |   cef_sandbox_lib = 'obj\\cef\\cef_sandbox.lib' | ||||||
|   sandbox_libs = [ |   sandbox_libs = [ | ||||||
|       'obj\\base\\allocator\\unified_allocator_shim\\*.obj', |  | ||||||
|       'obj\\base\\base.lib', |       'obj\\base\\base.lib', | ||||||
|       'obj\\base\\base_static.lib', |       'obj\\base\\base_static.lib', | ||||||
|       'obj\\base\\third_party\\dynamic_annotations\\dynamic_annotations.lib', |       'obj\\base\\third_party\\dynamic_annotations\\dynamic_annotations.lib', | ||||||
|       'obj\\cef\\cef_sandbox.lib', |       cef_sandbox_lib, | ||||||
|       'obj\\sandbox\\win\\sandbox.lib', |       'obj\\sandbox\\win\\sandbox.lib', | ||||||
|   ] |   ] | ||||||
|  |  | ||||||
|  |   # Generate the cef_sandbox.lib merged library. A separate *_sandbox build | ||||||
|  |   # should exist when GN is_official_build=true. | ||||||
|  |   if mode in ('standard', 'minimal', 'sandbox'): | ||||||
|  |     dirs = { | ||||||
|  |         'Debug': (build_dir_debug + '_sandbox', build_dir_debug), | ||||||
|  |         'Release': (build_dir_release + '_sandbox', build_dir_release) | ||||||
|  |     } | ||||||
|  |     for dir_name in dirs.keys(): | ||||||
|  |       for src_dir in dirs[dir_name]: | ||||||
|  |         if path_exists(os.path.join(src_dir, cef_sandbox_lib)): | ||||||
|  |           dst_dir = os.path.join(output_dir, dir_name) | ||||||
|  |           make_dir(dst_dir, options.quiet) | ||||||
|  |           combine_libs(src_dir, sandbox_libs, | ||||||
|  |                        os.path.join(dst_dir, 'cef_sandbox.lib')) | ||||||
|  |           break | ||||||
|  |  | ||||||
|   valid_build_dir = None |   valid_build_dir = None | ||||||
|  |  | ||||||
|   if mode == 'standard': |   if mode == 'standard': | ||||||
| @@ -672,8 +708,6 @@ if platform == 'windows': | |||||||
|             os.path.join(dst_dir, os.path.basename(binary)), options.quiet) |             os.path.join(dst_dir, os.path.basename(binary)), options.quiet) | ||||||
|       copy_file(os.path.join(build_dir, libcef_dll_file), os.path.join(dst_dir, 'libcef.lib'), \ |       copy_file(os.path.join(build_dir, libcef_dll_file), os.path.join(dst_dir, 'libcef.lib'), \ | ||||||
|                 options.quiet) |                 options.quiet) | ||||||
|       combine_libs(build_dir, sandbox_libs, |  | ||||||
|                    os.path.join(dst_dir, 'cef_sandbox.lib')) |  | ||||||
|  |  | ||||||
|       if not options.nosymbols: |       if not options.nosymbols: | ||||||
|         # create the symbol output directory |         # create the symbol output directory | ||||||
| @@ -686,39 +720,38 @@ if platform == 'windows': | |||||||
|     else: |     else: | ||||||
|       sys.stderr.write("No Debug build files.\n") |       sys.stderr.write("No Debug build files.\n") | ||||||
|  |  | ||||||
|   # transfer Release files |   if mode != 'sandbox': | ||||||
|   build_dir = build_dir_release |     # transfer Release files | ||||||
|   if not options.allowpartial or path_exists( |     build_dir = build_dir_release | ||||||
|       os.path.join(build_dir, 'libcef.dll')): |     if not options.allowpartial or path_exists( | ||||||
|     valid_build_dir = build_dir |         os.path.join(build_dir, 'libcef.dll')): | ||||||
|     dst_dir = os.path.join(output_dir, 'Release') |       valid_build_dir = build_dir | ||||||
|     make_dir(dst_dir, options.quiet) |       dst_dir = os.path.join(output_dir, 'Release') | ||||||
|     copy_files( |       make_dir(dst_dir, options.quiet) | ||||||
|         os.path.join(script_dir, 'distrib/win/*.dll'), dst_dir, options.quiet) |       copy_files( | ||||||
|     for binary in binaries: |           os.path.join(script_dir, 'distrib/win/*.dll'), dst_dir, options.quiet) | ||||||
|       copy_file( |       for binary in binaries: | ||||||
|           os.path.join(build_dir, binary), |         copy_file( | ||||||
|           os.path.join(dst_dir, os.path.basename(binary)), options.quiet) |             os.path.join(build_dir, binary), | ||||||
|  |             os.path.join(dst_dir, os.path.basename(binary)), options.quiet) | ||||||
|  |  | ||||||
|     if mode != 'client': |       if mode != 'client': | ||||||
|       copy_file(os.path.join(build_dir, libcef_dll_file), os.path.join(dst_dir, 'libcef.lib'), \ |         copy_file(os.path.join(build_dir, libcef_dll_file), os.path.join(dst_dir, 'libcef.lib'), \ | ||||||
|           options.quiet) |             options.quiet) | ||||||
|       combine_libs(build_dir, sandbox_libs, |       else: | ||||||
|                    os.path.join(dst_dir, 'cef_sandbox.lib')) |         copy_file( | ||||||
|  |             os.path.join(build_dir, 'cefclient.exe'), dst_dir, options.quiet) | ||||||
|  |  | ||||||
|  |       if not options.nosymbols: | ||||||
|  |         # create the symbol output directory | ||||||
|  |         symbol_output_dir = create_output_dir( | ||||||
|  |             output_dir_name + '_release_symbols', options.outputdir) | ||||||
|  |         # transfer contents | ||||||
|  |         copy_file( | ||||||
|  |             os.path.join(build_dir, 'libcef.dll.pdb'), symbol_output_dir, | ||||||
|  |             options.quiet) | ||||||
|     else: |     else: | ||||||
|       copy_file( |       sys.stderr.write("No Release build files.\n") | ||||||
|           os.path.join(build_dir, 'cefclient.exe'), dst_dir, options.quiet) |  | ||||||
|  |  | ||||||
|     if not options.nosymbols: |  | ||||||
|       # create the symbol output directory |  | ||||||
|       symbol_output_dir = create_output_dir( |  | ||||||
|           output_dir_name + '_release_symbols', options.outputdir) |  | ||||||
|       # transfer contents |  | ||||||
|       copy_file( |  | ||||||
|           os.path.join(build_dir, 'libcef.dll.pdb'), symbol_output_dir, |  | ||||||
|           options.quiet) |  | ||||||
|   else: |  | ||||||
|     sys.stderr.write("No Release build files.\n") |  | ||||||
|  |  | ||||||
|   if not valid_build_dir is None: |   if not valid_build_dir is None: | ||||||
|     # transfer resource files |     # transfer resource files | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user