mirror of
				https://bitbucket.org/chromiumembedded/cef
				synced 2025-06-05 21:39:12 +02:00 
			
		
		
		
	Compare commits
	
		
			60 Commits
		
	
	
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|  | f984155b3f | ||
|  | 80bd6062d7 | ||
|  | 88ff29a56a | ||
|  | beccb2dd1b | ||
|  | 6b8ef03a2b | ||
|  | c8ee0ae2ca | ||
|  | d6fc4a4c16 | ||
|  | 8b2618a72a | ||
|  | 4fdfc02858 | ||
|  | d685d27313 | ||
|  | fd774d81ad | ||
|  | 6e0baff75c | ||
|  | f264ab9620 | ||
|  | c993bcadc3 | ||
|  | edbfb207b8 | ||
|  | d7f087e766 | ||
|  | 7f76148993 | ||
|  | 7843d6cdff | ||
|  | a8ecb191da | ||
|  | 6064e023ff | ||
|  | a841c0a319 | ||
|  | fbe14a56a8 | ||
|  | a76670a3ed | ||
|  | fe419c09ec | ||
|  | 0187add5ae | ||
|  | 9610905541 | ||
|  | ac9d105c5d | ||
|  | 9c76128317 | ||
|  | b462c19db1 | ||
|  | 53b3f1c274 | ||
|  | cc0e7d207c | ||
|  | 648b7b243f | ||
|  | b099f8cb79 | ||
|  | aeeb51361b | ||
|  | 7a2765f89c | ||
|  | 3beb937bcb | ||
|  | d59682018c | ||
|  | 5cea4e312b | ||
|  | f7014becfa | ||
|  | e30a588a4c | ||
|  | 6e2177b6fa | ||
|  | 666341d24e | ||
|  | afbd288efa | ||
|  | 814fe1e069 | ||
|  | ebddf7c5f3 | ||
|  | 713ddcc96d | ||
|  | ed84471e8a | ||
|  | 99e95ca434 | ||
|  | a6c42a74b1 | ||
|  | 67eba55c79 | ||
|  | 97fe56d30c | ||
|  | f3598b5ab0 | ||
|  | dd8daeb8c9 | ||
|  | 8fc370c9be | ||
|  | 499813b294 | ||
|  | 3a77b243a3 | ||
|  | 0ad5d2918b | ||
|  | 37753febf5 | ||
|  | 5cd77e8491 | ||
|  | 287664d85f | 
							
								
								
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										3
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -46,4 +46,7 @@ Thumbs.db | |||||||
| /binary_distrib | /binary_distrib | ||||||
| /docs | /docs | ||||||
| # CEF generated files | # CEF generated files | ||||||
|  | /include/cef_pack_resources.h | ||||||
|  | /include/cef_pack_strings.h | ||||||
| /include/cef_version.h | /include/cef_version.h | ||||||
|  | /patch/patch_state.h | ||||||
|   | |||||||
| @@ -1,9 +0,0 @@ | |||||||
| # Copyright (c) 2017 The Chromium Embedded Framework Authors. All rights |  | ||||||
| # reserved. Use of this source code is governed by a BSD-style license that |  | ||||||
| # can be found in the LICENSE file |  | ||||||
|  |  | ||||||
| # Configuration settings for tools/fix_style.py |  | ||||||
| { |  | ||||||
|   # Directories containing these path components will be ignored. |  | ||||||
|   'ignore_directories': ['yapf'], |  | ||||||
| } |  | ||||||
| @@ -1,2 +0,0 @@ | |||||||
| [style] |  | ||||||
| based_on_style = chromium |  | ||||||
							
								
								
									
										420
									
								
								BUILD.gn
									
									
									
									
									
								
							
							
						
						
									
										420
									
								
								BUILD.gn
									
									
									
									
									
								
							| @@ -13,14 +13,14 @@ | |||||||
| #    Optionally configure GN by setting the `GN_DEFINES` and/or `GN_ARGUMENTS` | #    Optionally configure GN by setting the `GN_DEFINES` and/or `GN_ARGUMENTS` | ||||||
| #    environment variables. | #    environment variables. | ||||||
| # | # | ||||||
| #    Example A: Create an official build on Windows: | #    Example A: Use /DEBUG:FASTLINK on Windows: | ||||||
| # | # | ||||||
| #      > set GN_DEFINES=is_official_build=true | #      > set GN_DEFINES=is_win_fastlink=true | ||||||
| # | # | ||||||
| #    Example B: Generate VS2017 project files in addition to the default Ninja | #    Example B: Generate VS2015 project files in addition to the default Ninja | ||||||
| #               build files on Windows: | #               build files on Windows: | ||||||
| # | # | ||||||
| #      > set GN_ARGUMENTS=--ide=vs2017 --sln=cef --filters=//cef/* | #      > set GN_ARGUMENTS=--ide=vs2015 --sln=cef --filters=//cef/* | ||||||
| # | # | ||||||
| #      After completing the "GN Automated Build" or "GN Manual Build" section | #      After completing the "GN Automated Build" or "GN Manual Build" section | ||||||
| #      open "out\<build_dir>\cef.sln" for editing and debugging. Building must | #      open "out\<build_dir>\cef.sln" for editing and debugging. Building must | ||||||
| @@ -99,32 +99,24 @@ import("//build/config/locales.gni") | |||||||
| import("//build/config/sanitizers/sanitizers.gni") | import("//build/config/sanitizers/sanitizers.gni") | ||||||
| import("//build/config/ui.gni") | import("//build/config/ui.gni") | ||||||
| import("//cef/cef_repack_locales.gni") | import("//cef/cef_repack_locales.gni") | ||||||
| import("//chrome/common/features.gni") |  | ||||||
| import("//extensions/buildflags/buildflags.gni") |  | ||||||
| import("//media/media_options.gni") | import("//media/media_options.gni") | ||||||
| import("//mojo/public/tools/bindings/mojom.gni") | import("//mojo/public/tools/bindings/mojom.gni") | ||||||
| import("//ppapi/buildflags/buildflags.gni") |  | ||||||
| import("//printing/buildflags/buildflags.gni") |  | ||||||
| import("//services/catalog/public/tools/catalog.gni") |  | ||||||
| import("//services/service_manager/public/service_manifest.gni") |  | ||||||
| import("//third_party/icu/config.gni") | import("//third_party/icu/config.gni") | ||||||
| import("//third_party/widevine/cdm/widevine.gni") | import("//third_party/widevine/cdm/widevine.gni") | ||||||
| import("//tools/grit/repack.gni") | import("//tools/grit/repack.gni") | ||||||
| import("//tools/grit/grit_rule.gni") | import("//tools/grit/grit_rule.gni") | ||||||
| import("//tools/v8_context_snapshot/v8_context_snapshot.gni") |  | ||||||
| import("//v8/gni/v8.gni") | import("//v8/gni/v8.gni") | ||||||
| if (is_clang) { | if (is_clang) { | ||||||
|   import("//build/config/clang/clang.gni") |   import("//build/config/clang/clang.gni") | ||||||
| } | } | ||||||
| if (is_linux) { | if (is_linux) { | ||||||
|   import("//build/config/linux/pkg_config.gni") |   import("//build/config/linux/pkg_config.gni") | ||||||
|   import("//third_party/fontconfig/fontconfig.gni") |  | ||||||
| } | } | ||||||
| if (is_mac) { | if (is_mac) { | ||||||
|   import("//build/config/mac/rules.gni") |   import("//build/config/mac/rules.gni") | ||||||
|  |   import("//build_overrides/v8.gni") | ||||||
|   import("//build/mac/tweak_info_plist.gni") |   import("//build/mac/tweak_info_plist.gni") | ||||||
|   import("//build/util/version.gni") |   import("//media/cdm/ppapi/cdm_paths.gni") | ||||||
|   import("//media/cdm/library_cdm/cdm_paths.gni") |  | ||||||
| } | } | ||||||
| if (is_win) { | if (is_win) { | ||||||
|   import("//build/config/win/console_app.gni") |   import("//build/config/win/console_app.gni") | ||||||
| @@ -144,16 +136,17 @@ assert(!enable_print_preview) | |||||||
| # Enable support for Widevine CDM. | # Enable support for Widevine CDM. | ||||||
| assert(enable_widevine) | assert(enable_widevine) | ||||||
|  |  | ||||||
|  | # Disable support for plugin installation. | ||||||
|  | assert(!enable_plugin_installation) | ||||||
|  |  | ||||||
| if (is_clang) { | if (is_clang) { | ||||||
|   # Don't use the chrome style plugin. |   # Don't use the chrome style plugin. | ||||||
|   assert(!clang_use_chrome_plugins) |   assert(!clang_use_chrome_plugins) | ||||||
| } | } | ||||||
|  |  | ||||||
| if (is_linux) { | # CEF does not currently support component builds. See | ||||||
|   # Use system fontconfig. This avoids a startup hang on Ubuntu 16.04.4 (see | # https://bitbucket.org/chromiumembedded/cef/issues/1617 | ||||||
|   # issue #2424). | assert(!is_component_build) | ||||||
|   assert(!use_bundled_fontconfig) |  | ||||||
| } |  | ||||||
|  |  | ||||||
| if (is_mac) { | if (is_mac) { | ||||||
|   # Always generate dSYM files. The make_distrib script will fail if |   # Always generate dSYM files. The make_distrib script will fail if | ||||||
| @@ -167,45 +160,8 @@ if (is_mac) { | |||||||
| # | # | ||||||
|  |  | ||||||
| if (is_mac) { | if (is_mac) { | ||||||
|   cef_commit_number = exec_script( |   # TODO(cef): Generate this value using version.py. | ||||||
|     "//cef/tools/commit_number.py", |   cef_version = "99.77.34.5" | ||||||
|     [ rebase_path("//cef", root_build_dir) ], |  | ||||||
|     "trim string", []) |  | ||||||
|  |  | ||||||
|   cef_version_file = "//cef/VERSION" |  | ||||||
|  |  | ||||||
|   # The tweak_info_plist.py script requires a version number with 4 parts. CEF |  | ||||||
|   # uses a version number with 3 parts so just set the last part to 0. |  | ||||||
|   cef_plist_version = exec_script( |  | ||||||
|     "//build/util/version.py", |  | ||||||
|     [ |  | ||||||
|       "-f", |  | ||||||
|       rebase_path(cef_version_file, root_build_dir), |  | ||||||
|       "-f", |  | ||||||
|       rebase_path(chrome_version_file, root_build_dir), |  | ||||||
|       "-t", |  | ||||||
|       "@CEF_MAJOR@.@BUILD@.${cef_commit_number}.0", |  | ||||||
|     ], |  | ||||||
|     "trim string", |  | ||||||
|     [ cef_version_file, chrome_version_file ]) |  | ||||||
|  |  | ||||||
|   # Need to be creative to match dylib version formatting requirements. |  | ||||||
|   cef_dylib_version = exec_script( |  | ||||||
|     "//build/util/version.py", |  | ||||||
|     [ |  | ||||||
|       "-f", |  | ||||||
|       rebase_path(cef_version_file, root_build_dir), |  | ||||||
|       "-f", |  | ||||||
|       rebase_path(chrome_version_file, root_build_dir), |  | ||||||
|       "-t", |  | ||||||
|       "@CEF_MAJOR@${cef_commit_number}.@BUILD_HI@.@BUILD_LO@", |  | ||||||
|       "-e", |  | ||||||
|       "BUILD_HI=int(BUILD)/256", |  | ||||||
|       "-e", |  | ||||||
|       "BUILD_LO=int(BUILD)%256", |  | ||||||
|     ], |  | ||||||
|     "trim string", |  | ||||||
|     [ cef_version_file, chrome_version_file ]) |  | ||||||
| } | } | ||||||
|  |  | ||||||
| # Read file lists from gypi files. The gypi_to_gn.py script does not support | # Read file lists from gypi files. The gypi_to_gn.py script does not support | ||||||
| @@ -239,46 +195,15 @@ group("cef") { | |||||||
| # libcef static target. | # libcef static target. | ||||||
| # | # | ||||||
|  |  | ||||||
| if (is_win) { | # Configuration that will be applied to all targets that depend on | ||||||
|   # Target for building code that accesses chrome_elf internals. Included from | # libcef_static. | ||||||
|   # the //chrome_elf:crash target. Defined as a static_library instead of a | config("libcef_static_config") { | ||||||
|   # source_set because (a) the source files don't export any symbols and (b) |   # CEF targets use includes relative to the CEF root directory. | ||||||
|   # *_switches.cc duplication otherwise causes linker errors. |   include_dirs = [ "." ] | ||||||
|   static_library("chrome_elf_set") { |   defines = [ | ||||||
|     sources = [ |     "BUILDING_CEF_SHARED", | ||||||
|       "libcef/common/crash_reporter_client.cc", |     "USING_CHROMIUM_INCLUDES", | ||||||
|       "libcef/common/crash_reporter_client.h", |  | ||||||
|  |  | ||||||
|       # Required for crash_keys::GetChromeCrashKeys. |  | ||||||
|       # Otherwise we need to copy this array into CEF, which would be difficult |  | ||||||
|       # to maintain. |  | ||||||
|       "//chrome/common/crash_keys.cc", |  | ||||||
|       "//chrome/common/chrome_switches.cc", |  | ||||||
|       "//components/flags_ui/flags_ui_switches.cc", |  | ||||||
|       "//content/public/common/content_switches.cc", |  | ||||||
|   ] |   ] | ||||||
|  |  | ||||||
|     configs += [ |  | ||||||
|       "libcef/features:config", |  | ||||||
|       "//build/config:precompiled_headers", |  | ||||||
|     ] |  | ||||||
|  |  | ||||||
|     if (is_component_build) { |  | ||||||
|       # Avoid linker errors with content_switches.cc in component build by not |  | ||||||
|       # defining CONTENT_EXPORT. |  | ||||||
|       defines = ["COMPILE_CONTENT_STATICALLY"] |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     deps = [ |  | ||||||
|       "//components/crash/core/common",  # crash_keys |  | ||||||
|  |  | ||||||
|       # Required by chrome_switches.cc |  | ||||||
|       "//chrome/common:buildflags", |  | ||||||
|       "//ppapi/buildflags:buildflags", |  | ||||||
|       "//printing/buildflags:buildflags", |  | ||||||
|       "//ui/base:ui_features", |  | ||||||
|     ] |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|  |  | ||||||
| static_library("libcef_static") { | static_library("libcef_static") { | ||||||
| @@ -288,8 +213,6 @@ static_library("libcef_static") { | |||||||
|     "libcef/browser/browser_context.h", |     "libcef/browser/browser_context.h", | ||||||
|     "libcef/browser/browser_context_impl.cc", |     "libcef/browser/browser_context_impl.cc", | ||||||
|     "libcef/browser/browser_context_impl.h", |     "libcef/browser/browser_context_impl.h", | ||||||
|     "libcef/browser/browser_context_keyed_service_factories.cc", |  | ||||||
|     "libcef/browser/browser_context_keyed_service_factories.h", |  | ||||||
|     "libcef/browser/browser_context_proxy.cc", |     "libcef/browser/browser_context_proxy.cc", | ||||||
|     "libcef/browser/browser_context_proxy.h", |     "libcef/browser/browser_context_proxy.h", | ||||||
|     "libcef/browser/browser_host_impl.cc", |     "libcef/browser/browser_host_impl.cc", | ||||||
| @@ -333,16 +256,12 @@ static_library("libcef_static") { | |||||||
|     "libcef/browser/download_item_impl.h", |     "libcef/browser/download_item_impl.h", | ||||||
|     "libcef/browser/download_manager_delegate.cc", |     "libcef/browser/download_manager_delegate.cc", | ||||||
|     "libcef/browser/download_manager_delegate.h", |     "libcef/browser/download_manager_delegate.h", | ||||||
|     "libcef/browser/extension_impl.cc", |  | ||||||
|     "libcef/browser/extension_impl.h", |  | ||||||
|     "libcef/browser/extensions/api/storage/sync_value_store_cache.cc", |  | ||||||
|     "libcef/browser/extensions/api/storage/sync_value_store_cache.h", |  | ||||||
|     "libcef/browser/extensions/api/tabs/tabs_api.cc", |     "libcef/browser/extensions/api/tabs/tabs_api.cc", | ||||||
|     "libcef/browser/extensions/api/tabs/tabs_api.h", |     "libcef/browser/extensions/api/tabs/tabs_api.h", | ||||||
|  |     "libcef/browser/extensions/browser_context_keyed_service_factories.cc", | ||||||
|  |     "libcef/browser/extensions/browser_context_keyed_service_factories.h", | ||||||
|     "libcef/browser/extensions/browser_extensions_util.cc", |     "libcef/browser/extensions/browser_extensions_util.cc", | ||||||
|     "libcef/browser/extensions/browser_extensions_util.h", |     "libcef/browser/extensions/browser_extensions_util.h", | ||||||
|     "libcef/browser/extensions/browser_platform_delegate_background.cc", |  | ||||||
|     "libcef/browser/extensions/browser_platform_delegate_background.h", |  | ||||||
|     "libcef/browser/extensions/chrome_api_registration.cc", |     "libcef/browser/extensions/chrome_api_registration.cc", | ||||||
|     "libcef/browser/extensions/chrome_api_registration.h", |     "libcef/browser/extensions/chrome_api_registration.h", | ||||||
|     "libcef/browser/extensions/component_extension_resource_manager.cc", |     "libcef/browser/extensions/component_extension_resource_manager.cc", | ||||||
| @@ -351,18 +270,10 @@ static_library("libcef_static") { | |||||||
|     "libcef/browser/extensions/extensions_api_client.h", |     "libcef/browser/extensions/extensions_api_client.h", | ||||||
|     "libcef/browser/extensions/extensions_browser_client.cc", |     "libcef/browser/extensions/extensions_browser_client.cc", | ||||||
|     "libcef/browser/extensions/extensions_browser_client.h", |     "libcef/browser/extensions/extensions_browser_client.h", | ||||||
|     "libcef/browser/extensions/extension_background_host.cc", |  | ||||||
|     "libcef/browser/extensions/extension_background_host.h", |  | ||||||
|     "libcef/browser/extensions/extension_function_details.cc", |  | ||||||
|     "libcef/browser/extensions/extension_function_details.h", |  | ||||||
|     "libcef/browser/extensions/extension_host_delegate.cc", |  | ||||||
|     "libcef/browser/extensions/extension_host_delegate.h", |  | ||||||
|     "libcef/browser/extensions/extension_system.cc", |     "libcef/browser/extensions/extension_system.cc", | ||||||
|     "libcef/browser/extensions/extension_system.h", |     "libcef/browser/extensions/extension_system.h", | ||||||
|     "libcef/browser/extensions/extension_system_factory.cc", |     "libcef/browser/extensions/extension_system_factory.cc", | ||||||
|     "libcef/browser/extensions/extension_system_factory.h", |     "libcef/browser/extensions/extension_system_factory.h", | ||||||
|     "libcef/browser/extensions/extension_view_host.cc", |  | ||||||
|     "libcef/browser/extensions/extension_view_host.h", |  | ||||||
|     "libcef/browser/extensions/extension_web_contents_observer.cc", |     "libcef/browser/extensions/extension_web_contents_observer.cc", | ||||||
|     "libcef/browser/extensions/extension_web_contents_observer.h", |     "libcef/browser/extensions/extension_web_contents_observer.h", | ||||||
|     "libcef/browser/extensions/mime_handler_view_guest_delegate.cc", |     "libcef/browser/extensions/mime_handler_view_guest_delegate.cc", | ||||||
| @@ -371,15 +282,12 @@ static_library("libcef_static") { | |||||||
|     "libcef/browser/extensions/pdf_extension_util.h", |     "libcef/browser/extensions/pdf_extension_util.h", | ||||||
|     "libcef/browser/extensions/pdf_web_contents_helper_client.cc", |     "libcef/browser/extensions/pdf_web_contents_helper_client.cc", | ||||||
|     "libcef/browser/extensions/pdf_web_contents_helper_client.h", |     "libcef/browser/extensions/pdf_web_contents_helper_client.h", | ||||||
|     "libcef/browser/extensions/value_store/cef_value_store.cc", |  | ||||||
|     "libcef/browser/extensions/value_store/cef_value_store.h", |  | ||||||
|     "libcef/browser/extensions/value_store/cef_value_store_factory.cc", |  | ||||||
|     "libcef/browser/extensions/value_store/cef_value_store_factory.h", |  | ||||||
|     "libcef/browser/file_dialog_runner.h", |     "libcef/browser/file_dialog_runner.h", | ||||||
|     "libcef/browser/file_dialog_manager.cc", |     "libcef/browser/file_dialog_manager.cc", | ||||||
|     "libcef/browser/file_dialog_manager.h", |     "libcef/browser/file_dialog_manager.h", | ||||||
|     "libcef/browser/frame_host_impl.cc", |     "libcef/browser/frame_host_impl.cc", | ||||||
|     "libcef/browser/frame_host_impl.h", |     "libcef/browser/frame_host_impl.h", | ||||||
|  |     "libcef/browser/geolocation_impl.cc", | ||||||
|     "libcef/browser/image_impl.cc", |     "libcef/browser/image_impl.cc", | ||||||
|     "libcef/browser/image_impl.h", |     "libcef/browser/image_impl.h", | ||||||
|     "libcef/browser/javascript_dialog_runner.h", |     "libcef/browser/javascript_dialog_runner.h", | ||||||
| @@ -402,21 +310,18 @@ static_library("libcef_static") { | |||||||
|     "libcef/browser/net/chrome_scheme_handler.h", |     "libcef/browser/net/chrome_scheme_handler.h", | ||||||
|     "libcef/browser/net/cookie_store_proxy.cc", |     "libcef/browser/net/cookie_store_proxy.cc", | ||||||
|     "libcef/browser/net/cookie_store_proxy.h", |     "libcef/browser/net/cookie_store_proxy.h", | ||||||
|     "libcef/browser/net/crlset_file_util_impl.cc", |  | ||||||
|     "libcef/browser/net/devtools_scheme_handler.cc", |     "libcef/browser/net/devtools_scheme_handler.cc", | ||||||
|     "libcef/browser/net/devtools_scheme_handler.h", |     "libcef/browser/net/devtools_scheme_handler.h", | ||||||
|     "libcef/browser/net/internal_scheme_handler.cc", |     "libcef/browser/net/internal_scheme_handler.cc", | ||||||
|     "libcef/browser/net/internal_scheme_handler.h", |     "libcef/browser/net/internal_scheme_handler.h", | ||||||
|     "libcef/browser/net/net_util.cc", |  | ||||||
|     "libcef/browser/net/net_util.h", |  | ||||||
|     "libcef/browser/net/network_delegate.cc", |     "libcef/browser/net/network_delegate.cc", | ||||||
|     "libcef/browser/net/network_delegate.h", |     "libcef/browser/net/network_delegate.h", | ||||||
|     "libcef/browser/net/resource_request_job.cc", |     "libcef/browser/net/resource_request_job.cc", | ||||||
|     "libcef/browser/net/resource_request_job.h", |     "libcef/browser/net/resource_request_job.h", | ||||||
|  |     "libcef/browser/net/response_filter_wrapper.cc", | ||||||
|  |     "libcef/browser/net/response_filter_wrapper.h", | ||||||
|     "libcef/browser/net/scheme_handler.cc", |     "libcef/browser/net/scheme_handler.cc", | ||||||
|     "libcef/browser/net/scheme_handler.h", |     "libcef/browser/net/scheme_handler.h", | ||||||
|     "libcef/browser/net/source_stream.cc", |  | ||||||
|     "libcef/browser/net/source_stream.h", |  | ||||||
|     "libcef/browser/net/url_request_context.cc", |     "libcef/browser/net/url_request_context.cc", | ||||||
|     "libcef/browser/net/url_request_context.h", |     "libcef/browser/net/url_request_context.h", | ||||||
|     "libcef/browser/net/url_request_context_getter.h", |     "libcef/browser/net/url_request_context_getter.h", | ||||||
| @@ -437,8 +342,6 @@ static_library("libcef_static") { | |||||||
|     "libcef/browser/origin_whitelist_impl.h", |     "libcef/browser/origin_whitelist_impl.h", | ||||||
|     "libcef/browser/osr/browser_platform_delegate_osr.cc", |     "libcef/browser/osr/browser_platform_delegate_osr.cc", | ||||||
|     "libcef/browser/osr/browser_platform_delegate_osr.h", |     "libcef/browser/osr/browser_platform_delegate_osr.h", | ||||||
|     "libcef/browser/osr/osr_accessibility_util.cc", |  | ||||||
|     "libcef/browser/osr/osr_accessibility_util.h", |  | ||||||
|     "libcef/browser/osr/osr_util.cc", |     "libcef/browser/osr/osr_util.cc", | ||||||
|     "libcef/browser/osr/osr_util.h", |     "libcef/browser/osr/osr_util.h", | ||||||
|     "libcef/browser/osr/render_widget_host_view_osr.cc", |     "libcef/browser/osr/render_widget_host_view_osr.cc", | ||||||
| @@ -448,12 +351,20 @@ static_library("libcef_static") { | |||||||
|     "libcef/browser/osr/web_contents_view_osr.cc", |     "libcef/browser/osr/web_contents_view_osr.cc", | ||||||
|     "libcef/browser/osr/web_contents_view_osr.h", |     "libcef/browser/osr/web_contents_view_osr.h", | ||||||
|     "libcef/browser/path_util_impl.cc", |     "libcef/browser/path_util_impl.cc", | ||||||
|  |     "libcef/browser/pepper/browser_pepper_host_factory.cc", | ||||||
|  |     "libcef/browser/pepper/browser_pepper_host_factory.h", | ||||||
|  |     "libcef/browser/permissions/permission_context.cc", | ||||||
|  |     "libcef/browser/permissions/permission_context.h", | ||||||
|  |     "libcef/browser/permissions/permission_manager.cc", | ||||||
|  |     "libcef/browser/permissions/permission_manager.h", | ||||||
|  |     "libcef/browser/permissions/permission_util.cc", | ||||||
|  |     "libcef/browser/permissions/permission_util.h", | ||||||
|  |     "libcef/browser/plugins/plugin_info_message_filter.cc", | ||||||
|  |     "libcef/browser/plugins/plugin_info_message_filter.h", | ||||||
|     "libcef/browser/plugins/plugin_service_filter.cc", |     "libcef/browser/plugins/plugin_service_filter.cc", | ||||||
|     "libcef/browser/plugins/plugin_service_filter.h", |     "libcef/browser/plugins/plugin_service_filter.h", | ||||||
|     "libcef/browser/prefs/browser_prefs.cc", |     "libcef/browser/prefs/browser_prefs.cc", | ||||||
|     "libcef/browser/prefs/browser_prefs.h", |     "libcef/browser/prefs/browser_prefs.h", | ||||||
|     "libcef/browser/prefs/pref_store.cc", |  | ||||||
|     "libcef/browser/prefs/pref_store.h", |  | ||||||
|     "libcef/browser/prefs/renderer_prefs.cc", |     "libcef/browser/prefs/renderer_prefs.cc", | ||||||
|     "libcef/browser/prefs/renderer_prefs.h", |     "libcef/browser/prefs/renderer_prefs.h", | ||||||
|     "libcef/browser/print_settings_impl.cc", |     "libcef/browser/print_settings_impl.cc", | ||||||
| @@ -472,8 +383,6 @@ static_library("libcef_static") { | |||||||
|     "libcef/browser/request_context_impl.cc", |     "libcef/browser/request_context_impl.cc", | ||||||
|     "libcef/browser/request_context_impl.h", |     "libcef/browser/request_context_impl.h", | ||||||
|     "libcef/browser/scheme_impl.cc", |     "libcef/browser/scheme_impl.cc", | ||||||
|     "libcef/browser/server_impl.cc", |  | ||||||
|     "libcef/browser/server_impl.h", |  | ||||||
|     "libcef/browser/speech_recognition_manager_delegate.cc", |     "libcef/browser/speech_recognition_manager_delegate.cc", | ||||||
|     "libcef/browser/speech_recognition_manager_delegate.h", |     "libcef/browser/speech_recognition_manager_delegate.h", | ||||||
|     "libcef/browser/ssl_host_state_delegate.cc", |     "libcef/browser/ssl_host_state_delegate.cc", | ||||||
| @@ -585,14 +494,22 @@ static_library("libcef_static") { | |||||||
|     "libcef/renderer/extensions/extensions_dispatcher_delegate.h", |     "libcef/renderer/extensions/extensions_dispatcher_delegate.h", | ||||||
|     "libcef/renderer/extensions/extensions_renderer_client.cc", |     "libcef/renderer/extensions/extensions_renderer_client.cc", | ||||||
|     "libcef/renderer/extensions/extensions_renderer_client.h", |     "libcef/renderer/extensions/extensions_renderer_client.h", | ||||||
|     "libcef/renderer/extensions/print_render_frame_helper_delegate.cc", |     "libcef/renderer/extensions/print_web_view_helper_delegate.cc", | ||||||
|     "libcef/renderer/extensions/print_render_frame_helper_delegate.h", |     "libcef/renderer/extensions/print_web_view_helper_delegate.h", | ||||||
|     "libcef/renderer/frame_impl.cc", |     "libcef/renderer/frame_impl.cc", | ||||||
|     "libcef/renderer/frame_impl.h", |     "libcef/renderer/frame_impl.h", | ||||||
|  |     "libcef/renderer/media/cef_key_systems.cc", | ||||||
|  |     "libcef/renderer/media/cef_key_systems.h", | ||||||
|  |     "libcef/renderer/pepper/pepper_helper.cc", | ||||||
|  |     "libcef/renderer/pepper/pepper_helper.h", | ||||||
|  |     "libcef/renderer/pepper/renderer_pepper_host_factory.cc", | ||||||
|  |     "libcef/renderer/pepper/renderer_pepper_host_factory.h", | ||||||
|  |     "libcef/renderer/plugins/cef_plugin_placeholder.cc", | ||||||
|  |     "libcef/renderer/plugins/cef_plugin_placeholder.h", | ||||||
|  |     "libcef/renderer/plugins/plugin_preroller.cc", | ||||||
|  |     "libcef/renderer/plugins/plugin_preroller.h", | ||||||
|     "libcef/renderer/render_frame_observer.cc", |     "libcef/renderer/render_frame_observer.cc", | ||||||
|     "libcef/renderer/render_frame_observer.h", |     "libcef/renderer/render_frame_observer.h", | ||||||
|     "libcef/renderer/render_frame_util.cc", |  | ||||||
|     "libcef/renderer/render_frame_util.h", |  | ||||||
|     "libcef/renderer/render_message_filter.cc", |     "libcef/renderer/render_message_filter.cc", | ||||||
|     "libcef/renderer/render_message_filter.h", |     "libcef/renderer/render_message_filter.h", | ||||||
|     "libcef/renderer/render_thread_observer.cc", |     "libcef/renderer/render_thread_observer.cc", | ||||||
| @@ -602,6 +519,8 @@ static_library("libcef_static") { | |||||||
|     "libcef/renderer/thread_util.h", |     "libcef/renderer/thread_util.h", | ||||||
|     "libcef/renderer/v8_impl.cc", |     "libcef/renderer/v8_impl.cc", | ||||||
|     "libcef/renderer/v8_impl.h", |     "libcef/renderer/v8_impl.h", | ||||||
|  |     "libcef/renderer/webkit_glue.cc", | ||||||
|  |     "libcef/renderer/webkit_glue.h", | ||||||
|     "libcef/utility/content_utility_client.cc", |     "libcef/utility/content_utility_client.cc", | ||||||
|     "libcef/utility/content_utility_client.h", |     "libcef/utility/content_utility_client.h", | ||||||
|  |  | ||||||
| @@ -609,23 +528,32 @@ static_library("libcef_static") { | |||||||
|     # with enable_print_preview=0. |     # with enable_print_preview=0. | ||||||
|     "//chrome/renderer/pepper/chrome_pdf_print_client.cc", |     "//chrome/renderer/pepper/chrome_pdf_print_client.cc", | ||||||
|     "//chrome/renderer/pepper/chrome_pdf_print_client.h", |     "//chrome/renderer/pepper/chrome_pdf_print_client.h", | ||||||
|  |  | ||||||
|  |     # Part of //components/prefs:test_support which is testingonly. | ||||||
|  |     "//components/prefs/testing_pref_store.cc", | ||||||
|  |     "//components/prefs/testing_pref_store.h", | ||||||
|   ] |   ] | ||||||
|  |  | ||||||
|   configs += [ |   configs += [ | ||||||
|     "libcef/features:config", |     ":libcef_static_config", | ||||||
|     "//build/config:precompiled_headers", |     "//build/config:precompiled_headers", | ||||||
|  |  | ||||||
|     # TODO(jschuh): crbug.com/167187 fix size_t to int truncations. |     # TODO(jschuh): crbug.com/167187 fix size_t to int truncations. | ||||||
|     "//build/config/compiler:no_size_t_to_int_warning", |     "//build/config/compiler:no_size_t_to_int_warning", | ||||||
|  |  | ||||||
|  |     # Blink-internal include paths. | ||||||
|  |     "//third_party/WebKit/Source/core:core_include_dirs", | ||||||
|   ] |   ] | ||||||
|  |  | ||||||
|   public_configs = [ |   public_configs = [ | ||||||
|     "libcef/features:config", |     ":libcef_static_config", | ||||||
|   ] |   ] | ||||||
|  |  | ||||||
|   include_dirs = [ |   include_dirs = [ | ||||||
|     # Crashpad code uses paths relative to this directory. |     # Blink code uses paths relative to these directories. We need them because | ||||||
|     "//third_party/crashpad/crashpad", |     # we include Blink headers. | ||||||
|  |     "//third_party/WebKit/public/platform", | ||||||
|  |     "//third_party/WebKit/public/web", | ||||||
|   ] |   ] | ||||||
|  |  | ||||||
|   public_deps = [ |   public_deps = [ | ||||||
| @@ -654,10 +582,7 @@ static_library("libcef_static") { | |||||||
|     "//chrome/child", |     "//chrome/child", | ||||||
|     "//chrome/common", |     "//chrome/common", | ||||||
|     "//chrome/renderer", |     "//chrome/renderer", | ||||||
|     "//chrome/services/printing:lib", |  | ||||||
|     "//chrome/utility", |  | ||||||
|     "//components/cdm/renderer", |     "//components/cdm/renderer", | ||||||
|     "//components/certificate_transparency", |  | ||||||
|     "//components/content_settings/core/browser", |     "//components/content_settings/core/browser", | ||||||
|     "//components/content_settings/core/common", |     "//components/content_settings/core/common", | ||||||
|     "//components/crx_file", |     "//components/crx_file", | ||||||
| @@ -666,7 +591,6 @@ static_library("libcef_static") { | |||||||
|     "//components/keyed_service/content:content", |     "//components/keyed_service/content:content", | ||||||
|     "//components/keyed_service/core:core", |     "//components/keyed_service/core:core", | ||||||
|     "//components/navigation_interception", |     "//components/navigation_interception", | ||||||
|     "//components/network_session_configurator/browser", |  | ||||||
|     "//components/pdf/browser", |     "//components/pdf/browser", | ||||||
|     "//components/pdf/renderer", |     "//components/pdf/renderer", | ||||||
|     "//components/plugins/renderer", |     "//components/plugins/renderer", | ||||||
| @@ -674,10 +598,8 @@ static_library("libcef_static") { | |||||||
|     "//components/printing/browser", |     "//components/printing/browser", | ||||||
|     "//components/printing/common", |     "//components/printing/common", | ||||||
|     "//components/printing/renderer", |     "//components/printing/renderer", | ||||||
|     "//components/services/pdf_compositor:pdf_compositor_manifest", |  | ||||||
|     "//components/services/pdf_compositor/public/cpp:utils", |  | ||||||
|     "//components/services/pdf_compositor/public/interfaces", |  | ||||||
|     "//components/proxy_config", |     "//components/proxy_config", | ||||||
|  |     "//components/ssl_config", | ||||||
|     "//components/update_client", |     "//components/update_client", | ||||||
|     "//components/url_formatter", |     "//components/url_formatter", | ||||||
|     "//components/user_prefs", |     "//components/user_prefs", | ||||||
| @@ -685,48 +607,39 @@ static_library("libcef_static") { | |||||||
|     "//components/visitedlink/browser", |     "//components/visitedlink/browser", | ||||||
|     "//components/visitedlink/common", |     "//components/visitedlink/common", | ||||||
|     "//components/visitedlink/renderer", |     "//components/visitedlink/renderer", | ||||||
|     "//components/viz/service", |  | ||||||
|     "//components/web_cache/renderer", |     "//components/web_cache/renderer", | ||||||
|     "//content/public/app:both", |     "//content/public/app:both", | ||||||
|     "//content/public/browser", |     "//content/public/browser", | ||||||
|     "//content/public/child", |  | ||||||
|     "//content/public/common", |     "//content/public/common", | ||||||
|     "//content/public/gpu", |     "//content/public/gpu", | ||||||
|     "//content/public/renderer", |     "//content/public/renderer", | ||||||
|     "//content/public/utility", |     "//content/public/utility", | ||||||
|     "//crypto", |     "//crypto", | ||||||
|     "//device/base", |     "//device/core", | ||||||
|  |     "//device/geolocation", | ||||||
|  |     "//device/hid", | ||||||
|     "//extensions/browser", |     "//extensions/browser", | ||||||
|     "//extensions/browser/api:api_registration", |  | ||||||
|     "//extensions/buildflags", |  | ||||||
|     "//extensions/common/api", |     "//extensions/common/api", | ||||||
|  |     "//extensions/common/api:api_registration", | ||||||
|     "//extensions/renderer", |     "//extensions/renderer", | ||||||
|  |     "//extensions/utility", | ||||||
|     "//gpu", |     "//gpu", | ||||||
|     "//ipc", |     "//ipc", | ||||||
|     "//media", |     "//media", | ||||||
|     "//media/blink", |     "//media/blink", | ||||||
|     "//net", |     "//net", | ||||||
|     "//net:net_browser_services", |     "//net:net_browser_services", | ||||||
|     "//net:net_utility_services", |  | ||||||
|     "//net:net_with_v8", |     "//net:net_with_v8", | ||||||
|     "//pdf", |     "//pdf", | ||||||
|     "//ppapi/buildflags", |  | ||||||
|     "//printing/buildflags", |  | ||||||
|     "//services/network:network_service", |  | ||||||
|     "//services/network/public/cpp", |  | ||||||
|     "//services/service_manager/embedder", |  | ||||||
|     "//services/service_manager/public/cpp", |  | ||||||
|     "//services/service_manager/runner/common", |  | ||||||
|     "//skia", |     "//skia", | ||||||
|     "//storage/browser", |     "//storage/browser", | ||||||
|     "//third_party/blink/public:blink", |     "//third_party/brotli", | ||||||
|     "//third_party/brotli:dec", |     "//third_party/cld", | ||||||
|     "//third_party/cld_3/src/src:cld_3", |  | ||||||
|     "//third_party/hunspell", |     "//third_party/hunspell", | ||||||
|     "//third_party/leveldatabase", |     "//third_party/leveldatabase", | ||||||
|     "//third_party/libxml", |     "//third_party/libxml", | ||||||
|     "//third_party/widevine/cdm:headers", |     "//third_party/WebKit/public:blink", | ||||||
|     "//third_party/widevine/cdm", |     "//third_party/widevine/cdm:version_h", | ||||||
|     "//third_party/icu", |     "//third_party/icu", | ||||||
|     "//third_party/zlib:minizip", |     "//third_party/zlib:minizip", | ||||||
|     "//ui/base", |     "//ui/base", | ||||||
| @@ -742,6 +655,11 @@ static_library("libcef_static") { | |||||||
|     "//v8", |     "//v8", | ||||||
|   ] |   ] | ||||||
|  |  | ||||||
|  |   if (!is_mac) { | ||||||
|  |     # TODO(cef): Enable for Mac once Widevine build errors are resolved. | ||||||
|  |     deps += [ "//third_party/widevine/cdm:widevinecdmadapter" ] | ||||||
|  |   } | ||||||
|  |  | ||||||
|   if (is_win) { |   if (is_win) { | ||||||
|     sources += gypi_paths2.includes_win + [ |     sources += gypi_paths2.includes_win + [ | ||||||
|       "libcef/browser/browser_main_win.cc", |       "libcef/browser/browser_main_win.cc", | ||||||
| @@ -761,23 +679,15 @@ static_library("libcef_static") { | |||||||
|       "libcef/browser/osr/browser_platform_delegate_osr_win.cc", |       "libcef/browser/osr/browser_platform_delegate_osr_win.cc", | ||||||
|       "libcef/browser/osr/browser_platform_delegate_osr_win.h", |       "libcef/browser/osr/browser_platform_delegate_osr_win.h", | ||||||
|       "libcef/browser/osr/render_widget_host_view_osr_win.cc", |       "libcef/browser/osr/render_widget_host_view_osr_win.cc", | ||||||
|  |       "libcef/common/crash_reporting_win.cc", | ||||||
|       # Part of //chrome/utility. |       "libcef/common/crash_reporting_win.h", | ||||||
|       "//chrome/utility/printing_handler.cc", |       "libcef/utility/printing_handler.cc", | ||||||
|       "//chrome/utility/printing_handler.h", |       "libcef/utility/printing_handler.h", | ||||||
|     ] |     ] | ||||||
|  |  | ||||||
|     deps += [ |     deps += [ | ||||||
|       "//chrome_elf", |       "//chrome_elf", | ||||||
|     ] |     ] | ||||||
|  |  | ||||||
|     if (is_component_build) { |  | ||||||
|       deps += [ "//content:sandbox_helper_win" ] |  | ||||||
|     } |  | ||||||
|  |  | ||||||
|     libs = [ |  | ||||||
|       "comctl32.lib", |  | ||||||
|     ] |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   if (is_linux) { |   if (is_linux) { | ||||||
| @@ -796,9 +706,8 @@ static_library("libcef_static") { | |||||||
|     ] |     ] | ||||||
|  |  | ||||||
|     deps += [ |     deps += [ | ||||||
|       "//build/config/freetype", |       "//build/linux:fontconfig", | ||||||
|       "//services/ui:lib", |       "//third_party/freetype2", | ||||||
|       "//third_party/fontconfig", |  | ||||||
|     ] |     ] | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -821,7 +730,7 @@ static_library("libcef_static") { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   if (is_win || is_mac) { |   if (is_win || is_mac) { | ||||||
|     deps += [ "//third_party/crashpad/crashpad/handler" ] |     deps += [ "//third_party/crashpad/crashpad/handler:handler_lib" ] | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   if (use_x11) { |   if (use_x11) { | ||||||
| @@ -829,21 +738,12 @@ static_library("libcef_static") { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   if (is_posix && !is_mac) { |   if (is_posix && !is_mac) { | ||||||
|     sources += [ |  | ||||||
|       "libcef/common/cef_crash_report_utils.cc", |  | ||||||
|       "libcef/common/cef_crash_report_utils.h", |  | ||||||
|     ] |  | ||||||
|  |  | ||||||
|     deps += [ |     deps += [ | ||||||
|       "//components/crash/content/app", |       "//components/crash/content/app", | ||||||
|       "//components/crash/content/browser", |       "//components/crash/content/browser", | ||||||
|     ] |     ] | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   if (v8_use_external_startup_data && use_v8_context_snapshot) { |  | ||||||
|     deps += [ "//tools/v8_context_snapshot" ] |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   if (use_aura) { |   if (use_aura) { | ||||||
|     sources += [ |     sources += [ | ||||||
|       "libcef/browser/native/window_delegate_view.cc", |       "libcef/browser/native/window_delegate_view.cc", | ||||||
| @@ -918,12 +818,10 @@ static_library("libcef_static") { | |||||||
|     ] |     ] | ||||||
|  |  | ||||||
|     deps += [ |     deps += [ | ||||||
|       "//services/ui", |  | ||||||
|       "//ui/aura", |       "//ui/aura", | ||||||
|       "//ui/events", |       "//ui/events", | ||||||
|       "//ui/strings", |       "//ui/strings", | ||||||
|       "//ui/wm", |       "//ui/wm", | ||||||
|       "//ui/wm/public", |  | ||||||
|     ] |     ] | ||||||
|  |  | ||||||
|     if (toolkit_views) { |     if (toolkit_views) { | ||||||
| @@ -936,11 +834,6 @@ static_library("libcef_static") { | |||||||
|     if (is_win) { |     if (is_win) { | ||||||
|       sources += [ |       sources += [ | ||||||
|         # Support for UI input events. |         # Support for UI input events. | ||||||
|         # Part of //base/test:test_config which is testingonly. |  | ||||||
|         "//base/test/test_switches.cc", |  | ||||||
|         "//base/test/test_switches.h", |  | ||||||
|         "//base/test/test_timeouts.cc", |  | ||||||
|         "//base/test/test_timeouts.h", |  | ||||||
|         # Part of //ui/aura:test_support which is testingonly. |         # Part of //ui/aura:test_support which is testingonly. | ||||||
|         "//ui/aura/test/ui_controls_factory_aurawin.cc", |         "//ui/aura/test/ui_controls_factory_aurawin.cc", | ||||||
|         # Part of //ui/base:test_support which is testingonly. |         # Part of //ui/base:test_support which is testingonly. | ||||||
| @@ -1023,45 +916,6 @@ if (is_win) { | |||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| # |  | ||||||
| # Service manifests. |  | ||||||
| # |  | ||||||
|  |  | ||||||
| cef_packaged_services = [ |  | ||||||
|   "//chrome/app:chrome_manifest",  # For spell checking. |  | ||||||
|   "//chrome/app:chrome_renderer_manifest",  # For spell checking. |  | ||||||
|   "//chrome/services/printing:manifest", |  | ||||||
|   "//services/metrics:manifest", |  | ||||||
|   "//services/proxy_resolver:proxy_resolver_manifest", |  | ||||||
| ] |  | ||||||
|  |  | ||||||
| service_manifest("cef_packaged_services_manifest_overlay") { |  | ||||||
|   source = "libcef/common/service_manifests/packaged_services_manifest_overlay.json" |  | ||||||
|   packaged_services = cef_packaged_services |  | ||||||
| } |  | ||||||
|  |  | ||||||
| service_manifest("cef_browser_manifest_overlay") { |  | ||||||
|   source = "libcef/common/service_manifests/browser_manifest_overlay.json" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| service_manifest("cef_renderer_manifest_overlay") { |  | ||||||
|   source = "libcef/common/service_manifests/renderer_manifest_overlay.json" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| service_manifest("cef_utility_manifest_overlay") { |  | ||||||
|   source = "libcef/common/service_manifests/utility_manifest_overlay.json" |  | ||||||
| } |  | ||||||
|  |  | ||||||
| group("cef_manifest_overlays") { |  | ||||||
|   deps = [ |  | ||||||
|     ":cef_packaged_services_manifest_overlay", |  | ||||||
|     ":cef_browser_manifest_overlay", |  | ||||||
|     ":cef_renderer_manifest_overlay", |  | ||||||
|     ":cef_utility_manifest_overlay", |  | ||||||
|   ] |  | ||||||
| } |  | ||||||
|  |  | ||||||
|  |  | ||||||
| # | # | ||||||
| # Resource grit/pack targets. | # Resource grit/pack targets. | ||||||
| # | # | ||||||
| @@ -1074,11 +928,11 @@ template("cef_pak_scaled") { | |||||||
|     # Each input pak file should also have a deps line for completeness. |     # Each input pak file should also have a deps line for completeness. | ||||||
|     # Add associated .h files in the make_pack_header("resources") target. |     # Add associated .h files in the make_pack_header("resources") target. | ||||||
|     sources = [ |     sources = [ | ||||||
|  |       "$root_gen_dir/blink/public/resources/blink_image_resources_${percent}_percent.pak", | ||||||
|       "$root_gen_dir/chrome/renderer_resources_${percent}_percent.pak", |       "$root_gen_dir/chrome/renderer_resources_${percent}_percent.pak", | ||||||
|       "$root_gen_dir/components/components_resources_${percent}_percent.pak", |       "$root_gen_dir/components/components_resources_${percent}_percent.pak", | ||||||
|       "$root_gen_dir/content/app/resources/content_resources_${percent}_percent.pak", |       "$root_gen_dir/content/app/resources/content_resources_${percent}_percent.pak", | ||||||
|       "$root_gen_dir/extensions/extensions_browser_resources_${percent}_percent.pak", |       "$root_gen_dir/extensions/extensions_browser_resources_${percent}_percent.pak", | ||||||
|       "$root_gen_dir/third_party/blink/public/resources/blink_scaled_resources_${percent}_percent.pak", |  | ||||||
|       "$root_gen_dir/ui/resources/ui_resources_${percent}_percent.pak", |       "$root_gen_dir/ui/resources/ui_resources_${percent}_percent.pak", | ||||||
|     ] |     ] | ||||||
|  |  | ||||||
| @@ -1086,20 +940,14 @@ template("cef_pak_scaled") { | |||||||
|     # the libcef_static target. Grit deps that generate .cc files must be |     # the libcef_static target. Grit deps that generate .cc files must be | ||||||
|     # listed both here and in the libcef_static target. |     # listed both here and in the libcef_static target. | ||||||
|     public_deps = [ |     public_deps = [ | ||||||
|  |       "//third_party/WebKit/public:image_resources", | ||||||
|       "//chrome/renderer:resources", |       "//chrome/renderer:resources", | ||||||
|       "//components/resources:components_scaled_resources", |       "//components/resources:components_scaled_resources", | ||||||
|       "//content/app/resources", |       "//content/app/resources", | ||||||
|       "//extensions:extensions_browser_resources", |       "//extensions:extensions_browser_resources", | ||||||
|       "//third_party/blink/public:scaled_resources", |  | ||||||
|       "//ui/resources:ui_resources_grd", |       "//ui/resources:ui_resources_grd", | ||||||
|     ] |     ] | ||||||
|  |  | ||||||
|     deps = [ |  | ||||||
|       # This repack target generates the blink_scaled_resources_*_percent.pak |  | ||||||
|       # file but doesn't expose the public_deps required by make_pack_header. |  | ||||||
|       "//third_party/blink/public:scaled_resources_${percent}_percent", |  | ||||||
|     ] |  | ||||||
|  |  | ||||||
|     if (toolkit_views) { |     if (toolkit_views) { | ||||||
|       sources += [ |       sources += [ | ||||||
|         "$root_gen_dir/ui/views/resources/views_resources_${percent}_percent.pak" |         "$root_gen_dir/ui/views/resources/views_resources_${percent}_percent.pak" | ||||||
| @@ -1129,7 +977,7 @@ repack("pak_devtools") { | |||||||
|   # Each input pak file should also have a deps line for completeness. |   # Each input pak file should also have a deps line for completeness. | ||||||
|   # Add associated .h files in the make_pack_header("resources") target. |   # Add associated .h files in the make_pack_header("resources") target. | ||||||
|   sources = [ |   sources = [ | ||||||
|     "$root_gen_dir/content/browser/devtools/devtools_resources.pak", |     "$root_gen_dir/blink/devtools_resources.pak", | ||||||
|   ] |   ] | ||||||
|  |  | ||||||
|   # Use public_deps so that generated grit headers are discoverable from |   # Use public_deps so that generated grit headers are discoverable from | ||||||
| @@ -1150,7 +998,6 @@ repack("pak_extensions") { | |||||||
|     "$root_gen_dir/chrome/component_extension_resources.pak", |     "$root_gen_dir/chrome/component_extension_resources.pak", | ||||||
|     "$root_gen_dir/extensions/extensions_renderer_resources.pak", |     "$root_gen_dir/extensions/extensions_renderer_resources.pak", | ||||||
|     "$root_gen_dir/extensions/extensions_resources.pak", |     "$root_gen_dir/extensions/extensions_resources.pak", | ||||||
|     "$root_gen_dir/mojo/public/js/mojo_bindings_resources.pak", |  | ||||||
|     "$root_gen_dir/ui/resources/webui_resources.pak", |     "$root_gen_dir/ui/resources/webui_resources.pak", | ||||||
|   ] |   ] | ||||||
|  |  | ||||||
| @@ -1161,7 +1008,6 @@ repack("pak_extensions") { | |||||||
|     "//chrome/browser/resources:component_extension_resources", |     "//chrome/browser/resources:component_extension_resources", | ||||||
|     "//extensions:extensions_renderer_resources", |     "//extensions:extensions_renderer_resources", | ||||||
|     "//extensions:extensions_resources_grd", |     "//extensions:extensions_resources_grd", | ||||||
|     "//mojo/public/js:resources", |  | ||||||
|     "//ui/resources:webui_resources_grd", |     "//ui/resources:webui_resources_grd", | ||||||
|   ] |   ] | ||||||
|  |  | ||||||
| @@ -1202,11 +1048,6 @@ grit("cef_resources") { | |||||||
|     "grit/cef_resources.h", |     "grit/cef_resources.h", | ||||||
|     "cef_resources.pak", |     "cef_resources.pak", | ||||||
|   ] |   ] | ||||||
|   grit_flags = [ |  | ||||||
|     "-E", |  | ||||||
|     "root_gen_dir=" + rebase_path(root_gen_dir, root_build_dir), |  | ||||||
|   ] |  | ||||||
|   deps = [ ":cef_manifest_overlays" ] |  | ||||||
| } | } | ||||||
|  |  | ||||||
| # Generate cef.pak. | # Generate cef.pak. | ||||||
| @@ -1214,6 +1055,7 @@ repack("pak") { | |||||||
|   # Each input pak file should also have a deps line for completeness. |   # Each input pak file should also have a deps line for completeness. | ||||||
|   # Add associated .h files in the make_pack_header("resources") target. |   # Add associated .h files in the make_pack_header("resources") target. | ||||||
|   sources = [ |   sources = [ | ||||||
|  |     "$root_gen_dir/blink/public/resources/blink_resources.pak", | ||||||
|     "$root_gen_dir/chrome/browser_resources.pak", |     "$root_gen_dir/chrome/browser_resources.pak", | ||||||
|     "$root_gen_dir/chrome/net_internals_resources.pak", |     "$root_gen_dir/chrome/net_internals_resources.pak", | ||||||
|     "$root_gen_dir/chrome/common_resources.pak", |     "$root_gen_dir/chrome/common_resources.pak", | ||||||
| @@ -1222,13 +1064,13 @@ repack("pak") { | |||||||
|     "$root_gen_dir/content/browser/tracing/tracing_resources.pak", |     "$root_gen_dir/content/browser/tracing/tracing_resources.pak", | ||||||
|     "$root_gen_dir/content/content_resources.pak", |     "$root_gen_dir/content/content_resources.pak", | ||||||
|     "$root_gen_dir/net/net_resources.pak", |     "$root_gen_dir/net/net_resources.pak", | ||||||
|     "$root_gen_dir/third_party/blink/public/resources/blink_resources.pak", |  | ||||||
|   ] |   ] | ||||||
|  |  | ||||||
|   # Use public_deps so that generated grit headers are discoverable from |   # Use public_deps so that generated grit headers are discoverable from | ||||||
|   # the libcef_static target. Grit deps that generate .cc files must be |   # the libcef_static target. Grit deps that generate .cc files must be | ||||||
|   # listed both here and in the libcef_static target. |   # listed both here and in the libcef_static target. | ||||||
|   public_deps = [ |   public_deps = [ | ||||||
|  |     "//third_party/WebKit/public:resources_grit", | ||||||
|     "//chrome/browser:resources", |     "//chrome/browser:resources", | ||||||
|     "//chrome/browser/resources:net_internals_resources", |     "//chrome/browser/resources:net_internals_resources", | ||||||
|     "//chrome/common:resources", |     "//chrome/common:resources", | ||||||
| @@ -1237,7 +1079,6 @@ repack("pak") { | |||||||
|     "//content/browser/tracing:resources", |     "//content/browser/tracing:resources", | ||||||
|     "//content:resources", |     "//content:resources", | ||||||
|     "//net:net_resources", |     "//net:net_resources", | ||||||
|     "//third_party/blink/public:resources", |  | ||||||
|   ] |   ] | ||||||
|  |  | ||||||
|   output = "$root_out_dir/cef.pak" |   output = "$root_out_dir/cef.pak" | ||||||
| @@ -1274,6 +1115,9 @@ template("make_pack_header") { | |||||||
| make_pack_header("resources") { | make_pack_header("resources") { | ||||||
|   header = "$root_out_dir/includes/include/cef_pack_resources.h" |   header = "$root_out_dir/includes/include/cef_pack_resources.h" | ||||||
|   inputs = [ |   inputs = [ | ||||||
|  |     "$root_gen_dir/blink/grit/devtools_resources.h", | ||||||
|  |     "$root_gen_dir/blink/public/resources/grit/blink_image_resources.h", | ||||||
|  |     "$root_gen_dir/blink/public/resources/grit/blink_resources.h", | ||||||
|     "$root_gen_dir/cef/grit/cef_resources.h", |     "$root_gen_dir/cef/grit/cef_resources.h", | ||||||
|     "$root_gen_dir/chrome/grit/browser_resources.h", |     "$root_gen_dir/chrome/grit/browser_resources.h", | ||||||
|     "$root_gen_dir/chrome/grit/common_resources.h", |     "$root_gen_dir/chrome/grit/common_resources.h", | ||||||
| @@ -1281,14 +1125,12 @@ make_pack_header("resources") { | |||||||
|     "$root_gen_dir/chrome/grit/net_internals_resources.h", |     "$root_gen_dir/chrome/grit/net_internals_resources.h", | ||||||
|     "$root_gen_dir/chrome/grit/renderer_resources.h", |     "$root_gen_dir/chrome/grit/renderer_resources.h", | ||||||
|     "$root_gen_dir/components/grit/components_resources.h", |     "$root_gen_dir/components/grit/components_resources.h", | ||||||
|     "$root_gen_dir/content/browser/devtools/grit/devtools_resources.h", |  | ||||||
|     "$root_gen_dir/content/browser/tracing/grit/tracing_resources.h", |     "$root_gen_dir/content/browser/tracing/grit/tracing_resources.h", | ||||||
|     "$root_gen_dir/content/grit/content_resources.h", |     "$root_gen_dir/content/grit/content_resources.h", | ||||||
|     "$root_gen_dir/extensions/grit/extensions_browser_resources.h", |     "$root_gen_dir/extensions/grit/extensions_browser_resources.h", | ||||||
|     "$root_gen_dir/extensions/grit/extensions_renderer_resources.h", |     "$root_gen_dir/extensions/grit/extensions_renderer_resources.h", | ||||||
|     "$root_gen_dir/extensions/grit/extensions_resources.h", |     "$root_gen_dir/extensions/grit/extensions_resources.h", | ||||||
|     "$root_gen_dir/net/grit/net_resources.h", |     "$root_gen_dir/net/grit/net_resources.h", | ||||||
|     "$root_gen_dir/third_party/blink/public/resources/grit/blink_resources.h", |  | ||||||
|     "$root_gen_dir/ui/resources/grit/ui_resources.h", |     "$root_gen_dir/ui/resources/grit/ui_resources.h", | ||||||
|     "$root_gen_dir/ui/resources/grit/webui_resources.h", |     "$root_gen_dir/ui/resources/grit/webui_resources.h", | ||||||
|     "$root_gen_dir/ui/views/resources/grit/views_resources.h", |     "$root_gen_dir/ui/views/resources/grit/views_resources.h", | ||||||
| @@ -1326,7 +1168,7 @@ if (is_mac) { | |||||||
|       "--keystone=0", |       "--keystone=0", | ||||||
|       "--scm=1", |       "--scm=1", | ||||||
|       "--version", |       "--version", | ||||||
|       cef_plist_version, |       cef_version, | ||||||
|       "--branding", |       "--branding", | ||||||
|       cef_framework_name, |       cef_framework_name, | ||||||
|     ] |     ] | ||||||
| @@ -1354,6 +1196,8 @@ if (is_mac) { | |||||||
|       "$root_out_dir/cef_200_percent.pak", |       "$root_out_dir/cef_200_percent.pak", | ||||||
|       "$root_out_dir/cef_extensions.pak", |       "$root_out_dir/cef_extensions.pak", | ||||||
|       "$root_out_dir/devtools_resources.pak", |       "$root_out_dir/devtools_resources.pak", | ||||||
|  |       # TODO(cef): Restore this line once Widevine build errors are resolved. | ||||||
|  |       # "$root_out_dir/$widevine_cdm_path/widevinecdmadapter.plugin", | ||||||
|     ] |     ] | ||||||
|  |  | ||||||
|     public_deps = [ |     public_deps = [ | ||||||
| @@ -1362,6 +1206,8 @@ if (is_mac) { | |||||||
|       ":pak_200_percent", |       ":pak_200_percent", | ||||||
|       ":pak_devtools", |       ":pak_devtools", | ||||||
|       ":pak_extensions", |       ":pak_extensions", | ||||||
|  |       # TODO(cef): Restore this line once Widevine build errors are resolved. | ||||||
|  |       # "//third_party/widevine/cdm:widevinecdmadapter", | ||||||
|     ] |     ] | ||||||
|  |  | ||||||
|     if (icu_use_data_file) { |     if (icu_use_data_file) { | ||||||
| @@ -1375,10 +1221,6 @@ if (is_mac) { | |||||||
|         "$root_out_dir/snapshot_blob.bin", |         "$root_out_dir/snapshot_blob.bin", | ||||||
|       ] |       ] | ||||||
|       public_deps += [ "//v8" ] |       public_deps += [ "//v8" ] | ||||||
|       if (use_v8_context_snapshot) { |  | ||||||
|         sources += [ "$root_out_dir/v8_context_snapshot.bin" ] |  | ||||||
|         public_deps += [ "//tools/v8_context_snapshot" ] |  | ||||||
|       } |  | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     outputs = [ |     outputs = [ | ||||||
| @@ -1389,11 +1231,6 @@ if (is_mac) { | |||||||
|   mac_framework_bundle("cef_framework") { |   mac_framework_bundle("cef_framework") { | ||||||
|     output_name = cef_framework_name |     output_name = cef_framework_name | ||||||
|  |  | ||||||
|     framework_version = "A" |  | ||||||
|     framework_contents = [ |  | ||||||
|       "Resources", |  | ||||||
|     ] |  | ||||||
|  |  | ||||||
|     sources = gypi_paths2.includes_common + |     sources = gypi_paths2.includes_common + | ||||||
|               gypi_paths2.includes_mac + |               gypi_paths2.includes_mac + | ||||||
|               gypi_paths.autogen_cpp_includes + |               gypi_paths.autogen_cpp_includes + | ||||||
| @@ -1418,22 +1255,16 @@ if (is_mac) { | |||||||
|     # on one of the executables. However install_name_tool only operates |     # on one of the executables. However install_name_tool only operates | ||||||
|     # in-place, which is problematic to express in GN. Instead, use rpath-based |     # in-place, which is problematic to express in GN. Instead, use rpath-based | ||||||
|     # loading. |     # loading. | ||||||
|     ldflags = [ |     ldflags = [ "-Wl,-install_name,@rpath/Frameworks/$output_name.framework/$output_name" ] | ||||||
|       "-Wl,-install_name,@rpath/Frameworks/$output_name.framework/$output_name", |  | ||||||
|       "-compatibility_version", |  | ||||||
|       cef_dylib_version, |  | ||||||
|       "-current_version", |  | ||||||
|       cef_dylib_version, |  | ||||||
|     ] |  | ||||||
|  |  | ||||||
|     if (is_component_build) { |     if (is_component_build) { | ||||||
|       # Set up the rpath for the framework so that it can find dylibs in the |       # Set up the rpath for the framework so that it can find dylibs in the | ||||||
|       # root output directory. The framework is at |       # root output directory. The framework is at | ||||||
|       # $app_name.app/Contents/Frameworks/$output_name.framework/Versions/A/$output_name |       # $app_name.app/Contents/Frameworks/$output_name.framework/$output_name | ||||||
|       # so use loader_path to go back to the root output directory. |       # so use loader_path to go back to the root output directory. | ||||||
|       ldflags += [ |       ldflags += [ | ||||||
|         "-rpath", |         "-rpath", | ||||||
|         "@loader_path/../../../../../..", |         "@loader_path/../../../..", | ||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -1450,7 +1281,6 @@ if (is_mac) { | |||||||
|  |  | ||||||
|     deps = [ |     deps = [ | ||||||
|       ":libcef_static", |       ":libcef_static", | ||||||
|       "//build/config:exe_and_shlib_deps", |  | ||||||
|     ] |     ] | ||||||
|  |  | ||||||
|     if (is_win) { |     if (is_win) { | ||||||
| @@ -1471,12 +1301,9 @@ if (is_mac) { | |||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     if (is_linux && !is_debug && use_allocator=="none") { |     if (is_linux && !is_debug && !using_sanitizer && use_allocator=="none") { | ||||||
|       # Only export necessary symbols from libcef.so. |       # Only export necessary symbols from libcef.so. | ||||||
|       # Don't do this in Debug builds because it causes the resulting |       # Don't do this in Debug builds because it causes the resulting application to crash. | ||||||
|       # application to crash. |  | ||||||
|       # Also need to do this for ASAN builds to work around |  | ||||||
|       # https://crbug.com/832808. |  | ||||||
|       ldflags = [ "-Wl,--version-script=" + |       ldflags = [ "-Wl,--version-script=" + | ||||||
|                   rebase_path("//cef/libcef_dll/libcef.lst") ] |                   rebase_path("//cef/libcef_dll/libcef.lst") ] | ||||||
|     } |     } | ||||||
| @@ -1508,7 +1335,7 @@ if (is_mac) { | |||||||
|         "--keystone=0", |         "--keystone=0", | ||||||
|         "--scm=0", |         "--scm=0", | ||||||
|         "--version", |         "--version", | ||||||
|         cef_plist_version, |         cef_version, | ||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -1549,7 +1376,7 @@ if (is_mac) { | |||||||
|       ] |       ] | ||||||
|  |  | ||||||
|       outputs = [ |       outputs = [ | ||||||
|         "{{bundle_contents_dir}}/Frameworks/{{source_file_part}}", |         "{{bundle_root_dir}}/Frameworks/{{source_file_part}}", | ||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -1559,7 +1386,7 @@ if (is_mac) { | |||||||
|       args = [ |       args = [ | ||||||
|         "--scm=1", |         "--scm=1", | ||||||
|         "--version", |         "--version", | ||||||
|         cef_plist_version, |         cef_version, | ||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -1607,13 +1434,6 @@ if (is_mac) { | |||||||
|     ] |     ] | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   bundle_data("cefclient_resources_bundle_data_extensions_set_page_color") { |  | ||||||
|     sources = gypi_paths2.cefclient_sources_resources_extensions_set_page_color |  | ||||||
|     outputs = [ |  | ||||||
|       "{{bundle_resources_dir}}/extensions/set_page_color/{{source_file_part}}", |  | ||||||
|     ] |  | ||||||
|   } |  | ||||||
|  |  | ||||||
|   bundle_data("cefclient_resources_bundle_data_english") { |   bundle_data("cefclient_resources_bundle_data_english") { | ||||||
|     sources = [ |     sources = [ | ||||||
|       "tests/cefclient/resources/mac/English.lproj/InfoPlist.strings", |       "tests/cefclient/resources/mac/English.lproj/InfoPlist.strings", | ||||||
| @@ -1658,7 +1478,6 @@ if (is_mac) { | |||||||
|               gypi_paths2.cefclient_sources_mac |               gypi_paths2.cefclient_sources_mac | ||||||
|     deps = [ |     deps = [ | ||||||
|       ":cefclient_resources_bundle_data", |       ":cefclient_resources_bundle_data", | ||||||
|       ":cefclient_resources_bundle_data_extensions_set_page_color", |  | ||||||
|       ":cefclient_resources_bundle_data_english", |       ":cefclient_resources_bundle_data_english", | ||||||
|       ":cefclient_xibs", |       ":cefclient_xibs", | ||||||
|       ":libcef_dll_wrapper", |       ":libcef_dll_wrapper", | ||||||
| @@ -1822,11 +1641,6 @@ if (is_mac) { | |||||||
|                 gypi_paths2.cefclient_sources_resources |                 gypi_paths2.cefclient_sources_resources | ||||||
|       outputs = [ "${root_out_dir}/cefclient_files/{{source_file_part}}" ] |       outputs = [ "${root_out_dir}/cefclient_files/{{source_file_part}}" ] | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     copy("copy_cefclient_files_extensions_set_page_color") { |  | ||||||
|       sources = gypi_paths2.cefclient_sources_resources_extensions_set_page_color |  | ||||||
|       outputs = [ "${root_out_dir}/cefclient_files/extensions/set_page_color/{{source_file_part}}" ] |  | ||||||
|     } |  | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   executable("cefclient") { |   executable("cefclient") { | ||||||
| @@ -1839,13 +1653,12 @@ if (is_mac) { | |||||||
|               gypi_paths2.cefclient_sources_browser + |               gypi_paths2.cefclient_sources_browser + | ||||||
|               gypi_paths2.cefclient_sources_common + |               gypi_paths2.cefclient_sources_common + | ||||||
|               gypi_paths2.cefclient_sources_renderer + |               gypi_paths2.cefclient_sources_renderer + | ||||||
|               gypi_paths2.cefclient_sources_resources + |               gypi_paths2.cefclient_sources_resources | ||||||
|               gypi_paths2.cefclient_sources_resources_extensions_set_page_color |  | ||||||
|  |  | ||||||
|     deps = [ |     deps = [ | ||||||
|       ":libcef", |       ":libcef", | ||||||
|       ":libcef_dll_wrapper", |       ":libcef_dll_wrapper", | ||||||
|       "//build/config:exe_and_shlib_deps", |       "//build/config/sanitizers:deps", | ||||||
|     ] |     ] | ||||||
|  |  | ||||||
|     if (is_win) { |     if (is_win) { | ||||||
| @@ -1865,16 +1678,18 @@ if (is_mac) { | |||||||
|       deps += [ |       deps += [ | ||||||
|         ":cef_sandbox", |         ":cef_sandbox", | ||||||
|         "//build/win:default_exe_manifest", |         "//build/win:default_exe_manifest", | ||||||
|  |  | ||||||
|  |         # Tool that can be used for testing crash reporting. | ||||||
|  |         "//content/shell:content_shell_crash_service", | ||||||
|       ] |       ] | ||||||
|  |  | ||||||
|       libs = [ |       libs = [ | ||||||
|         "comctl32.lib", |         "comctl32.lib", | ||||||
|  |         "shlwapi.lib", | ||||||
|  |         "rpcrt4.lib", | ||||||
|  |         "opengl32.lib", | ||||||
|         "glu32.lib", |         "glu32.lib", | ||||||
|         "imm32.lib", |         "imm32.lib", | ||||||
|         "oleacc.lib", |  | ||||||
|         "opengl32.lib", |  | ||||||
|         "rpcrt4.lib", |  | ||||||
|         "shlwapi.lib", |  | ||||||
|       ] |       ] | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -1885,7 +1700,6 @@ if (is_mac) { | |||||||
|  |  | ||||||
|       deps += [ |       deps += [ | ||||||
|         ":copy_cefclient_files", |         ":copy_cefclient_files", | ||||||
|         ":copy_cefclient_files_extensions_set_page_color", |  | ||||||
|       ] |       ] | ||||||
|  |  | ||||||
|       libs = [ |       libs = [ | ||||||
| @@ -1919,7 +1733,7 @@ if (is_mac) { | |||||||
|     deps = [ |     deps = [ | ||||||
|       ":libcef", |       ":libcef", | ||||||
|       ":libcef_dll_wrapper", |       ":libcef_dll_wrapper", | ||||||
|       "//build/config:exe_and_shlib_deps", |       "//build/config/sanitizers:deps", | ||||||
|     ] |     ] | ||||||
|  |  | ||||||
|     if (is_win) { |     if (is_win) { | ||||||
| @@ -1988,7 +1802,7 @@ if (is_mac) { | |||||||
|     deps = [ |     deps = [ | ||||||
|       ":libcef", |       ":libcef", | ||||||
|       ":libcef_dll_wrapper", |       ":libcef_dll_wrapper", | ||||||
|       "//build/config:exe_and_shlib_deps", |       "//build/config/sanitizers:deps", | ||||||
|       "//testing/gtest", |       "//testing/gtest", | ||||||
|     ] |     ] | ||||||
|  |  | ||||||
|   | |||||||
| @@ -7,5 +7,5 @@ | |||||||
| # https://bitbucket.org/chromiumembedded/cef/wiki/BranchesAndBuilding | # https://bitbucket.org/chromiumembedded/cef/wiki/BranchesAndBuilding | ||||||
|  |  | ||||||
| { | { | ||||||
|   'chromium_checkout': 'refs/tags/68.0.3440.106', |   'chromium_checkout': 'refs/tags/55.0.2883.87', | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,71 +0,0 @@ | |||||||
| # The Chromium Embedded Framework (CEF) project is built on top of the Chromium |  | ||||||
| # project source tree. When updating Chromium to a new version certain files and |  | ||||||
| # patterns should be observed for changes. If changes are detected then the CEF |  | ||||||
| # source code or patch files will likely need to be updated. |  | ||||||
| # |  | ||||||
| # Add `--log-chromium-changes` to the automate-git.py command-line to output |  | ||||||
| # the following files in the <download-dir>: |  | ||||||
| # |  | ||||||
| # * chromium_update_changes.diff |  | ||||||
| #   Files in the chromium/src directory that have changed. See the 'files' |  | ||||||
| #   section below. |  | ||||||
| # |  | ||||||
| # * chromium_update_patterns.txt |  | ||||||
| #   Files in the chromium/src directory that contain invalid/unexpected |  | ||||||
| #   patterns. See the 'patterns' section below. Failure of this step is |  | ||||||
| #   considered a fatal error during update. |  | ||||||
| # |  | ||||||
| # * chromium_update_patches.txt |  | ||||||
| #   Output from attempting to update existing Chromium patch files using the |  | ||||||
| #   patch_updater.py tool. Failure of this step is considered a fatal error |  | ||||||
| #   during update. |  | ||||||
| # |  | ||||||
| # For complete update instructions see: |  | ||||||
| # https://bitbucket.org/chromiumembedded/cef/wiki/ChromiumUpdate.md |  | ||||||
|  |  | ||||||
| { |  | ||||||
|   # Files in the chromium/src directory that should be evaluated for changes. |  | ||||||
|   # Similar changes may need to be applied to the CEF source code. |  | ||||||
|   'files': [ |  | ||||||
|     'chrome/browser/browser_process.h', |  | ||||||
|     'chrome/browser/extensions/api/tabs/tabs_api.*', |  | ||||||
|     'chrome/browser/extensions/chrome_component_extension_resource_manager.*', |  | ||||||
|     'chrome/browser/extensions/chrome_extension_web_contents_observer.*', |  | ||||||
|     'chrome/browser/extensions/component_loader.*', |  | ||||||
|     'chrome/browser/extensions/extension_service.*', |  | ||||||
|     'chrome/browser/printing/print_view_manager*', |  | ||||||
|     'chrome/browser/printing/printing_message_filter*', |  | ||||||
|     'chrome/browser/profiles/profile.h', |  | ||||||
|     'chrome/browser/renderer_host/chrome_resource_dispatcher_host_delegate.*', |  | ||||||
|     'chrome/common/extensions/api/*_features.json', |  | ||||||
|     'chrome/renderer/chrome_content_renderer_client.*', |  | ||||||
|     'chrome/renderer/extensions/chrome_extensions_renderer_client.*', |  | ||||||
|     'content/browser/renderer_host/render_widget_host_view_base.*', |  | ||||||
|     'content/public/browser/render_widget_host_view.h', |  | ||||||
|     'content/public/browser/storage_partition.h', |  | ||||||
|     'content/public/browser/web_contents_delegate.h', |  | ||||||
|     'content/shell/BUILD.gn', |  | ||||||
|     'content/shell/app/*', |  | ||||||
|     'content/shell/browser/shell_*', |  | ||||||
|     'content/shell/browser/renderer_host/shell_*', |  | ||||||
|     'content/shell/common/shell_*', |  | ||||||
|     'content/shell/gpu/shell_*', |  | ||||||
|     'content/shell/renderer/shell_*', |  | ||||||
|     'content/shell/utility/shell_*', |  | ||||||
|     'extensions/shell/*', |  | ||||||
|     'net/cookies/cookie_store.h', |  | ||||||
|   ], |  | ||||||
|   # Patterns that should not be found in the chromium/src directory after |  | ||||||
|   # applying patch files. |  | ||||||
|   'patterns': [ |  | ||||||
|     { |  | ||||||
|       # New instances of this static_cast are added to the Chromium sources with |  | ||||||
|       # some regularity. If unfixed they will result in runtime crashes. |  | ||||||
|       'pattern': 'static_cast<StoragePartitionImpl\*>(', |  | ||||||
|       'exclude_matches': '^(.+?)test(.+?):', |  | ||||||
|       'message': 'New instances in non-test files should be converted to ' +\ |  | ||||||
|                  'call StoragePartition methods.' +\ |  | ||||||
|                  '\nSee storage_partition_1973.patch.', |  | ||||||
|     }, |  | ||||||
|   ], |  | ||||||
| } |  | ||||||
| @@ -48,13 +48,13 @@ | |||||||
| #     libgtkglext1-dev  (required by the cefclient target only) | #     libgtkglext1-dev  (required by the cefclient target only) | ||||||
| # | # | ||||||
| # - Mac OS X requirements: | # - Mac OS X requirements: | ||||||
| #   Xcode 5 or newer building on Mac OS X 10.9 (Mavericks) or newer. Xcode 8.3 | #   Xcode 5 or newer building on Mac OS X 10.9 (Mavericks) or newer. Xcode 7.2 | ||||||
| #   and OS X 10.12 are recommended. The Xcode command-line tools must also be | #   and OS X 10.11 are recommended. The Xcode command-line tools must also be | ||||||
| #   installed. Only 64-bit builds are supported on OS X. | #   installed. Only 64-bit builds are supported on OS X. | ||||||
| # | # | ||||||
| # - Windows requirements: | # - Windows requirements: | ||||||
| #   Visual Studio 2010 or newer building on Windows 7 or newer. Visual Studio | #   Visual Studio 2010 or newer building on Windows 7 or newer. Visual Studio | ||||||
| #   2015 Update 3 and Windows 10 64-bit are recommended. | #   2015 Update 2 and Windows 10 64-bit are recommended. | ||||||
| # | # | ||||||
| # BUILD EXAMPLES | # BUILD EXAMPLES | ||||||
| # | # | ||||||
| @@ -199,12 +199,10 @@ add_subdirectory(${CEF_LIBCEF_DLL_WRAPPER_PATH} libcef_dll_wrapper) | |||||||
| # Include application targets. | # Include application targets. | ||||||
| # Comes from the <target>/CMakeLists.txt file in the current directory. | # Comes from the <target>/CMakeLists.txt file in the current directory. | ||||||
| # TODO: Change these lines to match your project target when you copy this file. | # TODO: Change these lines to match your project target when you copy this file. | ||||||
| if(EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/tests") |  | ||||||
| add_subdirectory(tests/cefclient) | add_subdirectory(tests/cefclient) | ||||||
| add_subdirectory(tests/cefsimple) | add_subdirectory(tests/cefsimple) | ||||||
| add_subdirectory(tests/gtest) | add_subdirectory(tests/gtest) | ||||||
| add_subdirectory(tests/ceftests) | add_subdirectory(tests/ceftests) | ||||||
| endif() |  | ||||||
|  |  | ||||||
| # Display configuration settings. | # Display configuration settings. | ||||||
| PRINT_CEF_CONFIG() | PRINT_CEF_CONFIG() | ||||||
|   | |||||||
| @@ -42,13 +42,12 @@ The CEF project is an extension of the Chromium project. CEF maintains developme | |||||||
|  |  | ||||||
| The base CEF framework includes support for the C and C++ programming languages. Thanks to the hard work of external maintainers CEF can integrate with a number of other programming languages and frameworks. These external projects are not maintained by CEF so please contact the respective project maintainer if you have any questions or issues. | The base CEF framework includes support for the C and C++ programming languages. Thanks to the hard work of external maintainers CEF can integrate with a number of other programming languages and frameworks. These external projects are not maintained by CEF so please contact the respective project maintainer if you have any questions or issues. | ||||||
|  |  | ||||||
| * .Net (CEF3) - https://github.com/cefsharp/CefSharp | * .Net - https://github.com/chillitom/CefSharp | ||||||
| * .Net (CEF1) - https://bitbucket.org/fddima/cefglue | * .Net (CEF1) - https://bitbucket.org/fddima/cefglue | ||||||
| * .Net/Mono (CEF3) - https://bitbucket.org/xilium/xilium.cefglue | * .Net/Mono (CEF3) - https://bitbucket.org/xilium/xilium.cefglue | ||||||
| * .Net (CEF3) - https://bitbucket.org/chromiumfx/chromiumfx | * .Net (CEF3) - https://bitbucket.org/chromiumfx/chromiumfx | ||||||
| * Delphi (CEF1) - http://code.google.com/p/delphichromiumembedded/ | * Delphi (CEF1) - http://code.google.com/p/delphichromiumembedded/ | ||||||
| * Delphi (CEF3) - https://github.com/hgourvest/dcef3 | * Delphi (CEF3) - http://code.google.com/p/dcef3/ | ||||||
| * Delphi (CEF3) - https://github.com/salvadordf/CEF4Delphi |  | ||||||
| * Go - https://github.com/CzarekTomczak/cef2go | * Go - https://github.com/CzarekTomczak/cef2go | ||||||
| * Java - https://bitbucket.org/chromiumembedded/java-cef | * Java - https://bitbucket.org/chromiumembedded/java-cef | ||||||
| * Java - http://code.google.com/p/javacef/ | * Java - http://code.google.com/p/javacef/ | ||||||
|   | |||||||
							
								
								
									
										122
									
								
								cef_paths.gypi
									
									
									
									
									
								
							
							
						
						
									
										122
									
								
								cef_paths.gypi
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | |||||||
| # Copyright (c) 2018 The Chromium Embedded Framework Authors. All rights | # Copyright (c) 2017 The Chromium Embedded Framework Authors. All rights | ||||||
| # reserved. Use of this source code is governed by a BSD-style license that | # reserved. Use of this source code is governed by a BSD-style license that | ||||||
| # can be found in the LICENSE file. | # can be found in the LICENSE file. | ||||||
| # | # | ||||||
| @@ -8,13 +8,10 @@ | |||||||
| # by hand. See the translator.README.txt file in the tools directory for | # by hand. See the translator.README.txt file in the tools directory for | ||||||
| # more information. | # more information. | ||||||
| # | # | ||||||
| # $hash=67bc21133e37f5361a39f25dcfe004616d467dbc$ |  | ||||||
| # |  | ||||||
|  |  | ||||||
| { | { | ||||||
|   'variables': { |   'variables': { | ||||||
|     'autogen_cpp_includes': [ |     'autogen_cpp_includes': [ | ||||||
|       'include/cef_accessibility_handler.h', |  | ||||||
|       'include/cef_app.h', |       'include/cef_app.h', | ||||||
|       'include/cef_auth_callback.h', |       'include/cef_auth_callback.h', | ||||||
|       'include/cef_browser.h', |       'include/cef_browser.h', | ||||||
| @@ -32,12 +29,12 @@ | |||||||
|       'include/cef_download_item.h', |       'include/cef_download_item.h', | ||||||
|       'include/cef_drag_data.h', |       'include/cef_drag_data.h', | ||||||
|       'include/cef_drag_handler.h', |       'include/cef_drag_handler.h', | ||||||
|       'include/cef_extension.h', |  | ||||||
|       'include/cef_extension_handler.h', |  | ||||||
|       'include/cef_file_util.h', |       'include/cef_file_util.h', | ||||||
|       'include/cef_find_handler.h', |       'include/cef_find_handler.h', | ||||||
|       'include/cef_focus_handler.h', |       'include/cef_focus_handler.h', | ||||||
|       'include/cef_frame.h', |       'include/cef_frame.h', | ||||||
|  |       'include/cef_geolocation.h', | ||||||
|  |       'include/cef_geolocation_handler.h', | ||||||
|       'include/cef_image.h', |       'include/cef_image.h', | ||||||
|       'include/cef_jsdialog_handler.h', |       'include/cef_jsdialog_handler.h', | ||||||
|       'include/cef_keyboard_handler.h', |       'include/cef_keyboard_handler.h', | ||||||
| @@ -65,7 +62,6 @@ | |||||||
|       'include/cef_response.h', |       'include/cef_response.h', | ||||||
|       'include/cef_response_filter.h', |       'include/cef_response_filter.h', | ||||||
|       'include/cef_scheme.h', |       'include/cef_scheme.h', | ||||||
|       'include/cef_server.h', |  | ||||||
|       'include/cef_ssl_info.h', |       'include/cef_ssl_info.h', | ||||||
|       'include/cef_ssl_status.h', |       'include/cef_ssl_status.h', | ||||||
|       'include/cef_stream.h', |       'include/cef_stream.h', | ||||||
| @@ -81,7 +77,6 @@ | |||||||
|       'include/cef_x509_certificate.h', |       'include/cef_x509_certificate.h', | ||||||
|       'include/cef_xml_reader.h', |       'include/cef_xml_reader.h', | ||||||
|       'include/cef_zip_reader.h', |       'include/cef_zip_reader.h', | ||||||
|       'include/test/cef_test_helpers.h', |  | ||||||
|       'include/test/cef_translator_test.h', |       'include/test/cef_translator_test.h', | ||||||
|       'include/views/cef_box_layout.h', |       'include/views/cef_box_layout.h', | ||||||
|       'include/views/cef_browser_view.h', |       'include/views/cef_browser_view.h', | ||||||
| @@ -105,7 +100,6 @@ | |||||||
|       'include/views/cef_window_delegate.h', |       'include/views/cef_window_delegate.h', | ||||||
|     ], |     ], | ||||||
|     'autogen_capi_includes': [ |     'autogen_capi_includes': [ | ||||||
|       'include/capi/cef_accessibility_handler_capi.h', |  | ||||||
|       'include/capi/cef_app_capi.h', |       'include/capi/cef_app_capi.h', | ||||||
|       'include/capi/cef_auth_callback_capi.h', |       'include/capi/cef_auth_callback_capi.h', | ||||||
|       'include/capi/cef_browser_capi.h', |       'include/capi/cef_browser_capi.h', | ||||||
| @@ -123,12 +117,12 @@ | |||||||
|       'include/capi/cef_download_item_capi.h', |       'include/capi/cef_download_item_capi.h', | ||||||
|       'include/capi/cef_drag_data_capi.h', |       'include/capi/cef_drag_data_capi.h', | ||||||
|       'include/capi/cef_drag_handler_capi.h', |       'include/capi/cef_drag_handler_capi.h', | ||||||
|       'include/capi/cef_extension_capi.h', |  | ||||||
|       'include/capi/cef_extension_handler_capi.h', |  | ||||||
|       'include/capi/cef_file_util_capi.h', |       'include/capi/cef_file_util_capi.h', | ||||||
|       'include/capi/cef_find_handler_capi.h', |       'include/capi/cef_find_handler_capi.h', | ||||||
|       'include/capi/cef_focus_handler_capi.h', |       'include/capi/cef_focus_handler_capi.h', | ||||||
|       'include/capi/cef_frame_capi.h', |       'include/capi/cef_frame_capi.h', | ||||||
|  |       'include/capi/cef_geolocation_capi.h', | ||||||
|  |       'include/capi/cef_geolocation_handler_capi.h', | ||||||
|       'include/capi/cef_image_capi.h', |       'include/capi/cef_image_capi.h', | ||||||
|       'include/capi/cef_jsdialog_handler_capi.h', |       'include/capi/cef_jsdialog_handler_capi.h', | ||||||
|       'include/capi/cef_keyboard_handler_capi.h', |       'include/capi/cef_keyboard_handler_capi.h', | ||||||
| @@ -156,7 +150,6 @@ | |||||||
|       'include/capi/cef_response_capi.h', |       'include/capi/cef_response_capi.h', | ||||||
|       'include/capi/cef_response_filter_capi.h', |       'include/capi/cef_response_filter_capi.h', | ||||||
|       'include/capi/cef_scheme_capi.h', |       'include/capi/cef_scheme_capi.h', | ||||||
|       'include/capi/cef_server_capi.h', |  | ||||||
|       'include/capi/cef_ssl_info_capi.h', |       'include/capi/cef_ssl_info_capi.h', | ||||||
|       'include/capi/cef_ssl_status_capi.h', |       'include/capi/cef_ssl_status_capi.h', | ||||||
|       'include/capi/cef_stream_capi.h', |       'include/capi/cef_stream_capi.h', | ||||||
| @@ -172,7 +165,6 @@ | |||||||
|       'include/capi/cef_x509_certificate_capi.h', |       'include/capi/cef_x509_certificate_capi.h', | ||||||
|       'include/capi/cef_xml_reader_capi.h', |       'include/capi/cef_xml_reader_capi.h', | ||||||
|       'include/capi/cef_zip_reader_capi.h', |       'include/capi/cef_zip_reader_capi.h', | ||||||
|       'include/capi/test/cef_test_helpers_capi.h', |  | ||||||
|       'include/capi/test/cef_translator_test_capi.h', |       'include/capi/test/cef_translator_test_capi.h', | ||||||
|       'include/capi/views/cef_box_layout_capi.h', |       'include/capi/views/cef_box_layout_capi.h', | ||||||
|       'include/capi/views/cef_browser_view_capi.h', |       'include/capi/views/cef_browser_view_capi.h', | ||||||
| @@ -196,8 +188,6 @@ | |||||||
|       'include/capi/views/cef_window_delegate_capi.h', |       'include/capi/views/cef_window_delegate_capi.h', | ||||||
|     ], |     ], | ||||||
|     'autogen_library_side': [ |     'autogen_library_side': [ | ||||||
|       'libcef_dll/ctocpp/accessibility_handler_ctocpp.cc', |  | ||||||
|       'libcef_dll/ctocpp/accessibility_handler_ctocpp.h', |  | ||||||
|       'libcef_dll/ctocpp/app_ctocpp.cc', |       'libcef_dll/ctocpp/app_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/app_ctocpp.h', |       'libcef_dll/ctocpp/app_ctocpp.h', | ||||||
|       'libcef_dll/cpptoc/auth_callback_cpptoc.cc', |       'libcef_dll/cpptoc/auth_callback_cpptoc.cc', | ||||||
| @@ -268,10 +258,6 @@ | |||||||
|       'libcef_dll/ctocpp/drag_handler_ctocpp.h', |       'libcef_dll/ctocpp/drag_handler_ctocpp.h', | ||||||
|       'libcef_dll/ctocpp/end_tracing_callback_ctocpp.cc', |       'libcef_dll/ctocpp/end_tracing_callback_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/end_tracing_callback_ctocpp.h', |       'libcef_dll/ctocpp/end_tracing_callback_ctocpp.h', | ||||||
|       'libcef_dll/cpptoc/extension_cpptoc.cc', |  | ||||||
|       'libcef_dll/cpptoc/extension_cpptoc.h', |  | ||||||
|       'libcef_dll/ctocpp/extension_handler_ctocpp.cc', |  | ||||||
|       'libcef_dll/ctocpp/extension_handler_ctocpp.h', |  | ||||||
|       'libcef_dll/cpptoc/file_dialog_callback_cpptoc.cc', |       'libcef_dll/cpptoc/file_dialog_callback_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/file_dialog_callback_cpptoc.h', |       'libcef_dll/cpptoc/file_dialog_callback_cpptoc.h', | ||||||
|       'libcef_dll/cpptoc/views/fill_layout_cpptoc.cc', |       'libcef_dll/cpptoc/views/fill_layout_cpptoc.cc', | ||||||
| @@ -282,8 +268,12 @@ | |||||||
|       'libcef_dll/ctocpp/focus_handler_ctocpp.h', |       'libcef_dll/ctocpp/focus_handler_ctocpp.h', | ||||||
|       'libcef_dll/cpptoc/frame_cpptoc.cc', |       'libcef_dll/cpptoc/frame_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/frame_cpptoc.h', |       'libcef_dll/cpptoc/frame_cpptoc.h', | ||||||
|       'libcef_dll/cpptoc/get_extension_resource_callback_cpptoc.cc', |       'libcef_dll/cpptoc/geolocation_callback_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/get_extension_resource_callback_cpptoc.h', |       'libcef_dll/cpptoc/geolocation_callback_cpptoc.h', | ||||||
|  |       'libcef_dll/ctocpp/geolocation_handler_ctocpp.cc', | ||||||
|  |       'libcef_dll/ctocpp/geolocation_handler_ctocpp.h', | ||||||
|  |       'libcef_dll/ctocpp/get_geolocation_callback_ctocpp.cc', | ||||||
|  |       'libcef_dll/ctocpp/get_geolocation_callback_ctocpp.h', | ||||||
|       'libcef_dll/cpptoc/image_cpptoc.cc', |       'libcef_dll/cpptoc/image_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/image_cpptoc.h', |       'libcef_dll/cpptoc/image_cpptoc.h', | ||||||
|       'libcef_dll/cpptoc/jsdialog_callback_cpptoc.cc', |       'libcef_dll/cpptoc/jsdialog_callback_cpptoc.cc', | ||||||
| @@ -306,8 +296,6 @@ | |||||||
|       'libcef_dll/cpptoc/views/menu_button_cpptoc.h', |       'libcef_dll/cpptoc/views/menu_button_cpptoc.h', | ||||||
|       'libcef_dll/ctocpp/views/menu_button_delegate_ctocpp.cc', |       'libcef_dll/ctocpp/views/menu_button_delegate_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/views/menu_button_delegate_ctocpp.h', |       'libcef_dll/ctocpp/views/menu_button_delegate_ctocpp.h', | ||||||
|       'libcef_dll/cpptoc/views/menu_button_pressed_lock_cpptoc.cc', |  | ||||||
|       'libcef_dll/cpptoc/views/menu_button_pressed_lock_cpptoc.h', |  | ||||||
|       'libcef_dll/cpptoc/menu_model_cpptoc.cc', |       'libcef_dll/cpptoc/menu_model_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/menu_model_cpptoc.h', |       'libcef_dll/cpptoc/menu_model_cpptoc.h', | ||||||
|       'libcef_dll/ctocpp/menu_model_delegate_ctocpp.cc', |       'libcef_dll/ctocpp/menu_model_delegate_ctocpp.cc', | ||||||
| @@ -382,10 +370,6 @@ | |||||||
|       'libcef_dll/cpptoc/views/scroll_view_cpptoc.h', |       'libcef_dll/cpptoc/views/scroll_view_cpptoc.h', | ||||||
|       'libcef_dll/cpptoc/select_client_certificate_callback_cpptoc.cc', |       'libcef_dll/cpptoc/select_client_certificate_callback_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/select_client_certificate_callback_cpptoc.h', |       'libcef_dll/cpptoc/select_client_certificate_callback_cpptoc.h', | ||||||
|       'libcef_dll/cpptoc/server_cpptoc.cc', |  | ||||||
|       'libcef_dll/cpptoc/server_cpptoc.h', |  | ||||||
|       'libcef_dll/ctocpp/server_handler_ctocpp.cc', |  | ||||||
|       'libcef_dll/ctocpp/server_handler_ctocpp.h', |  | ||||||
|       'libcef_dll/ctocpp/set_cookie_callback_ctocpp.cc', |       'libcef_dll/ctocpp/set_cookie_callback_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/set_cookie_callback_ctocpp.h', |       'libcef_dll/ctocpp/set_cookie_callback_ctocpp.h', | ||||||
|       'libcef_dll/cpptoc/stream_reader_cpptoc.cc', |       'libcef_dll/cpptoc/stream_reader_cpptoc.cc', | ||||||
| @@ -406,34 +390,22 @@ | |||||||
|       'libcef_dll/cpptoc/thread_cpptoc.h', |       'libcef_dll/cpptoc/thread_cpptoc.h', | ||||||
|       'libcef_dll/cpptoc/test/translator_test_cpptoc.cc', |       'libcef_dll/cpptoc/test/translator_test_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/test/translator_test_cpptoc.h', |       'libcef_dll/cpptoc/test/translator_test_cpptoc.h', | ||||||
|       'libcef_dll/ctocpp/test/translator_test_ref_ptr_client_ctocpp.cc', |       'libcef_dll/ctocpp/test/translator_test_handler_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/test/translator_test_ref_ptr_client_ctocpp.h', |       'libcef_dll/ctocpp/test/translator_test_handler_ctocpp.h', | ||||||
|       'libcef_dll/ctocpp/test/translator_test_ref_ptr_client_child_ctocpp.cc', |       'libcef_dll/ctocpp/test/translator_test_handler_child_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/test/translator_test_ref_ptr_client_child_ctocpp.h', |       'libcef_dll/ctocpp/test/translator_test_handler_child_ctocpp.h', | ||||||
|       'libcef_dll/cpptoc/test/translator_test_ref_ptr_library_cpptoc.cc', |       'libcef_dll/cpptoc/test/translator_test_object_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/test/translator_test_ref_ptr_library_cpptoc.h', |       'libcef_dll/cpptoc/test/translator_test_object_cpptoc.h', | ||||||
|       'libcef_dll/cpptoc/test/translator_test_ref_ptr_library_child_cpptoc.cc', |       'libcef_dll/cpptoc/test/translator_test_object_child_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/test/translator_test_ref_ptr_library_child_cpptoc.h', |       'libcef_dll/cpptoc/test/translator_test_object_child_cpptoc.h', | ||||||
|       'libcef_dll/cpptoc/test/translator_test_ref_ptr_library_child_child_cpptoc.cc', |       'libcef_dll/cpptoc/test/translator_test_object_child_child_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/test/translator_test_ref_ptr_library_child_child_cpptoc.h', |       'libcef_dll/cpptoc/test/translator_test_object_child_child_cpptoc.h', | ||||||
|       'libcef_dll/ctocpp/test/translator_test_scoped_client_ctocpp.cc', |  | ||||||
|       'libcef_dll/ctocpp/test/translator_test_scoped_client_ctocpp.h', |  | ||||||
|       'libcef_dll/ctocpp/test/translator_test_scoped_client_child_ctocpp.cc', |  | ||||||
|       'libcef_dll/ctocpp/test/translator_test_scoped_client_child_ctocpp.h', |  | ||||||
|       'libcef_dll/cpptoc/test/translator_test_scoped_library_cpptoc.cc', |  | ||||||
|       'libcef_dll/cpptoc/test/translator_test_scoped_library_cpptoc.h', |  | ||||||
|       'libcef_dll/cpptoc/test/translator_test_scoped_library_child_cpptoc.cc', |  | ||||||
|       'libcef_dll/cpptoc/test/translator_test_scoped_library_child_cpptoc.h', |  | ||||||
|       'libcef_dll/cpptoc/test/translator_test_scoped_library_child_child_cpptoc.cc', |  | ||||||
|       'libcef_dll/cpptoc/test/translator_test_scoped_library_child_child_cpptoc.h', |  | ||||||
|       'libcef_dll/cpptoc/urlrequest_cpptoc.cc', |       'libcef_dll/cpptoc/urlrequest_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/urlrequest_cpptoc.h', |       'libcef_dll/cpptoc/urlrequest_cpptoc.h', | ||||||
|       'libcef_dll/ctocpp/urlrequest_client_ctocpp.cc', |       'libcef_dll/ctocpp/urlrequest_client_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/urlrequest_client_ctocpp.h', |       'libcef_dll/ctocpp/urlrequest_client_ctocpp.h', | ||||||
|       'libcef_dll/ctocpp/v8accessor_ctocpp.cc', |       'libcef_dll/ctocpp/v8accessor_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/v8accessor_ctocpp.h', |       'libcef_dll/ctocpp/v8accessor_ctocpp.h', | ||||||
|       'libcef_dll/ctocpp/v8array_buffer_release_callback_ctocpp.cc', |  | ||||||
|       'libcef_dll/ctocpp/v8array_buffer_release_callback_ctocpp.h', |  | ||||||
|       'libcef_dll/cpptoc/v8context_cpptoc.cc', |       'libcef_dll/cpptoc/v8context_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/v8context_cpptoc.h', |       'libcef_dll/cpptoc/v8context_cpptoc.h', | ||||||
|       'libcef_dll/cpptoc/v8exception_cpptoc.cc', |       'libcef_dll/cpptoc/v8exception_cpptoc.cc', | ||||||
| @@ -478,8 +450,6 @@ | |||||||
|       'libcef_dll/cpptoc/zip_reader_cpptoc.h', |       'libcef_dll/cpptoc/zip_reader_cpptoc.h', | ||||||
|     ], |     ], | ||||||
|     'autogen_client_side': [ |     'autogen_client_side': [ | ||||||
|       'libcef_dll/cpptoc/accessibility_handler_cpptoc.cc', |  | ||||||
|       'libcef_dll/cpptoc/accessibility_handler_cpptoc.h', |  | ||||||
|       'libcef_dll/cpptoc/app_cpptoc.cc', |       'libcef_dll/cpptoc/app_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/app_cpptoc.h', |       'libcef_dll/cpptoc/app_cpptoc.h', | ||||||
|       'libcef_dll/ctocpp/auth_callback_ctocpp.cc', |       'libcef_dll/ctocpp/auth_callback_ctocpp.cc', | ||||||
| @@ -550,10 +520,6 @@ | |||||||
|       'libcef_dll/cpptoc/drag_handler_cpptoc.h', |       'libcef_dll/cpptoc/drag_handler_cpptoc.h', | ||||||
|       'libcef_dll/cpptoc/end_tracing_callback_cpptoc.cc', |       'libcef_dll/cpptoc/end_tracing_callback_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/end_tracing_callback_cpptoc.h', |       'libcef_dll/cpptoc/end_tracing_callback_cpptoc.h', | ||||||
|       'libcef_dll/ctocpp/extension_ctocpp.cc', |  | ||||||
|       'libcef_dll/ctocpp/extension_ctocpp.h', |  | ||||||
|       'libcef_dll/cpptoc/extension_handler_cpptoc.cc', |  | ||||||
|       'libcef_dll/cpptoc/extension_handler_cpptoc.h', |  | ||||||
|       'libcef_dll/ctocpp/file_dialog_callback_ctocpp.cc', |       'libcef_dll/ctocpp/file_dialog_callback_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/file_dialog_callback_ctocpp.h', |       'libcef_dll/ctocpp/file_dialog_callback_ctocpp.h', | ||||||
|       'libcef_dll/ctocpp/views/fill_layout_ctocpp.cc', |       'libcef_dll/ctocpp/views/fill_layout_ctocpp.cc', | ||||||
| @@ -564,8 +530,12 @@ | |||||||
|       'libcef_dll/cpptoc/focus_handler_cpptoc.h', |       'libcef_dll/cpptoc/focus_handler_cpptoc.h', | ||||||
|       'libcef_dll/ctocpp/frame_ctocpp.cc', |       'libcef_dll/ctocpp/frame_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/frame_ctocpp.h', |       'libcef_dll/ctocpp/frame_ctocpp.h', | ||||||
|       'libcef_dll/ctocpp/get_extension_resource_callback_ctocpp.cc', |       'libcef_dll/ctocpp/geolocation_callback_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/get_extension_resource_callback_ctocpp.h', |       'libcef_dll/ctocpp/geolocation_callback_ctocpp.h', | ||||||
|  |       'libcef_dll/cpptoc/geolocation_handler_cpptoc.cc', | ||||||
|  |       'libcef_dll/cpptoc/geolocation_handler_cpptoc.h', | ||||||
|  |       'libcef_dll/cpptoc/get_geolocation_callback_cpptoc.cc', | ||||||
|  |       'libcef_dll/cpptoc/get_geolocation_callback_cpptoc.h', | ||||||
|       'libcef_dll/ctocpp/image_ctocpp.cc', |       'libcef_dll/ctocpp/image_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/image_ctocpp.h', |       'libcef_dll/ctocpp/image_ctocpp.h', | ||||||
|       'libcef_dll/ctocpp/jsdialog_callback_ctocpp.cc', |       'libcef_dll/ctocpp/jsdialog_callback_ctocpp.cc', | ||||||
| @@ -588,8 +558,6 @@ | |||||||
|       'libcef_dll/ctocpp/views/menu_button_ctocpp.h', |       'libcef_dll/ctocpp/views/menu_button_ctocpp.h', | ||||||
|       'libcef_dll/cpptoc/views/menu_button_delegate_cpptoc.cc', |       'libcef_dll/cpptoc/views/menu_button_delegate_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/views/menu_button_delegate_cpptoc.h', |       'libcef_dll/cpptoc/views/menu_button_delegate_cpptoc.h', | ||||||
|       'libcef_dll/ctocpp/views/menu_button_pressed_lock_ctocpp.cc', |  | ||||||
|       'libcef_dll/ctocpp/views/menu_button_pressed_lock_ctocpp.h', |  | ||||||
|       'libcef_dll/ctocpp/menu_model_ctocpp.cc', |       'libcef_dll/ctocpp/menu_model_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/menu_model_ctocpp.h', |       'libcef_dll/ctocpp/menu_model_ctocpp.h', | ||||||
|       'libcef_dll/cpptoc/menu_model_delegate_cpptoc.cc', |       'libcef_dll/cpptoc/menu_model_delegate_cpptoc.cc', | ||||||
| @@ -664,10 +632,6 @@ | |||||||
|       'libcef_dll/ctocpp/views/scroll_view_ctocpp.h', |       'libcef_dll/ctocpp/views/scroll_view_ctocpp.h', | ||||||
|       'libcef_dll/ctocpp/select_client_certificate_callback_ctocpp.cc', |       'libcef_dll/ctocpp/select_client_certificate_callback_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/select_client_certificate_callback_ctocpp.h', |       'libcef_dll/ctocpp/select_client_certificate_callback_ctocpp.h', | ||||||
|       'libcef_dll/ctocpp/server_ctocpp.cc', |  | ||||||
|       'libcef_dll/ctocpp/server_ctocpp.h', |  | ||||||
|       'libcef_dll/cpptoc/server_handler_cpptoc.cc', |  | ||||||
|       'libcef_dll/cpptoc/server_handler_cpptoc.h', |  | ||||||
|       'libcef_dll/cpptoc/set_cookie_callback_cpptoc.cc', |       'libcef_dll/cpptoc/set_cookie_callback_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/set_cookie_callback_cpptoc.h', |       'libcef_dll/cpptoc/set_cookie_callback_cpptoc.h', | ||||||
|       'libcef_dll/ctocpp/stream_reader_ctocpp.cc', |       'libcef_dll/ctocpp/stream_reader_ctocpp.cc', | ||||||
| @@ -688,34 +652,22 @@ | |||||||
|       'libcef_dll/ctocpp/thread_ctocpp.h', |       'libcef_dll/ctocpp/thread_ctocpp.h', | ||||||
|       'libcef_dll/ctocpp/test/translator_test_ctocpp.cc', |       'libcef_dll/ctocpp/test/translator_test_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/test/translator_test_ctocpp.h', |       'libcef_dll/ctocpp/test/translator_test_ctocpp.h', | ||||||
|       'libcef_dll/cpptoc/test/translator_test_ref_ptr_client_cpptoc.cc', |       'libcef_dll/cpptoc/test/translator_test_handler_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/test/translator_test_ref_ptr_client_cpptoc.h', |       'libcef_dll/cpptoc/test/translator_test_handler_cpptoc.h', | ||||||
|       'libcef_dll/cpptoc/test/translator_test_ref_ptr_client_child_cpptoc.cc', |       'libcef_dll/cpptoc/test/translator_test_handler_child_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/test/translator_test_ref_ptr_client_child_cpptoc.h', |       'libcef_dll/cpptoc/test/translator_test_handler_child_cpptoc.h', | ||||||
|       'libcef_dll/ctocpp/test/translator_test_ref_ptr_library_ctocpp.cc', |       'libcef_dll/ctocpp/test/translator_test_object_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/test/translator_test_ref_ptr_library_ctocpp.h', |       'libcef_dll/ctocpp/test/translator_test_object_ctocpp.h', | ||||||
|       'libcef_dll/ctocpp/test/translator_test_ref_ptr_library_child_ctocpp.cc', |       'libcef_dll/ctocpp/test/translator_test_object_child_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/test/translator_test_ref_ptr_library_child_ctocpp.h', |       'libcef_dll/ctocpp/test/translator_test_object_child_ctocpp.h', | ||||||
|       'libcef_dll/ctocpp/test/translator_test_ref_ptr_library_child_child_ctocpp.cc', |       'libcef_dll/ctocpp/test/translator_test_object_child_child_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/test/translator_test_ref_ptr_library_child_child_ctocpp.h', |       'libcef_dll/ctocpp/test/translator_test_object_child_child_ctocpp.h', | ||||||
|       'libcef_dll/cpptoc/test/translator_test_scoped_client_cpptoc.cc', |  | ||||||
|       'libcef_dll/cpptoc/test/translator_test_scoped_client_cpptoc.h', |  | ||||||
|       'libcef_dll/cpptoc/test/translator_test_scoped_client_child_cpptoc.cc', |  | ||||||
|       'libcef_dll/cpptoc/test/translator_test_scoped_client_child_cpptoc.h', |  | ||||||
|       'libcef_dll/ctocpp/test/translator_test_scoped_library_ctocpp.cc', |  | ||||||
|       'libcef_dll/ctocpp/test/translator_test_scoped_library_ctocpp.h', |  | ||||||
|       'libcef_dll/ctocpp/test/translator_test_scoped_library_child_ctocpp.cc', |  | ||||||
|       'libcef_dll/ctocpp/test/translator_test_scoped_library_child_ctocpp.h', |  | ||||||
|       'libcef_dll/ctocpp/test/translator_test_scoped_library_child_child_ctocpp.cc', |  | ||||||
|       'libcef_dll/ctocpp/test/translator_test_scoped_library_child_child_ctocpp.h', |  | ||||||
|       'libcef_dll/ctocpp/urlrequest_ctocpp.cc', |       'libcef_dll/ctocpp/urlrequest_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/urlrequest_ctocpp.h', |       'libcef_dll/ctocpp/urlrequest_ctocpp.h', | ||||||
|       'libcef_dll/cpptoc/urlrequest_client_cpptoc.cc', |       'libcef_dll/cpptoc/urlrequest_client_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/urlrequest_client_cpptoc.h', |       'libcef_dll/cpptoc/urlrequest_client_cpptoc.h', | ||||||
|       'libcef_dll/cpptoc/v8accessor_cpptoc.cc', |       'libcef_dll/cpptoc/v8accessor_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/v8accessor_cpptoc.h', |       'libcef_dll/cpptoc/v8accessor_cpptoc.h', | ||||||
|       'libcef_dll/cpptoc/v8array_buffer_release_callback_cpptoc.cc', |  | ||||||
|       'libcef_dll/cpptoc/v8array_buffer_release_callback_cpptoc.h', |  | ||||||
|       'libcef_dll/ctocpp/v8context_ctocpp.cc', |       'libcef_dll/ctocpp/v8context_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/v8context_ctocpp.h', |       'libcef_dll/ctocpp/v8context_ctocpp.h', | ||||||
|       'libcef_dll/ctocpp/v8exception_ctocpp.cc', |       'libcef_dll/ctocpp/v8exception_ctocpp.cc', | ||||||
|   | |||||||
| @@ -88,17 +88,12 @@ | |||||||
|       'include/internal/cef_types_linux.h', |       'include/internal/cef_types_linux.h', | ||||||
|     ], |     ], | ||||||
|     'libcef_sources_common': [ |     'libcef_sources_common': [ | ||||||
|       'libcef_dll/cpptoc/cpptoc_ref_counted.h', |       'libcef_dll/cpptoc/cpptoc.h', | ||||||
|       'libcef_dll/cpptoc/cpptoc_scoped.h', |       'libcef_dll/ctocpp/base_ctocpp.cc', | ||||||
|       'libcef_dll/ctocpp/base_ref_counted_ctocpp.cc', |       'libcef_dll/ctocpp/base_ctocpp.h', | ||||||
|       'libcef_dll/ctocpp/base_ref_counted_ctocpp.h', |       'libcef_dll/ctocpp/ctocpp.h', | ||||||
|       'libcef_dll/ctocpp/base_scoped_ctocpp.cc', |  | ||||||
|       'libcef_dll/ctocpp/base_scoped_ctocpp.h', |  | ||||||
|       'libcef_dll/ctocpp/ctocpp_ref_counted.h', |  | ||||||
|       'libcef_dll/ctocpp/ctocpp_scoped.h', |  | ||||||
|       'libcef_dll/libcef_dll.cc', |       'libcef_dll/libcef_dll.cc', | ||||||
|       'libcef_dll/libcef_dll2.cc', |       'libcef_dll/libcef_dll2.cc', | ||||||
|       'libcef_dll/ptr_util.h', |  | ||||||
|       'libcef_dll/resource.h', |       'libcef_dll/resource.h', | ||||||
|       'libcef_dll/transfer_util.cc', |       'libcef_dll/transfer_util.cc', | ||||||
|       'libcef_dll/transfer_util.h', |       'libcef_dll/transfer_util.h', | ||||||
| @@ -119,15 +114,10 @@ | |||||||
|       'libcef_dll/base/cef_weak_ptr.cc', |       'libcef_dll/base/cef_weak_ptr.cc', | ||||||
|     ], |     ], | ||||||
|     'libcef_dll_wrapper_sources_common': [ |     'libcef_dll_wrapper_sources_common': [ | ||||||
|       'libcef_dll/cpptoc/base_ref_counted_cpptoc.cc', |       'libcef_dll/cpptoc/base_cpptoc.cc', | ||||||
|       'libcef_dll/cpptoc/base_ref_counted_cpptoc.h', |       'libcef_dll/cpptoc/base_cpptoc.h', | ||||||
|       'libcef_dll/cpptoc/base_scoped_cpptoc.cc', |       'libcef_dll/cpptoc/cpptoc.h', | ||||||
|       'libcef_dll/cpptoc/base_scoped_cpptoc.h', |       'libcef_dll/ctocpp/ctocpp.h', | ||||||
|       'libcef_dll/cpptoc/cpptoc_ref_counted.h', |  | ||||||
|       'libcef_dll/cpptoc/cpptoc_scoped.h', |  | ||||||
|       'libcef_dll/ctocpp/ctocpp_ref_counted.h', |  | ||||||
|       'libcef_dll/ctocpp/ctocpp_scoped.h', |  | ||||||
|       'libcef_dll/ptr_util.h', |  | ||||||
|       'libcef_dll/transfer_util.cc', |       'libcef_dll/transfer_util.cc', | ||||||
|       'libcef_dll/transfer_util.h', |       'libcef_dll/transfer_util.h', | ||||||
|       'libcef_dll/wrapper_types.h', |       'libcef_dll/wrapper_types.h', | ||||||
| @@ -146,10 +136,6 @@ | |||||||
|     'shared_sources_browser': [ |     'shared_sources_browser': [ | ||||||
|       'tests/shared/browser/client_app_browser.cc', |       'tests/shared/browser/client_app_browser.cc', | ||||||
|       'tests/shared/browser/client_app_browser.h', |       'tests/shared/browser/client_app_browser.h', | ||||||
|       'tests/shared/browser/extension_util.cc', |  | ||||||
|       'tests/shared/browser/extension_util.h', |  | ||||||
|       'tests/shared/browser/file_util.cc', |  | ||||||
|       'tests/shared/browser/file_util.h', |  | ||||||
|       'tests/shared/browser/geometry_util.cc', |       'tests/shared/browser/geometry_util.cc', | ||||||
|       'tests/shared/browser/geometry_util.h', |       'tests/shared/browser/geometry_util.h', | ||||||
|       'tests/shared/browser/main_message_loop.cc', |       'tests/shared/browser/main_message_loop.cc', | ||||||
| @@ -159,6 +145,8 @@ | |||||||
|       'tests/shared/browser/main_message_loop_std.cc', |       'tests/shared/browser/main_message_loop_std.cc', | ||||||
|       'tests/shared/browser/main_message_loop_std.h', |       'tests/shared/browser/main_message_loop_std.h', | ||||||
|       'tests/shared/browser/resource_util.h', |       'tests/shared/browser/resource_util.h', | ||||||
|  |       'tests/shared/browser/resource_util.cc', | ||||||
|  |       'tests/shared/browser/resource_util.h', | ||||||
|     ], |     ], | ||||||
|     'shared_sources_common': [ |     'shared_sources_common': [ | ||||||
|       'tests/shared/common/client_app.cc', |       'tests/shared/common/client_app.cc', | ||||||
| @@ -218,8 +206,6 @@ | |||||||
|       'tests/cefclient/browser/dialog_test.h', |       'tests/cefclient/browser/dialog_test.h', | ||||||
|       'tests/cefclient/browser/drm_test.cc', |       'tests/cefclient/browser/drm_test.cc', | ||||||
|       'tests/cefclient/browser/drm_test.h', |       'tests/cefclient/browser/drm_test.h', | ||||||
|       'tests/cefclient/browser/image_cache.cc', |  | ||||||
|       'tests/cefclient/browser/image_cache.h', |  | ||||||
|       'tests/cefclient/browser/main_context.cc', |       'tests/cefclient/browser/main_context.cc', | ||||||
|       'tests/cefclient/browser/main_context.h', |       'tests/cefclient/browser/main_context.h', | ||||||
|       'tests/cefclient/browser/main_context_impl.cc', |       'tests/cefclient/browser/main_context_impl.cc', | ||||||
| @@ -239,8 +225,6 @@ | |||||||
|       'tests/cefclient/browser/root_window_manager.h', |       'tests/cefclient/browser/root_window_manager.h', | ||||||
|       'tests/cefclient/browser/scheme_test.cc', |       'tests/cefclient/browser/scheme_test.cc', | ||||||
|       'tests/cefclient/browser/scheme_test.h', |       'tests/cefclient/browser/scheme_test.h', | ||||||
|       'tests/cefclient/browser/server_test.cc', |  | ||||||
|       'tests/cefclient/browser/server_test.h', |  | ||||||
|       'tests/cefclient/browser/temp_window.h', |       'tests/cefclient/browser/temp_window.h', | ||||||
|       'tests/cefclient/browser/test_runner.cc', |       'tests/cefclient/browser/test_runner.cc', | ||||||
|       'tests/cefclient/browser/test_runner.h', |       'tests/cefclient/browser/test_runner.h', | ||||||
| @@ -279,20 +263,11 @@ | |||||||
|       'tests/cefclient/resources/performance2.html', |       'tests/cefclient/resources/performance2.html', | ||||||
|       'tests/cefclient/resources/preferences.html', |       'tests/cefclient/resources/preferences.html', | ||||||
|       'tests/cefclient/resources/response_filter.html', |       'tests/cefclient/resources/response_filter.html', | ||||||
|       'tests/cefclient/resources/server.html', |  | ||||||
|       'tests/cefclient/resources/transparency.html', |       'tests/cefclient/resources/transparency.html', | ||||||
|       'tests/cefclient/resources/urlrequest.html', |       'tests/cefclient/resources/urlrequest.html', | ||||||
|       'tests/cefclient/resources/websocket.html', |  | ||||||
|       'tests/cefclient/resources/window.html', |       'tests/cefclient/resources/window.html', | ||||||
|       'tests/cefclient/resources/xmlhttprequest.html', |       'tests/cefclient/resources/xmlhttprequest.html', | ||||||
|     ], |     ], | ||||||
|     'cefclient_sources_resources_extensions_set_page_color': [ |  | ||||||
|       'tests/cefclient/resources/extensions/set_page_color/icon.png', |  | ||||||
|       'tests/cefclient/resources/extensions/set_page_color/manifest.json', |  | ||||||
|       'tests/cefclient/resources/extensions/set_page_color/popup.html', |  | ||||||
|       'tests/cefclient/resources/extensions/set_page_color/popup.js', |  | ||||||
|       'tests/cefclient/resources/extensions/set_page_color/README.md', |  | ||||||
|     ], |  | ||||||
|     'cefclient_sources_win': [ |     'cefclient_sources_win': [ | ||||||
|       'tests/cefclient/browser/browser_window_osr_win.cc', |       'tests/cefclient/browser/browser_window_osr_win.cc', | ||||||
|       'tests/cefclient/browser/browser_window_osr_win.h', |       'tests/cefclient/browser/browser_window_osr_win.h', | ||||||
| @@ -301,11 +276,6 @@ | |||||||
|       'tests/cefclient/browser/main_context_impl_win.cc', |       'tests/cefclient/browser/main_context_impl_win.cc', | ||||||
|       'tests/cefclient/browser/main_message_loop_multithreaded_win.cc', |       'tests/cefclient/browser/main_message_loop_multithreaded_win.cc', | ||||||
|       'tests/cefclient/browser/main_message_loop_multithreaded_win.h', |       'tests/cefclient/browser/main_message_loop_multithreaded_win.h', | ||||||
|       'tests/cefclient/browser/osr_accessibility_helper.cc', |  | ||||||
|       'tests/cefclient/browser/osr_accessibility_helper.h', |  | ||||||
|       'tests/cefclient/browser/osr_accessibility_node.cc', |  | ||||||
|       'tests/cefclient/browser/osr_accessibility_node.h', |  | ||||||
|       'tests/cefclient/browser/osr_accessibility_node_win.cc', |  | ||||||
|       'tests/cefclient/browser/osr_dragdrop_win.cc', |       'tests/cefclient/browser/osr_dragdrop_win.cc', | ||||||
|       'tests/cefclient/browser/osr_dragdrop_win.h', |       'tests/cefclient/browser/osr_dragdrop_win.h', | ||||||
|       'tests/cefclient/browser/osr_ime_handler_win.cc', |       'tests/cefclient/browser/osr_ime_handler_win.cc', | ||||||
| @@ -319,10 +289,6 @@ | |||||||
|       'tests/cefclient/browser/root_window_win.h', |       'tests/cefclient/browser/root_window_win.h', | ||||||
|       'tests/cefclient/browser/temp_window_win.cc', |       'tests/cefclient/browser/temp_window_win.cc', | ||||||
|       'tests/cefclient/browser/temp_window_win.h', |       'tests/cefclient/browser/temp_window_win.h', | ||||||
|       'tests/cefclient/browser/views_menu_bar.cc', |  | ||||||
|       'tests/cefclient/browser/views_menu_bar.h', |  | ||||||
|       'tests/cefclient/browser/views_style.cc', |  | ||||||
|       'tests/cefclient/browser/views_style.h', |  | ||||||
|       'tests/cefclient/browser/views_window.cc', |       'tests/cefclient/browser/views_window.cc', | ||||||
|       'tests/cefclient/browser/views_window.h', |       'tests/cefclient/browser/views_window.h', | ||||||
|       'tests/cefclient/browser/window_test_runner_views.cc', |       'tests/cefclient/browser/window_test_runner_views.cc', | ||||||
| @@ -341,11 +307,6 @@ | |||||||
|       'tests/cefclient/browser/browser_window_std_mac.h', |       'tests/cefclient/browser/browser_window_std_mac.h', | ||||||
|       'tests/cefclient/browser/browser_window_std_mac.mm', |       'tests/cefclient/browser/browser_window_std_mac.mm', | ||||||
|       'tests/cefclient/browser/main_context_impl_posix.cc', |       'tests/cefclient/browser/main_context_impl_posix.cc', | ||||||
|       'tests/cefclient/browser/osr_accessibility_helper.cc', |  | ||||||
|       'tests/cefclient/browser/osr_accessibility_helper.h', |  | ||||||
|       'tests/cefclient/browser/osr_accessibility_node.cc', |  | ||||||
|       'tests/cefclient/browser/osr_accessibility_node.h', |  | ||||||
|       'tests/cefclient/browser/osr_accessibility_node_mac.mm', |  | ||||||
|       'tests/cefclient/browser/root_window_mac.h', |       'tests/cefclient/browser/root_window_mac.h', | ||||||
|       'tests/cefclient/browser/root_window_mac.mm', |       'tests/cefclient/browser/root_window_mac.mm', | ||||||
|       'tests/cefclient/browser/temp_window_mac.h', |       'tests/cefclient/browser/temp_window_mac.h', | ||||||
| @@ -379,10 +340,6 @@ | |||||||
|       'tests/cefclient/browser/root_window_views.h', |       'tests/cefclient/browser/root_window_views.h', | ||||||
|       'tests/cefclient/browser/temp_window_x11.cc', |       'tests/cefclient/browser/temp_window_x11.cc', | ||||||
|       'tests/cefclient/browser/temp_window_x11.h', |       'tests/cefclient/browser/temp_window_x11.h', | ||||||
|       'tests/cefclient/browser/views_menu_bar.cc', |  | ||||||
|       'tests/cefclient/browser/views_menu_bar.h', |  | ||||||
|       'tests/cefclient/browser/views_style.cc', |  | ||||||
|       'tests/cefclient/browser/views_style.h', |  | ||||||
|       'tests/cefclient/browser/views_window.cc', |       'tests/cefclient/browser/views_window.cc', | ||||||
|       'tests/cefclient/browser/views_window.h', |       'tests/cefclient/browser/views_window.h', | ||||||
|       'tests/cefclient/browser/window_test_runner_gtk.cc', |       'tests/cefclient/browser/window_test_runner_gtk.cc', | ||||||
| @@ -432,15 +389,11 @@ | |||||||
|       'tests/ceftests/dom_unittest.cc', |       'tests/ceftests/dom_unittest.cc', | ||||||
|       'tests/ceftests/download_unittest.cc', |       'tests/ceftests/download_unittest.cc', | ||||||
|       'tests/ceftests/draggable_regions_unittest.cc', |       'tests/ceftests/draggable_regions_unittest.cc', | ||||||
|       'tests/ceftests/extensions/background_unittest.cc', |       'tests/ceftests/file_util.cc', | ||||||
|       'tests/ceftests/extensions/chrome_alarms_unittest.cc', |       'tests/ceftests/file_util.h', | ||||||
|       'tests/ceftests/extensions/chrome_storage_unittest.cc', |  | ||||||
|       'tests/ceftests/extensions/chrome_tabs_unittest.cc', |  | ||||||
|       'tests/ceftests/extensions/extension_test_handler.cc', |  | ||||||
|       'tests/ceftests/extensions/extension_test_handler.h', |  | ||||||
|       'tests/ceftests/extensions/view_unittest.cc', |  | ||||||
|       'tests/ceftests/file_util_unittest.cc', |       'tests/ceftests/file_util_unittest.cc', | ||||||
|       'tests/ceftests/frame_unittest.cc', |       'tests/ceftests/frame_unittest.cc', | ||||||
|  |       'tests/ceftests/geolocation_unittest.cc', | ||||||
|       'tests/ceftests/image_unittest.cc', |       'tests/ceftests/image_unittest.cc', | ||||||
|       'tests/ceftests/image_util.cc', |       'tests/ceftests/image_util.cc', | ||||||
|       'tests/ceftests/image_util.h', |       'tests/ceftests/image_util.h', | ||||||
| @@ -449,8 +402,6 @@ | |||||||
|       'tests/ceftests/message_router_unittest.cc', |       'tests/ceftests/message_router_unittest.cc', | ||||||
|       'tests/ceftests/navigation_unittest.cc', |       'tests/ceftests/navigation_unittest.cc', | ||||||
|       'tests/ceftests/os_rendering_unittest.cc', |       'tests/ceftests/os_rendering_unittest.cc', | ||||||
|       'tests/ceftests/osr_accessibility_unittest.cc', |  | ||||||
|       'tests/ceftests/osr_display_unittest.cc', |  | ||||||
|       'tests/ceftests/parser_unittest.cc', |       'tests/ceftests/parser_unittest.cc', | ||||||
|       'tests/ceftests/plugin_unittest.cc', |       'tests/ceftests/plugin_unittest.cc', | ||||||
|       'tests/ceftests/preference_unittest.cc', |       'tests/ceftests/preference_unittest.cc', | ||||||
| @@ -466,7 +417,6 @@ | |||||||
|       'tests/ceftests/run_all_unittests.cc', |       'tests/ceftests/run_all_unittests.cc', | ||||||
|       'tests/ceftests/scheme_handler_unittest.cc', |       'tests/ceftests/scheme_handler_unittest.cc', | ||||||
|       'tests/ceftests/scoped_temp_dir_unittest.cc', |       'tests/ceftests/scoped_temp_dir_unittest.cc', | ||||||
|       'tests/ceftests/server_unittest.cc', |  | ||||||
|       'tests/ceftests/stream_unittest.cc', |       'tests/ceftests/stream_unittest.cc', | ||||||
|       'tests/ceftests/stream_resource_handler_unittest.cc', |       'tests/ceftests/stream_resource_handler_unittest.cc', | ||||||
|       'tests/ceftests/string_unittest.cc', |       'tests/ceftests/string_unittest.cc', | ||||||
| @@ -514,14 +464,15 @@ | |||||||
|       'tests/ceftests/run_all_unittests_mac.mm', |       'tests/ceftests/run_all_unittests_mac.mm', | ||||||
|     ], |     ], | ||||||
|     'ceftests_sources_mac_helper': [ |     'ceftests_sources_mac_helper': [ | ||||||
|       'tests/shared/browser/file_util.cc', |       'tests/shared/browser/resource_util.cc', | ||||||
|       'tests/shared/browser/file_util.h', |  | ||||||
|       'tests/shared/browser/resource_util.h', |       'tests/shared/browser/resource_util.h', | ||||||
|       'tests/shared/browser/resource_util_mac.mm', |       'tests/shared/browser/resource_util_mac.mm', | ||||||
|       'tests/shared/browser/resource_util_posix.cc', |       'tests/shared/browser/resource_util_posix.cc', | ||||||
|       'tests/ceftests/client_app_delegates.cc', |       'tests/ceftests/client_app_delegates.cc', | ||||||
|       'tests/ceftests/cookie_unittest.cc', |       'tests/ceftests/cookie_unittest.cc', | ||||||
|       'tests/ceftests/dom_unittest.cc', |       'tests/ceftests/dom_unittest.cc', | ||||||
|  |       'tests/ceftests/file_util.cc', | ||||||
|  |       'tests/ceftests/file_util.h', | ||||||
|       'tests/ceftests/frame_unittest.cc', |       'tests/ceftests/frame_unittest.cc', | ||||||
|       'tests/ceftests/message_router_unittest.cc', |       'tests/ceftests/message_router_unittest.cc', | ||||||
|       'tests/ceftests/navigation_unittest.cc', |       'tests/ceftests/navigation_unittest.cc', | ||||||
|   | |||||||
| @@ -19,7 +19,7 @@ macro(PRINT_CEF_CONFIG) | |||||||
|   message(STATUS "Platform:                     ${CMAKE_SYSTEM_NAME}") |   message(STATUS "Platform:                     ${CMAKE_SYSTEM_NAME}") | ||||||
|   message(STATUS "Project architecture:         ${PROJECT_ARCH}") |   message(STATUS "Project architecture:         ${PROJECT_ARCH}") | ||||||
|  |  | ||||||
|   if(GEN_NINJA OR GEN_MAKEFILES) |   if(${CMAKE_GENERATOR} STREQUAL "Ninja" OR ${CMAKE_GENERATOR} STREQUAL "Unix Makefiles") | ||||||
|     message(STATUS "Build type:                   ${CMAKE_BUILD_TYPE}") |     message(STATUS "Build type:                   ${CMAKE_BUILD_TYPE}") | ||||||
|   endif() |   endif() | ||||||
|  |  | ||||||
| @@ -81,7 +81,8 @@ endmacro() | |||||||
|  |  | ||||||
| # Determine the target output directory based on platform and generator. | # Determine the target output directory based on platform and generator. | ||||||
| macro(SET_CEF_TARGET_OUT_DIR) | macro(SET_CEF_TARGET_OUT_DIR) | ||||||
|   if(GEN_NINJA OR GEN_MAKEFILES) |   if(${CMAKE_GENERATOR} STREQUAL "Ninja" OR | ||||||
|  |      ${CMAKE_GENERATOR} STREQUAL "Unix Makefiles") | ||||||
|     # By default Ninja and Make builds don't create a subdirectory named after |     # By default Ninja and Make builds don't create a subdirectory named after | ||||||
|     # the configuration. |     # the configuration. | ||||||
|     set(CEF_TARGET_OUT_DIR "${CMAKE_CURRENT_BINARY_DIR}/${CMAKE_BUILD_TYPE}") |     set(CEF_TARGET_OUT_DIR "${CMAKE_CURRENT_BINARY_DIR}/${CMAKE_BUILD_TYPE}") | ||||||
| @@ -101,19 +102,7 @@ macro(COPY_FILES target file_list source_dir target_dir) | |||||||
|     set(source_file ${source_dir}/${FILENAME}) |     set(source_file ${source_dir}/${FILENAME}) | ||||||
|     get_filename_component(target_name ${FILENAME} NAME) |     get_filename_component(target_name ${FILENAME} NAME) | ||||||
|     set(target_file ${target_dir}/${target_name}) |     set(target_file ${target_dir}/${target_name}) | ||||||
|  |     if(IS_DIRECTORY ${source_file}) | ||||||
|     string(FIND ${source_file} "$<CONFIGURATION>" _pos) |  | ||||||
|     if(NOT ${_pos} EQUAL -1) |  | ||||||
|       # Must test with an actual configuration directory. |  | ||||||
|       string(REPLACE "$<CONFIGURATION>" "Release" existing_source_file ${source_file}) |  | ||||||
|       if(NOT EXISTS ${existing_source_file}) |  | ||||||
|         string(REPLACE "$<CONFIGURATION>" "Debug" existing_source_file ${source_file}) |  | ||||||
|       endif() |  | ||||||
|     else() |  | ||||||
|       set(existing_source_file ${source_file}) |  | ||||||
|     endif() |  | ||||||
|  |  | ||||||
|     if(IS_DIRECTORY ${existing_source_file}) |  | ||||||
|       add_custom_command( |       add_custom_command( | ||||||
|         TARGET ${target} |         TARGET ${target} | ||||||
|         POST_BUILD |         POST_BUILD | ||||||
| @@ -287,17 +276,17 @@ endmacro() | |||||||
| # SET_EXECUTABLE_TARGET_PROPERTIES() instead of calling this macro directly. | # SET_EXECUTABLE_TARGET_PROPERTIES() instead of calling this macro directly. | ||||||
| macro(SET_COMMON_TARGET_PROPERTIES target) | macro(SET_COMMON_TARGET_PROPERTIES target) | ||||||
|   # Compile flags. |   # Compile flags. | ||||||
|   target_compile_options(${target} PRIVATE ${CEF_COMPILER_FLAGS} ${CEF_CXX_COMPILER_FLAGS}) |   target_compile_options(${target} PUBLIC ${CEF_COMPILER_FLAGS} ${CEF_CXX_COMPILER_FLAGS}) | ||||||
|   target_compile_options(${target} PRIVATE $<$<CONFIG:Debug>:${CEF_COMPILER_FLAGS_DEBUG} ${CEF_CXX_COMPILER_FLAGS_DEBUG}>) |   target_compile_options(${target} PUBLIC $<$<CONFIG:Debug>:${CEF_COMPILER_FLAGS_DEBUG} ${CEF_CXX_COMPILER_FLAGS_DEBUG}>) | ||||||
|   target_compile_options(${target} PRIVATE $<$<CONFIG:Release>:${CEF_COMPILER_FLAGS_RELEASE} ${CEF_CXX_COMPILER_FLAGS_RELEASE}>) |   target_compile_options(${target} PUBLIC $<$<CONFIG:Release>:${CEF_COMPILER_FLAGS_RELEASE} ${CEF_CXX_COMPILER_FLAGS_RELEASE}>) | ||||||
|  |  | ||||||
|   # Compile definitions. |   # Compile definitions. | ||||||
|   target_compile_definitions(${target} PRIVATE ${CEF_COMPILER_DEFINES}) |   target_compile_definitions(${target} PUBLIC ${CEF_COMPILER_DEFINES}) | ||||||
|   target_compile_definitions(${target} PRIVATE $<$<CONFIG:Debug>:${CEF_COMPILER_DEFINES_DEBUG}>) |   target_compile_definitions(${target} PUBLIC $<$<CONFIG:Debug>:${CEF_COMPILER_DEFINES_DEBUG}>) | ||||||
|   target_compile_definitions(${target} PRIVATE $<$<CONFIG:Release>:${CEF_COMPILER_DEFINES_RELEASE}>) |   target_compile_definitions(${target} PUBLIC $<$<CONFIG:Release>:${CEF_COMPILER_DEFINES_RELEASE}>) | ||||||
|  |  | ||||||
|   # Include directories. |   # Include directories. | ||||||
|   target_include_directories(${target} PRIVATE ${CEF_INCLUDE_PATH}) |   target_include_directories(${target} PUBLIC ${CEF_INCLUDE_PATH}) | ||||||
|  |  | ||||||
|   # Linker flags. |   # Linker flags. | ||||||
|   if(CEF_LINKER_FLAGS) |   if(CEF_LINKER_FLAGS) | ||||||
|   | |||||||
| @@ -37,14 +37,9 @@ if(NOT DEFINED PROJECT_ARCH) | |||||||
|   endif() |   endif() | ||||||
| endif() | endif() | ||||||
|  |  | ||||||
| if(${CMAKE_GENERATOR} STREQUAL "Ninja") |  | ||||||
|   set(GEN_NINJA 1) |  | ||||||
| elseif(${CMAKE_GENERATOR} STREQUAL "Unix Makefiles") |  | ||||||
|   set(GEN_MAKEFILES 1) |  | ||||||
| endif() |  | ||||||
|  |  | ||||||
| # Determine the build type. | # Determine the build type. | ||||||
| if(NOT CMAKE_BUILD_TYPE AND (GEN_NINJA OR GEN_MAKEFILES)) | if(NOT CMAKE_BUILD_TYPE AND | ||||||
|  |    (${CMAKE_GENERATOR} STREQUAL "Ninja" OR ${CMAKE_GENERATOR} STREQUAL "Unix Makefiles")) | ||||||
|   # CMAKE_BUILD_TYPE should be specified when using Ninja or Unix Makefiles. |   # CMAKE_BUILD_TYPE should be specified when using Ninja or Unix Makefiles. | ||||||
|   set(CMAKE_BUILD_TYPE Release) |   set(CMAKE_BUILD_TYPE Release) | ||||||
|   message(WARNING "No CMAKE_BUILD_TYPE value selected, using ${CMAKE_BUILD_TYPE}") |   message(WARNING "No CMAKE_BUILD_TYPE value selected, using ${CMAKE_BUILD_TYPE}") | ||||||
| @@ -86,8 +81,6 @@ if(OS_LINUX) | |||||||
|     -Werror                         # Treat warnings as errors |     -Werror                         # Treat warnings as errors | ||||||
|     -Wno-missing-field-initializers # Don't warn about missing field initializers |     -Wno-missing-field-initializers # Don't warn about missing field initializers | ||||||
|     -Wno-unused-parameter           # Don't warn about unused parameters |     -Wno-unused-parameter           # Don't warn about unused parameters | ||||||
|     -Wno-error=comment              # Don't warn about code in comments |  | ||||||
|     -Wno-comment                    # Don't warn about code in comments |  | ||||||
|     ) |     ) | ||||||
|   list(APPEND CEF_C_COMPILER_FLAGS |   list(APPEND CEF_C_COMPILER_FLAGS | ||||||
|     -std=c99                        # Use the C99 language standard |     -std=c99                        # Use the C99 language standard | ||||||
| @@ -199,12 +192,8 @@ if(OS_LINUX) | |||||||
|   set(CEF_BINARY_FILES |   set(CEF_BINARY_FILES | ||||||
|     chrome-sandbox |     chrome-sandbox | ||||||
|     libcef.so |     libcef.so | ||||||
|     libEGL.so |  | ||||||
|     libGLESv2.so |  | ||||||
|     natives_blob.bin |     natives_blob.bin | ||||||
|     snapshot_blob.bin |     snapshot_blob.bin | ||||||
|     v8_context_snapshot.bin |  | ||||||
|     swiftshader |  | ||||||
|     ) |     ) | ||||||
|  |  | ||||||
|   # List of CEF resource files. |   # List of CEF resource files. | ||||||
| @@ -226,7 +215,7 @@ endif() | |||||||
|  |  | ||||||
| if(OS_MACOSX) | if(OS_MACOSX) | ||||||
|   # Platform-specific compiler/linker flags. |   # Platform-specific compiler/linker flags. | ||||||
|   # See also Xcode target properties in cef_macros.cmake. |   # See also Xcode target properties in macros.cmake. | ||||||
|   set(CEF_LIBTYPE SHARED) |   set(CEF_LIBTYPE SHARED) | ||||||
|   list(APPEND CEF_COMPILER_FLAGS |   list(APPEND CEF_COMPILER_FLAGS | ||||||
|     -fno-strict-aliasing            # Avoid assumptions regarding non-aliasing of objects of different types |     -fno-strict-aliasing            # Avoid assumptions regarding non-aliasing of objects of different types | ||||||
| @@ -270,15 +259,6 @@ if(OS_MACOSX) | |||||||
|     -Wl,-dead_strip                 # Strip dead code |     -Wl,-dead_strip                 # Strip dead code | ||||||
|     ) |     ) | ||||||
|  |  | ||||||
|   include(CheckCXXCompilerFlag) |  | ||||||
|  |  | ||||||
|   CHECK_CXX_COMPILER_FLAG(-Wno-undefined-var-template COMPILER_SUPPORTS_NO_UNDEFINED_VAR_TEMPLATE) |  | ||||||
|   if(COMPILER_SUPPORTS_NO_UNDEFINED_VAR_TEMPLATE) |  | ||||||
|     list(APPEND CEF_CXX_COMPILER_FLAGS |  | ||||||
|       -Wno-undefined-var-template   # Don't warn about potentially uninstantiated static members |  | ||||||
|       ) |  | ||||||
|   endif() |  | ||||||
|  |  | ||||||
|   # Standard libraries. |   # Standard libraries. | ||||||
|   set(CEF_STANDARD_LIBS |   set(CEF_STANDARD_LIBS | ||||||
|     -lpthread |     -lpthread | ||||||
| @@ -288,7 +268,7 @@ if(OS_MACOSX) | |||||||
|  |  | ||||||
|   # Find the newest available base SDK. |   # Find the newest available base SDK. | ||||||
|   execute_process(COMMAND xcode-select --print-path OUTPUT_VARIABLE XCODE_PATH OUTPUT_STRIP_TRAILING_WHITESPACE) |   execute_process(COMMAND xcode-select --print-path OUTPUT_VARIABLE XCODE_PATH OUTPUT_STRIP_TRAILING_WHITESPACE) | ||||||
|   foreach(OS_VERSION 10.11 10.10 10.9) |   foreach(OS_VERSION 10.10 10.9 10.8 10.7) | ||||||
|     set(SDK "${XCODE_PATH}/Platforms/MacOSX.platform/Developer/SDKs/MacOSX${OS_VERSION}.sdk") |     set(SDK "${XCODE_PATH}/Platforms/MacOSX.platform/Developer/SDKs/MacOSX${OS_VERSION}.sdk") | ||||||
|     if(NOT "${CMAKE_OSX_SYSROOT}" AND EXISTS "${SDK}" AND IS_DIRECTORY "${SDK}") |     if(NOT "${CMAKE_OSX_SYSROOT}" AND EXISTS "${SDK}" AND IS_DIRECTORY "${SDK}") | ||||||
|       set(CMAKE_OSX_SYSROOT ${SDK}) |       set(CMAKE_OSX_SYSROOT ${SDK}) | ||||||
| @@ -296,7 +276,7 @@ if(OS_MACOSX) | |||||||
|   endforeach() |   endforeach() | ||||||
|  |  | ||||||
|   # Target SDK. |   # Target SDK. | ||||||
|   set(CEF_TARGET_SDK               "10.9") |   set(CEF_TARGET_SDK               "10.7") | ||||||
|   list(APPEND CEF_COMPILER_FLAGS |   list(APPEND CEF_COMPILER_FLAGS | ||||||
|     -mmacosx-version-min=${CEF_TARGET_SDK} |     -mmacosx-version-min=${CEF_TARGET_SDK} | ||||||
|   ) |   ) | ||||||
| @@ -325,45 +305,27 @@ endif() | |||||||
| # | # | ||||||
|  |  | ||||||
| if(OS_WINDOWS) | if(OS_WINDOWS) | ||||||
|   if (GEN_NINJA) |  | ||||||
|     # When using the Ninja generator clear the CMake defaults to avoid excessive |  | ||||||
|     # console warnings (see issue #2120). |  | ||||||
|     set(CMAKE_CXX_FLAGS "") |  | ||||||
|     set(CMAKE_CXX_FLAGS_DEBUG "") |  | ||||||
|     set(CMAKE_CXX_FLAGS_RELEASE "") |  | ||||||
|   endif() |  | ||||||
|  |  | ||||||
|   # 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) |   if(USE_SANDBOX AND NOT MSVC_VERSION EQUAL 1900) | ||||||
|     # Check if the current MSVC version is compatible with the cef_sandbox.lib |     # The cef_sandbox.lib static library is currently built with VS2015. It will | ||||||
|     # static library. For a list of all version numbers see |     # not link successfully with other VS versions. | ||||||
|     # https://en.wikipedia.org/wiki/Microsoft_Visual_C%2B%2B#Internal_version_numbering |  | ||||||
|     list(APPEND supported_msvc_versions |  | ||||||
|       1900  # VS2015 and updates 1, 2, & 3 |  | ||||||
|       1910  # VS2017 version 15.1 & 15.2 |  | ||||||
|       1911  # VS2017 version 15.3 & 15.4 |  | ||||||
|       1912  # VS2017 version 15.5 |  | ||||||
|       1913  # VS2017 version 15.6 |  | ||||||
|       1914  # VS2017 version 15.7 |  | ||||||
|       ) |  | ||||||
|     list(FIND supported_msvc_versions ${MSVC_VERSION} _index) |  | ||||||
|     if (${_index} EQUAL -1) |  | ||||||
|       message(WARNING "CEF sandbox is not compatible with the current MSVC version (${MSVC_VERSION})") |  | ||||||
|     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() |   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") | ||||||
|  |  | ||||||
|   # Consumers using different runtime types may want to pass different flags |  | ||||||
|   set(CEF_RUNTIME_LIBRARY_FLAG "/MT" CACHE STRING "Optional flag specifying which runtime to use") |  | ||||||
|   if (CEF_RUNTIME_LIBRARY_FLAG) |  | ||||||
|     list(APPEND CEF_COMPILER_FLAGS_DEBUG ${CEF_RUNTIME_LIBRARY_FLAG}d) |  | ||||||
|     list(APPEND CEF_COMPILER_FLAGS_RELEASE ${CEF_RUNTIME_LIBRARY_FLAG}) |  | ||||||
|   endif() |  | ||||||
|  |  | ||||||
|   # Platform-specific compiler/linker flags. |   # Platform-specific compiler/linker flags. | ||||||
|   set(CEF_LIBTYPE STATIC) |   set(CEF_LIBTYPE STATIC) | ||||||
|   list(APPEND CEF_COMPILER_FLAGS |   list(APPEND CEF_COMPILER_FLAGS | ||||||
| @@ -382,11 +344,24 @@ 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) | ||||||
|  |     # CMake adds /RTC1, /D"_DEBUG" and a few other values by default for Debug | ||||||
|  |     # builds. We can't link the sandbox with those values so clear the CMake | ||||||
|  |     # defaults here. | ||||||
|  |     set(CMAKE_CXX_FLAGS_DEBUG "") | ||||||
|  |  | ||||||
|     list(APPEND CEF_COMPILER_FLAGS_DEBUG |     list(APPEND CEF_COMPILER_FLAGS_DEBUG | ||||||
|  |       /MT           # Multithreaded release runtime | ||||||
|  |       ) | ||||||
|  |   else() | ||||||
|  |     list(APPEND CEF_COMPILER_FLAGS_DEBUG | ||||||
|  |       /MTd          # Multithreaded debug runtime | ||||||
|       /RTC1         # Disable optimizations |       /RTC1         # Disable optimizations | ||||||
|       /Od           # Enable basic run-time checks |       /Od           # Enable basic run-time checks | ||||||
|       ) |       ) | ||||||
|  |   endif() | ||||||
|   list(APPEND CEF_COMPILER_FLAGS_RELEASE |   list(APPEND CEF_COMPILER_FLAGS_RELEASE | ||||||
|  |     /MT           # Multithreaded release runtime | ||||||
|     /O2           # Optimize for maximum speed |     /O2           # Optimize for maximum speed | ||||||
|     /Ob2          # Inline any suitable function |     /Ob2          # Inline any suitable function | ||||||
|     /GF           # Enable string pooling |     /GF           # Enable string pooling | ||||||
| @@ -401,11 +376,17 @@ if(OS_WINDOWS) | |||||||
|   list(APPEND CEF_COMPILER_DEFINES |   list(APPEND CEF_COMPILER_DEFINES | ||||||
|     WIN32 _WIN32 _WINDOWS             # Windows platform |     WIN32 _WIN32 _WINDOWS             # Windows platform | ||||||
|     UNICODE _UNICODE                  # Unicode build |     UNICODE _UNICODE                  # Unicode build | ||||||
|     WINVER=0x0601 _WIN32_WINNT=0x601  # Targeting Windows 7 |     WINVER=0x0602 _WIN32_WINNT=0x602  # Targeting Windows 8 | ||||||
|     NOMINMAX                          # Use the standard's templated min/max |     NOMINMAX                          # Use the standard's templated min/max | ||||||
|     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 | ||||||
|     ) |     ) | ||||||
| @@ -438,8 +419,6 @@ if(OS_WINDOWS) | |||||||
|     libGLESv2.dll |     libGLESv2.dll | ||||||
|     natives_blob.bin |     natives_blob.bin | ||||||
|     snapshot_blob.bin |     snapshot_blob.bin | ||||||
|     v8_context_snapshot.bin |  | ||||||
|     swiftshader |  | ||||||
|     ) |     ) | ||||||
|  |  | ||||||
|   # List of CEF resource files. |   # List of CEF resource files. | ||||||
| @@ -475,26 +454,10 @@ 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 atlmfc directory if it exists. It may be at any depth inside |  | ||||||
|     # the VC directory. The cl.exe path returned by CMAKE_CXX_COMPILER may also |  | ||||||
|     # 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_NAME ${VC_DIR} NAME) |  | ||||||
|     while(NOT ${VC_DIR_NAME} STREQUAL "VC") |  | ||||||
|       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) |  | ||||||
|     endwhile() |  | ||||||
|  |  | ||||||
|     # Determine if the Visual Studio install supports ATL. |     # Determine if the Visual Studio install supports ATL. | ||||||
|     if(NOT HAS_ATLMFC) |     get_filename_component(VC_BIN_DIR ${CMAKE_CXX_COMPILER} DIRECTORY) | ||||||
|       message(WARNING "ATL is not supported by your VC installation.") |     get_filename_component(VC_DIR ${VC_BIN_DIR} DIRECTORY) | ||||||
|  |     if(NOT IS_DIRECTORY "${VC_DIR}/atlmfc") | ||||||
|       set(USE_ATL OFF) |       set(USE_ATL OFF) | ||||||
|     endif() |     endif() | ||||||
|   endif() |   endif() | ||||||
|   | |||||||
| @@ -39,49 +39,14 @@ | |||||||
| #define CEF_INCLUDE_BASE_CEF_ATOMIC_REF_COUNT_H_ | #define CEF_INCLUDE_BASE_CEF_ATOMIC_REF_COUNT_H_ | ||||||
| #pragma once | #pragma once | ||||||
|  |  | ||||||
| #if defined(USING_CHROMIUM_INCLUDES) | #if defined(BASE_ATOMIC_REF_COUNT_H_) | ||||||
|  | // Do nothing if the Chromium header has already been included. | ||||||
|  | // This can happen in cases where Chromium code is used directly by the | ||||||
|  | // client application. When using Chromium code directly always include | ||||||
|  | // the Chromium header first to avoid type conflicts. | ||||||
|  | #elif defined(USING_CHROMIUM_INCLUDES) | ||||||
| // When building CEF include the Chromium header directly. | // When building CEF include the Chromium header directly. | ||||||
| #include "base/atomic_ref_count.h" | #include "base/atomic_ref_count.h" | ||||||
|  |  | ||||||
| // Used when declaring a base::AtomicRefCount value. This is an object type with |  | ||||||
| // Chromium headers. |  | ||||||
| #define ATOMIC_DECLARATION (0) |  | ||||||
|  |  | ||||||
| // Maintaining compatibility with AtompicRefCount* functions that were removed |  | ||||||
| // from Chromium in http://crrev.com/ee96d561. |  | ||||||
| namespace base { |  | ||||||
|  |  | ||||||
| // Increment a reference count by 1. |  | ||||||
| inline void AtomicRefCountInc(volatile AtomicRefCount* ptr) { |  | ||||||
|   const_cast<AtomicRefCount*>(ptr)->Increment(); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // Decrement a reference count by 1 and return whether the result is non-zero. |  | ||||||
| // Insert barriers to ensure that state written before the reference count |  | ||||||
| // became zero will be visible to a thread that has just made the count zero. |  | ||||||
| inline bool AtomicRefCountDec(volatile AtomicRefCount* ptr) { |  | ||||||
|   return const_cast<AtomicRefCount*>(ptr)->Decrement(); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // Return whether the reference count is one.  If the reference count is used |  | ||||||
| // in the conventional way, a refrerence count of 1 implies that the current |  | ||||||
| // thread owns the reference and no other thread shares it.  This call performs |  | ||||||
| // the test for a reference count of one, and performs the memory barrier |  | ||||||
| // needed for the owning thread to act on the object, knowing that it has |  | ||||||
| // exclusive access to the object. |  | ||||||
| inline bool AtomicRefCountIsOne(volatile AtomicRefCount* ptr) { |  | ||||||
|   return const_cast<AtomicRefCount*>(ptr)->IsOne(); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| // Return whether the reference count is zero.  With conventional object |  | ||||||
| // referencing counting, the object will be destroyed, so the reference count |  | ||||||
| // should never be zero.  Hence this is generally used for a debug check. |  | ||||||
| inline bool AtomicRefCountIsZero(volatile AtomicRefCount* ptr) { |  | ||||||
|   return const_cast<AtomicRefCount*>(ptr)->IsZero(); |  | ||||||
| } |  | ||||||
|  |  | ||||||
| }  // namespace base |  | ||||||
|  |  | ||||||
| #else  // !USING_CHROMIUM_INCLUDES | #else  // !USING_CHROMIUM_INCLUDES | ||||||
| // The following is substantially similar to the Chromium implementation. | // The following is substantially similar to the Chromium implementation. | ||||||
| // If the Chromium implementation diverges the below implementation should be | // If the Chromium implementation diverges the below implementation should be | ||||||
| @@ -93,10 +58,6 @@ inline bool AtomicRefCountIsZero(volatile AtomicRefCount* ptr) { | |||||||
| #define ANNOTATE_HAPPENS_BEFORE(obj) /* empty */ | #define ANNOTATE_HAPPENS_BEFORE(obj) /* empty */ | ||||||
| #define ANNOTATE_HAPPENS_AFTER(obj) /* empty */ | #define ANNOTATE_HAPPENS_AFTER(obj) /* empty */ | ||||||
|  |  | ||||||
| // Used when declaring a base::AtomicRefCount value. This is an integer/ptr type |  | ||||||
| // with CEF headers. |  | ||||||
| #define ATOMIC_DECLARATION = 0 |  | ||||||
|  |  | ||||||
| namespace base { | namespace base { | ||||||
|  |  | ||||||
| typedef subtle::Atomic32 AtomicRefCount; | typedef subtle::Atomic32 AtomicRefCount; | ||||||
|   | |||||||
| @@ -122,7 +122,8 @@ Atomic32 NoBarrier_AtomicExchange(volatile Atomic32* ptr, Atomic32 new_value); | |||||||
| // *ptr with the increment applied.  This routine implies no memory barriers. | // *ptr with the increment applied.  This routine implies no memory barriers. | ||||||
| Atomic32 NoBarrier_AtomicIncrement(volatile Atomic32* ptr, Atomic32 increment); | Atomic32 NoBarrier_AtomicIncrement(volatile Atomic32* ptr, Atomic32 increment); | ||||||
|  |  | ||||||
| Atomic32 Barrier_AtomicIncrement(volatile Atomic32* ptr, Atomic32 increment); | Atomic32 Barrier_AtomicIncrement(volatile Atomic32* ptr, | ||||||
|  |                                  Atomic32 increment); | ||||||
|  |  | ||||||
| // These following lower-level operations are typically useful only to people | // These following lower-level operations are typically useful only to people | ||||||
| // implementing higher-level synchronization operations like spinlocks, | // implementing higher-level synchronization operations like spinlocks, | ||||||
|   | |||||||
| @@ -43,11 +43,11 @@ | |||||||
| // On Mac OS X, |long long| is used for 64-bit types for compatibility with | // On Mac OS X, |long long| is used for 64-bit types for compatibility with | ||||||
| // <inttypes.h> format macros even in the LP64 model. | // <inttypes.h> format macros even in the LP64 model. | ||||||
| #if defined(__LP64__) && !defined(OS_MACOSX) && !defined(OS_OPENBSD) | #if defined(__LP64__) && !defined(OS_MACOSX) && !defined(OS_OPENBSD) | ||||||
| typedef long int64; | typedef long                int64;  // NOLINT(runtime/int) | ||||||
| typedef unsigned long uint64; | typedef unsigned long       uint64;  // NOLINT(runtime/int) | ||||||
| #else | #else | ||||||
| typedef long long int64; | typedef long long           int64;  // NOLINT(runtime/int) | ||||||
| typedef unsigned long long uint64; | typedef unsigned long long  uint64;  // NOLINT(runtime/int) | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| // TODO: Remove these type guards.  These are to avoid conflicts with | // TODO: Remove these type guards.  These are to avoid conflicts with | ||||||
| @@ -64,16 +64,6 @@ typedef int int32; | |||||||
| typedef unsigned int       uint32; | typedef unsigned int       uint32; | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #ifndef _INT16 |  | ||||||
| #define _INT16 |  | ||||||
| typedef short int16; |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #ifndef _UINT16 |  | ||||||
| #define _UINT16 |  | ||||||
| typedef unsigned short uint16; |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| // UTF-16 character type. | // UTF-16 character type. | ||||||
| // This should be kept synchronized with base/strings/string16.h | // This should be kept synchronized with base/strings/string16.h | ||||||
| #ifndef char16 | #ifndef char16 | ||||||
|   | |||||||
| @@ -89,32 +89,34 @@ | |||||||
| namespace base { | namespace base { | ||||||
|  |  | ||||||
| template <typename Functor> | template <typename Functor> | ||||||
| base::Callback<typename cef_internal::BindState< | base::Callback< | ||||||
|  |     typename cef_internal::BindState< | ||||||
|         typename cef_internal::FunctorTraits<Functor>::RunnableType, |         typename cef_internal::FunctorTraits<Functor>::RunnableType, | ||||||
|         typename cef_internal::FunctorTraits<Functor>::RunType, |         typename cef_internal::FunctorTraits<Functor>::RunType, | ||||||
|     void()>::UnboundRunType> |         void()> | ||||||
|  |             ::UnboundRunType> | ||||||
| Bind(Functor functor) { | Bind(Functor functor) { | ||||||
|   // Typedefs for how to store and run the functor. |   // Typedefs for how to store and run the functor. | ||||||
|   typedef |   typedef typename cef_internal::FunctorTraits<Functor>::RunnableType RunnableType; | ||||||
|       typename cef_internal::FunctorTraits<Functor>::RunnableType RunnableType; |  | ||||||
|   typedef typename cef_internal::FunctorTraits<Functor>::RunType RunType; |   typedef typename cef_internal::FunctorTraits<Functor>::RunType RunType; | ||||||
|  |  | ||||||
|   typedef cef_internal::BindState<RunnableType, RunType, void()> BindState; |   typedef cef_internal::BindState<RunnableType, RunType, void()> BindState; | ||||||
|  |  | ||||||
|  |  | ||||||
|   return Callback<typename BindState::UnboundRunType>( |   return Callback<typename BindState::UnboundRunType>( | ||||||
|       new BindState(cef_internal::MakeRunnable(functor))); |       new BindState(cef_internal::MakeRunnable(functor))); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <typename Functor, typename P1> | template <typename Functor, typename P1> | ||||||
| base::Callback<typename cef_internal::BindState< | base::Callback< | ||||||
|  |     typename cef_internal::BindState< | ||||||
|         typename cef_internal::FunctorTraits<Functor>::RunnableType, |         typename cef_internal::FunctorTraits<Functor>::RunnableType, | ||||||
|         typename cef_internal::FunctorTraits<Functor>::RunType, |         typename cef_internal::FunctorTraits<Functor>::RunType, | ||||||
|     void(typename cef_internal::CallbackParamTraits<P1>::StorageType)>:: |         void(typename cef_internal::CallbackParamTraits<P1>::StorageType)> | ||||||
|                    UnboundRunType> |             ::UnboundRunType> | ||||||
| Bind(Functor functor, const P1& p1) { | Bind(Functor functor, const P1& p1) { | ||||||
|   // Typedefs for how to store and run the functor. |   // Typedefs for how to store and run the functor. | ||||||
|   typedef |   typedef typename cef_internal::FunctorTraits<Functor>::RunnableType RunnableType; | ||||||
|       typename cef_internal::FunctorTraits<Functor>::RunnableType RunnableType; |  | ||||||
|   typedef typename cef_internal::FunctorTraits<Functor>::RunType RunType; |   typedef typename cef_internal::FunctorTraits<Functor>::RunType RunType; | ||||||
|  |  | ||||||
|   // Use RunnableType::RunType instead of RunType above because our |   // Use RunnableType::RunType instead of RunType above because our | ||||||
| @@ -136,32 +138,32 @@ Bind(Functor functor, const P1& p1) { | |||||||
|   // a scoped_refptr because BindState<> itself takes care of AddRef() for |   // a scoped_refptr because BindState<> itself takes care of AddRef() for | ||||||
|   // methods. We also disallow binding of an array as the method's target |   // methods. We also disallow binding of an array as the method's target | ||||||
|   // object. |   // object. | ||||||
|   COMPILE_ASSERT(cef_internal::HasIsMethodTag<RunnableType>::value || |   COMPILE_ASSERT( | ||||||
|  |       cef_internal::HasIsMethodTag<RunnableType>::value || | ||||||
|           !cef_internal::NeedsScopedRefptrButGetsRawPtr<P1>::value, |           !cef_internal::NeedsScopedRefptrButGetsRawPtr<P1>::value, | ||||||
|       p1_is_refcounted_type_and_needs_scoped_refptr); |       p1_is_refcounted_type_and_needs_scoped_refptr); | ||||||
|   COMPILE_ASSERT(!cef_internal::HasIsMethodTag<RunnableType>::value || |   COMPILE_ASSERT(!cef_internal::HasIsMethodTag<RunnableType>::value || | ||||||
|                      !is_array<P1>::value, |                      !is_array<P1>::value, | ||||||
|                  first_bound_argument_to_method_cannot_be_array); |                  first_bound_argument_to_method_cannot_be_array); | ||||||
|   typedef cef_internal::BindState< |   typedef cef_internal::BindState<RunnableType, RunType, | ||||||
|       RunnableType, RunType, |       void(typename cef_internal::CallbackParamTraits<P1>::StorageType)> BindState; | ||||||
|       void(typename cef_internal::CallbackParamTraits<P1>::StorageType)> |  | ||||||
|       BindState; |  | ||||||
|  |  | ||||||
|   return Callback<typename BindState::UnboundRunType>( |   return Callback<typename BindState::UnboundRunType>( | ||||||
|       new BindState(cef_internal::MakeRunnable(functor), p1)); |       new BindState(cef_internal::MakeRunnable(functor), p1)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <typename Functor, typename P1, typename P2> | template <typename Functor, typename P1, typename P2> | ||||||
| base::Callback<typename cef_internal::BindState< | base::Callback< | ||||||
|  |     typename cef_internal::BindState< | ||||||
|         typename cef_internal::FunctorTraits<Functor>::RunnableType, |         typename cef_internal::FunctorTraits<Functor>::RunnableType, | ||||||
|         typename cef_internal::FunctorTraits<Functor>::RunType, |         typename cef_internal::FunctorTraits<Functor>::RunType, | ||||||
|         void(typename cef_internal::CallbackParamTraits<P1>::StorageType, |         void(typename cef_internal::CallbackParamTraits<P1>::StorageType, | ||||||
|          typename cef_internal::CallbackParamTraits<P2>::StorageType)>:: |             typename cef_internal::CallbackParamTraits<P2>::StorageType)> | ||||||
|                    UnboundRunType> |             ::UnboundRunType> | ||||||
| Bind(Functor functor, const P1& p1, const P2& p2) { | Bind(Functor functor, const P1& p1, const P2& p2) { | ||||||
|   // Typedefs for how to store and run the functor. |   // Typedefs for how to store and run the functor. | ||||||
|   typedef |   typedef typename cef_internal::FunctorTraits<Functor>::RunnableType RunnableType; | ||||||
|       typename cef_internal::FunctorTraits<Functor>::RunnableType RunnableType; |  | ||||||
|   typedef typename cef_internal::FunctorTraits<Functor>::RunType RunType; |   typedef typename cef_internal::FunctorTraits<Functor>::RunType RunType; | ||||||
|  |  | ||||||
|   // Use RunnableType::RunType instead of RunType above because our |   // Use RunnableType::RunType instead of RunType above because our | ||||||
| @@ -184,7 +186,8 @@ Bind(Functor functor, const P1& p1, const P2& p2) { | |||||||
|   // a scoped_refptr because BindState<> itself takes care of AddRef() for |   // a scoped_refptr because BindState<> itself takes care of AddRef() for | ||||||
|   // methods. We also disallow binding of an array as the method's target |   // methods. We also disallow binding of an array as the method's target | ||||||
|   // object. |   // object. | ||||||
|   COMPILE_ASSERT(cef_internal::HasIsMethodTag<RunnableType>::value || |   COMPILE_ASSERT( | ||||||
|  |       cef_internal::HasIsMethodTag<RunnableType>::value || | ||||||
|           !cef_internal::NeedsScopedRefptrButGetsRawPtr<P1>::value, |           !cef_internal::NeedsScopedRefptrButGetsRawPtr<P1>::value, | ||||||
|       p1_is_refcounted_type_and_needs_scoped_refptr); |       p1_is_refcounted_type_and_needs_scoped_refptr); | ||||||
|   COMPILE_ASSERT(!cef_internal::HasIsMethodTag<RunnableType>::value || |   COMPILE_ASSERT(!cef_internal::HasIsMethodTag<RunnableType>::value || | ||||||
| @@ -192,28 +195,27 @@ Bind(Functor functor, const P1& p1, const P2& p2) { | |||||||
|                  first_bound_argument_to_method_cannot_be_array); |                  first_bound_argument_to_method_cannot_be_array); | ||||||
|   COMPILE_ASSERT(!cef_internal::NeedsScopedRefptrButGetsRawPtr<P2>::value, |   COMPILE_ASSERT(!cef_internal::NeedsScopedRefptrButGetsRawPtr<P2>::value, | ||||||
|                  p2_is_refcounted_type_and_needs_scoped_refptr); |                  p2_is_refcounted_type_and_needs_scoped_refptr); | ||||||
|   typedef cef_internal::BindState< |   typedef cef_internal::BindState<RunnableType, RunType, | ||||||
|       RunnableType, RunType, |  | ||||||
|       void(typename cef_internal::CallbackParamTraits<P1>::StorageType, |       void(typename cef_internal::CallbackParamTraits<P1>::StorageType, | ||||||
|            typename cef_internal::CallbackParamTraits<P2>::StorageType)> |       typename cef_internal::CallbackParamTraits<P2>::StorageType)> BindState; | ||||||
|       BindState; |  | ||||||
|  |  | ||||||
|   return Callback<typename BindState::UnboundRunType>( |   return Callback<typename BindState::UnboundRunType>( | ||||||
|       new BindState(cef_internal::MakeRunnable(functor), p1, p2)); |       new BindState(cef_internal::MakeRunnable(functor), p1, p2)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <typename Functor, typename P1, typename P2, typename P3> | template <typename Functor, typename P1, typename P2, typename P3> | ||||||
| base::Callback<typename cef_internal::BindState< | base::Callback< | ||||||
|  |     typename cef_internal::BindState< | ||||||
|         typename cef_internal::FunctorTraits<Functor>::RunnableType, |         typename cef_internal::FunctorTraits<Functor>::RunnableType, | ||||||
|         typename cef_internal::FunctorTraits<Functor>::RunType, |         typename cef_internal::FunctorTraits<Functor>::RunType, | ||||||
|         void(typename cef_internal::CallbackParamTraits<P1>::StorageType, |         void(typename cef_internal::CallbackParamTraits<P1>::StorageType, | ||||||
|             typename cef_internal::CallbackParamTraits<P2>::StorageType, |             typename cef_internal::CallbackParamTraits<P2>::StorageType, | ||||||
|          typename cef_internal::CallbackParamTraits<P3>::StorageType)>:: |             typename cef_internal::CallbackParamTraits<P3>::StorageType)> | ||||||
|                    UnboundRunType> |             ::UnboundRunType> | ||||||
| Bind(Functor functor, const P1& p1, const P2& p2, const P3& p3) { | Bind(Functor functor, const P1& p1, const P2& p2, const P3& p3) { | ||||||
|   // Typedefs for how to store and run the functor. |   // Typedefs for how to store and run the functor. | ||||||
|   typedef |   typedef typename cef_internal::FunctorTraits<Functor>::RunnableType RunnableType; | ||||||
|       typename cef_internal::FunctorTraits<Functor>::RunnableType RunnableType; |  | ||||||
|   typedef typename cef_internal::FunctorTraits<Functor>::RunType RunType; |   typedef typename cef_internal::FunctorTraits<Functor>::RunType RunType; | ||||||
|  |  | ||||||
|   // Use RunnableType::RunType instead of RunType above because our |   // Use RunnableType::RunType instead of RunType above because our | ||||||
| @@ -237,7 +239,8 @@ Bind(Functor functor, const P1& p1, const P2& p2, const P3& p3) { | |||||||
|   // a scoped_refptr because BindState<> itself takes care of AddRef() for |   // a scoped_refptr because BindState<> itself takes care of AddRef() for | ||||||
|   // methods. We also disallow binding of an array as the method's target |   // methods. We also disallow binding of an array as the method's target | ||||||
|   // object. |   // object. | ||||||
|   COMPILE_ASSERT(cef_internal::HasIsMethodTag<RunnableType>::value || |   COMPILE_ASSERT( | ||||||
|  |       cef_internal::HasIsMethodTag<RunnableType>::value || | ||||||
|           !cef_internal::NeedsScopedRefptrButGetsRawPtr<P1>::value, |           !cef_internal::NeedsScopedRefptrButGetsRawPtr<P1>::value, | ||||||
|       p1_is_refcounted_type_and_needs_scoped_refptr); |       p1_is_refcounted_type_and_needs_scoped_refptr); | ||||||
|   COMPILE_ASSERT(!cef_internal::HasIsMethodTag<RunnableType>::value || |   COMPILE_ASSERT(!cef_internal::HasIsMethodTag<RunnableType>::value || | ||||||
| @@ -247,30 +250,29 @@ Bind(Functor functor, const P1& p1, const P2& p2, const P3& p3) { | |||||||
|                  p2_is_refcounted_type_and_needs_scoped_refptr); |                  p2_is_refcounted_type_and_needs_scoped_refptr); | ||||||
|   COMPILE_ASSERT(!cef_internal::NeedsScopedRefptrButGetsRawPtr<P3>::value, |   COMPILE_ASSERT(!cef_internal::NeedsScopedRefptrButGetsRawPtr<P3>::value, | ||||||
|                  p3_is_refcounted_type_and_needs_scoped_refptr); |                  p3_is_refcounted_type_and_needs_scoped_refptr); | ||||||
|   typedef cef_internal::BindState< |   typedef cef_internal::BindState<RunnableType, RunType, | ||||||
|       RunnableType, RunType, |  | ||||||
|       void(typename cef_internal::CallbackParamTraits<P1>::StorageType, |       void(typename cef_internal::CallbackParamTraits<P1>::StorageType, | ||||||
|       typename cef_internal::CallbackParamTraits<P2>::StorageType, |       typename cef_internal::CallbackParamTraits<P2>::StorageType, | ||||||
|            typename cef_internal::CallbackParamTraits<P3>::StorageType)> |       typename cef_internal::CallbackParamTraits<P3>::StorageType)> BindState; | ||||||
|       BindState; |  | ||||||
|  |  | ||||||
|   return Callback<typename BindState::UnboundRunType>( |   return Callback<typename BindState::UnboundRunType>( | ||||||
|       new BindState(cef_internal::MakeRunnable(functor), p1, p2, p3)); |       new BindState(cef_internal::MakeRunnable(functor), p1, p2, p3)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <typename Functor, typename P1, typename P2, typename P3, typename P4> | template <typename Functor, typename P1, typename P2, typename P3, typename P4> | ||||||
| base::Callback<typename cef_internal::BindState< | base::Callback< | ||||||
|  |     typename cef_internal::BindState< | ||||||
|         typename cef_internal::FunctorTraits<Functor>::RunnableType, |         typename cef_internal::FunctorTraits<Functor>::RunnableType, | ||||||
|         typename cef_internal::FunctorTraits<Functor>::RunType, |         typename cef_internal::FunctorTraits<Functor>::RunType, | ||||||
|         void(typename cef_internal::CallbackParamTraits<P1>::StorageType, |         void(typename cef_internal::CallbackParamTraits<P1>::StorageType, | ||||||
|             typename cef_internal::CallbackParamTraits<P2>::StorageType, |             typename cef_internal::CallbackParamTraits<P2>::StorageType, | ||||||
|             typename cef_internal::CallbackParamTraits<P3>::StorageType, |             typename cef_internal::CallbackParamTraits<P3>::StorageType, | ||||||
|          typename cef_internal::CallbackParamTraits<P4>::StorageType)>:: |             typename cef_internal::CallbackParamTraits<P4>::StorageType)> | ||||||
|                    UnboundRunType> |             ::UnboundRunType> | ||||||
| Bind(Functor functor, const P1& p1, const P2& p2, const P3& p3, const P4& p4) { | Bind(Functor functor, const P1& p1, const P2& p2, const P3& p3, const P4& p4) { | ||||||
|   // Typedefs for how to store and run the functor. |   // Typedefs for how to store and run the functor. | ||||||
|   typedef |   typedef typename cef_internal::FunctorTraits<Functor>::RunnableType RunnableType; | ||||||
|       typename cef_internal::FunctorTraits<Functor>::RunnableType RunnableType; |  | ||||||
|   typedef typename cef_internal::FunctorTraits<Functor>::RunType RunType; |   typedef typename cef_internal::FunctorTraits<Functor>::RunType RunType; | ||||||
|  |  | ||||||
|   // Use RunnableType::RunType instead of RunType above because our |   // Use RunnableType::RunType instead of RunType above because our | ||||||
| @@ -295,7 +297,8 @@ Bind(Functor functor, const P1& p1, const P2& p2, const P3& p3, const P4& p4) { | |||||||
|   // a scoped_refptr because BindState<> itself takes care of AddRef() for |   // a scoped_refptr because BindState<> itself takes care of AddRef() for | ||||||
|   // methods. We also disallow binding of an array as the method's target |   // methods. We also disallow binding of an array as the method's target | ||||||
|   // object. |   // object. | ||||||
|   COMPILE_ASSERT(cef_internal::HasIsMethodTag<RunnableType>::value || |   COMPILE_ASSERT( | ||||||
|  |       cef_internal::HasIsMethodTag<RunnableType>::value || | ||||||
|           !cef_internal::NeedsScopedRefptrButGetsRawPtr<P1>::value, |           !cef_internal::NeedsScopedRefptrButGetsRawPtr<P1>::value, | ||||||
|       p1_is_refcounted_type_and_needs_scoped_refptr); |       p1_is_refcounted_type_and_needs_scoped_refptr); | ||||||
|   COMPILE_ASSERT(!cef_internal::HasIsMethodTag<RunnableType>::value || |   COMPILE_ASSERT(!cef_internal::HasIsMethodTag<RunnableType>::value || | ||||||
| @@ -307,42 +310,33 @@ Bind(Functor functor, const P1& p1, const P2& p2, const P3& p3, const P4& p4) { | |||||||
|                  p3_is_refcounted_type_and_needs_scoped_refptr); |                  p3_is_refcounted_type_and_needs_scoped_refptr); | ||||||
|   COMPILE_ASSERT(!cef_internal::NeedsScopedRefptrButGetsRawPtr<P4>::value, |   COMPILE_ASSERT(!cef_internal::NeedsScopedRefptrButGetsRawPtr<P4>::value, | ||||||
|                  p4_is_refcounted_type_and_needs_scoped_refptr); |                  p4_is_refcounted_type_and_needs_scoped_refptr); | ||||||
|   typedef cef_internal::BindState< |   typedef cef_internal::BindState<RunnableType, RunType, | ||||||
|       RunnableType, RunType, |  | ||||||
|       void(typename cef_internal::CallbackParamTraits<P1>::StorageType, |       void(typename cef_internal::CallbackParamTraits<P1>::StorageType, | ||||||
|       typename cef_internal::CallbackParamTraits<P2>::StorageType, |       typename cef_internal::CallbackParamTraits<P2>::StorageType, | ||||||
|       typename cef_internal::CallbackParamTraits<P3>::StorageType, |       typename cef_internal::CallbackParamTraits<P3>::StorageType, | ||||||
|            typename cef_internal::CallbackParamTraits<P4>::StorageType)> |       typename cef_internal::CallbackParamTraits<P4>::StorageType)> BindState; | ||||||
|       BindState; |  | ||||||
|  |  | ||||||
|   return Callback<typename BindState::UnboundRunType>( |   return Callback<typename BindState::UnboundRunType>( | ||||||
|       new BindState(cef_internal::MakeRunnable(functor), p1, p2, p3, p4)); |       new BindState(cef_internal::MakeRunnable(functor), p1, p2, p3, p4)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <typename Functor, | template <typename Functor, typename P1, typename P2, typename P3, typename P4, | ||||||
|           typename P1, |  | ||||||
|           typename P2, |  | ||||||
|           typename P3, |  | ||||||
|           typename P4, |  | ||||||
|     typename P5> |     typename P5> | ||||||
| base::Callback<typename cef_internal::BindState< | base::Callback< | ||||||
|  |     typename cef_internal::BindState< | ||||||
|         typename cef_internal::FunctorTraits<Functor>::RunnableType, |         typename cef_internal::FunctorTraits<Functor>::RunnableType, | ||||||
|         typename cef_internal::FunctorTraits<Functor>::RunType, |         typename cef_internal::FunctorTraits<Functor>::RunType, | ||||||
|         void(typename cef_internal::CallbackParamTraits<P1>::StorageType, |         void(typename cef_internal::CallbackParamTraits<P1>::StorageType, | ||||||
|             typename cef_internal::CallbackParamTraits<P2>::StorageType, |             typename cef_internal::CallbackParamTraits<P2>::StorageType, | ||||||
|             typename cef_internal::CallbackParamTraits<P3>::StorageType, |             typename cef_internal::CallbackParamTraits<P3>::StorageType, | ||||||
|             typename cef_internal::CallbackParamTraits<P4>::StorageType, |             typename cef_internal::CallbackParamTraits<P4>::StorageType, | ||||||
|          typename cef_internal::CallbackParamTraits<P5>::StorageType)>:: |             typename cef_internal::CallbackParamTraits<P5>::StorageType)> | ||||||
|                    UnboundRunType> |             ::UnboundRunType> | ||||||
| Bind(Functor functor, | Bind(Functor functor, const P1& p1, const P2& p2, const P3& p3, const P4& p4, | ||||||
|      const P1& p1, |  | ||||||
|      const P2& p2, |  | ||||||
|      const P3& p3, |  | ||||||
|      const P4& p4, |  | ||||||
|     const P5& p5) { |     const P5& p5) { | ||||||
|   // Typedefs for how to store and run the functor. |   // Typedefs for how to store and run the functor. | ||||||
|   typedef |   typedef typename cef_internal::FunctorTraits<Functor>::RunnableType RunnableType; | ||||||
|       typename cef_internal::FunctorTraits<Functor>::RunnableType RunnableType; |  | ||||||
|   typedef typename cef_internal::FunctorTraits<Functor>::RunType RunType; |   typedef typename cef_internal::FunctorTraits<Functor>::RunType RunType; | ||||||
|  |  | ||||||
|   // Use RunnableType::RunType instead of RunType above because our |   // Use RunnableType::RunType instead of RunType above because our | ||||||
| @@ -368,7 +362,8 @@ Bind(Functor functor, | |||||||
|   // a scoped_refptr because BindState<> itself takes care of AddRef() for |   // a scoped_refptr because BindState<> itself takes care of AddRef() for | ||||||
|   // methods. We also disallow binding of an array as the method's target |   // methods. We also disallow binding of an array as the method's target | ||||||
|   // object. |   // object. | ||||||
|   COMPILE_ASSERT(cef_internal::HasIsMethodTag<RunnableType>::value || |   COMPILE_ASSERT( | ||||||
|  |       cef_internal::HasIsMethodTag<RunnableType>::value || | ||||||
|           !cef_internal::NeedsScopedRefptrButGetsRawPtr<P1>::value, |           !cef_internal::NeedsScopedRefptrButGetsRawPtr<P1>::value, | ||||||
|       p1_is_refcounted_type_and_needs_scoped_refptr); |       p1_is_refcounted_type_and_needs_scoped_refptr); | ||||||
|   COMPILE_ASSERT(!cef_internal::HasIsMethodTag<RunnableType>::value || |   COMPILE_ASSERT(!cef_internal::HasIsMethodTag<RunnableType>::value || | ||||||
| @@ -382,27 +377,22 @@ Bind(Functor functor, | |||||||
|                  p4_is_refcounted_type_and_needs_scoped_refptr); |                  p4_is_refcounted_type_and_needs_scoped_refptr); | ||||||
|   COMPILE_ASSERT(!cef_internal::NeedsScopedRefptrButGetsRawPtr<P5>::value, |   COMPILE_ASSERT(!cef_internal::NeedsScopedRefptrButGetsRawPtr<P5>::value, | ||||||
|                  p5_is_refcounted_type_and_needs_scoped_refptr); |                  p5_is_refcounted_type_and_needs_scoped_refptr); | ||||||
|   typedef cef_internal::BindState< |   typedef cef_internal::BindState<RunnableType, RunType, | ||||||
|       RunnableType, RunType, |  | ||||||
|       void(typename cef_internal::CallbackParamTraits<P1>::StorageType, |       void(typename cef_internal::CallbackParamTraits<P1>::StorageType, | ||||||
|       typename cef_internal::CallbackParamTraits<P2>::StorageType, |       typename cef_internal::CallbackParamTraits<P2>::StorageType, | ||||||
|       typename cef_internal::CallbackParamTraits<P3>::StorageType, |       typename cef_internal::CallbackParamTraits<P3>::StorageType, | ||||||
|       typename cef_internal::CallbackParamTraits<P4>::StorageType, |       typename cef_internal::CallbackParamTraits<P4>::StorageType, | ||||||
|            typename cef_internal::CallbackParamTraits<P5>::StorageType)> |       typename cef_internal::CallbackParamTraits<P5>::StorageType)> BindState; | ||||||
|       BindState; |  | ||||||
|  |  | ||||||
|   return Callback<typename BindState::UnboundRunType>( |   return Callback<typename BindState::UnboundRunType>( | ||||||
|       new BindState(cef_internal::MakeRunnable(functor), p1, p2, p3, p4, p5)); |       new BindState(cef_internal::MakeRunnable(functor), p1, p2, p3, p4, p5)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <typename Functor, | template <typename Functor, typename P1, typename P2, typename P3, typename P4, | ||||||
|           typename P1, |     typename P5, typename P6> | ||||||
|           typename P2, | base::Callback< | ||||||
|           typename P3, |     typename cef_internal::BindState< | ||||||
|           typename P4, |  | ||||||
|           typename P5, |  | ||||||
|           typename P6> |  | ||||||
| base::Callback<typename cef_internal::BindState< |  | ||||||
|         typename cef_internal::FunctorTraits<Functor>::RunnableType, |         typename cef_internal::FunctorTraits<Functor>::RunnableType, | ||||||
|         typename cef_internal::FunctorTraits<Functor>::RunType, |         typename cef_internal::FunctorTraits<Functor>::RunType, | ||||||
|         void(typename cef_internal::CallbackParamTraits<P1>::StorageType, |         void(typename cef_internal::CallbackParamTraits<P1>::StorageType, | ||||||
| @@ -410,18 +400,12 @@ base::Callback<typename cef_internal::BindState< | |||||||
|             typename cef_internal::CallbackParamTraits<P3>::StorageType, |             typename cef_internal::CallbackParamTraits<P3>::StorageType, | ||||||
|             typename cef_internal::CallbackParamTraits<P4>::StorageType, |             typename cef_internal::CallbackParamTraits<P4>::StorageType, | ||||||
|             typename cef_internal::CallbackParamTraits<P5>::StorageType, |             typename cef_internal::CallbackParamTraits<P5>::StorageType, | ||||||
|          typename cef_internal::CallbackParamTraits<P6>::StorageType)>:: |             typename cef_internal::CallbackParamTraits<P6>::StorageType)> | ||||||
|                    UnboundRunType> |             ::UnboundRunType> | ||||||
| Bind(Functor functor, | Bind(Functor functor, const P1& p1, const P2& p2, const P3& p3, const P4& p4, | ||||||
|      const P1& p1, |     const P5& p5, const P6& p6) { | ||||||
|      const P2& p2, |  | ||||||
|      const P3& p3, |  | ||||||
|      const P4& p4, |  | ||||||
|      const P5& p5, |  | ||||||
|      const P6& p6) { |  | ||||||
|   // Typedefs for how to store and run the functor. |   // Typedefs for how to store and run the functor. | ||||||
|   typedef |   typedef typename cef_internal::FunctorTraits<Functor>::RunnableType RunnableType; | ||||||
|       typename cef_internal::FunctorTraits<Functor>::RunnableType RunnableType; |  | ||||||
|   typedef typename cef_internal::FunctorTraits<Functor>::RunType RunType; |   typedef typename cef_internal::FunctorTraits<Functor>::RunType RunType; | ||||||
|  |  | ||||||
|   // Use RunnableType::RunType instead of RunType above because our |   // Use RunnableType::RunType instead of RunType above because our | ||||||
| @@ -448,7 +432,8 @@ Bind(Functor functor, | |||||||
|   // a scoped_refptr because BindState<> itself takes care of AddRef() for |   // a scoped_refptr because BindState<> itself takes care of AddRef() for | ||||||
|   // methods. We also disallow binding of an array as the method's target |   // methods. We also disallow binding of an array as the method's target | ||||||
|   // object. |   // object. | ||||||
|   COMPILE_ASSERT(cef_internal::HasIsMethodTag<RunnableType>::value || |   COMPILE_ASSERT( | ||||||
|  |       cef_internal::HasIsMethodTag<RunnableType>::value || | ||||||
|           !cef_internal::NeedsScopedRefptrButGetsRawPtr<P1>::value, |           !cef_internal::NeedsScopedRefptrButGetsRawPtr<P1>::value, | ||||||
|       p1_is_refcounted_type_and_needs_scoped_refptr); |       p1_is_refcounted_type_and_needs_scoped_refptr); | ||||||
|   COMPILE_ASSERT(!cef_internal::HasIsMethodTag<RunnableType>::value || |   COMPILE_ASSERT(!cef_internal::HasIsMethodTag<RunnableType>::value || | ||||||
| @@ -464,29 +449,23 @@ Bind(Functor functor, | |||||||
|                  p5_is_refcounted_type_and_needs_scoped_refptr); |                  p5_is_refcounted_type_and_needs_scoped_refptr); | ||||||
|   COMPILE_ASSERT(!cef_internal::NeedsScopedRefptrButGetsRawPtr<P6>::value, |   COMPILE_ASSERT(!cef_internal::NeedsScopedRefptrButGetsRawPtr<P6>::value, | ||||||
|                  p6_is_refcounted_type_and_needs_scoped_refptr); |                  p6_is_refcounted_type_and_needs_scoped_refptr); | ||||||
|   typedef cef_internal::BindState< |   typedef cef_internal::BindState<RunnableType, RunType, | ||||||
|       RunnableType, RunType, |  | ||||||
|       void(typename cef_internal::CallbackParamTraits<P1>::StorageType, |       void(typename cef_internal::CallbackParamTraits<P1>::StorageType, | ||||||
|       typename cef_internal::CallbackParamTraits<P2>::StorageType, |       typename cef_internal::CallbackParamTraits<P2>::StorageType, | ||||||
|       typename cef_internal::CallbackParamTraits<P3>::StorageType, |       typename cef_internal::CallbackParamTraits<P3>::StorageType, | ||||||
|       typename cef_internal::CallbackParamTraits<P4>::StorageType, |       typename cef_internal::CallbackParamTraits<P4>::StorageType, | ||||||
|       typename cef_internal::CallbackParamTraits<P5>::StorageType, |       typename cef_internal::CallbackParamTraits<P5>::StorageType, | ||||||
|            typename cef_internal::CallbackParamTraits<P6>::StorageType)> |       typename cef_internal::CallbackParamTraits<P6>::StorageType)> BindState; | ||||||
|       BindState; |  | ||||||
|  |  | ||||||
|   return Callback<typename BindState::UnboundRunType>(new BindState( |  | ||||||
|       cef_internal::MakeRunnable(functor), p1, p2, p3, p4, p5, p6)); |   return Callback<typename BindState::UnboundRunType>( | ||||||
|  |       new BindState(cef_internal::MakeRunnable(functor), p1, p2, p3, p4, p5, p6)); | ||||||
| } | } | ||||||
|  |  | ||||||
| template <typename Functor, | template <typename Functor, typename P1, typename P2, typename P3, typename P4, | ||||||
|           typename P1, |     typename P5, typename P6, typename P7> | ||||||
|           typename P2, | base::Callback< | ||||||
|           typename P3, |     typename cef_internal::BindState< | ||||||
|           typename P4, |  | ||||||
|           typename P5, |  | ||||||
|           typename P6, |  | ||||||
|           typename P7> |  | ||||||
| base::Callback<typename cef_internal::BindState< |  | ||||||
|         typename cef_internal::FunctorTraits<Functor>::RunnableType, |         typename cef_internal::FunctorTraits<Functor>::RunnableType, | ||||||
|         typename cef_internal::FunctorTraits<Functor>::RunType, |         typename cef_internal::FunctorTraits<Functor>::RunType, | ||||||
|         void(typename cef_internal::CallbackParamTraits<P1>::StorageType, |         void(typename cef_internal::CallbackParamTraits<P1>::StorageType, | ||||||
| @@ -495,19 +474,12 @@ base::Callback<typename cef_internal::BindState< | |||||||
|             typename cef_internal::CallbackParamTraits<P4>::StorageType, |             typename cef_internal::CallbackParamTraits<P4>::StorageType, | ||||||
|             typename cef_internal::CallbackParamTraits<P5>::StorageType, |             typename cef_internal::CallbackParamTraits<P5>::StorageType, | ||||||
|             typename cef_internal::CallbackParamTraits<P6>::StorageType, |             typename cef_internal::CallbackParamTraits<P6>::StorageType, | ||||||
|          typename cef_internal::CallbackParamTraits<P7>::StorageType)>:: |             typename cef_internal::CallbackParamTraits<P7>::StorageType)> | ||||||
|                    UnboundRunType> |             ::UnboundRunType> | ||||||
| Bind(Functor functor, | Bind(Functor functor, const P1& p1, const P2& p2, const P3& p3, const P4& p4, | ||||||
|      const P1& p1, |     const P5& p5, const P6& p6, const P7& p7) { | ||||||
|      const P2& p2, |  | ||||||
|      const P3& p3, |  | ||||||
|      const P4& p4, |  | ||||||
|      const P5& p5, |  | ||||||
|      const P6& p6, |  | ||||||
|      const P7& p7) { |  | ||||||
|   // Typedefs for how to store and run the functor. |   // Typedefs for how to store and run the functor. | ||||||
|   typedef |   typedef typename cef_internal::FunctorTraits<Functor>::RunnableType RunnableType; | ||||||
|       typename cef_internal::FunctorTraits<Functor>::RunnableType RunnableType; |  | ||||||
|   typedef typename cef_internal::FunctorTraits<Functor>::RunType RunType; |   typedef typename cef_internal::FunctorTraits<Functor>::RunType RunType; | ||||||
|  |  | ||||||
|   // Use RunnableType::RunType instead of RunType above because our |   // Use RunnableType::RunType instead of RunType above because our | ||||||
| @@ -535,7 +507,8 @@ Bind(Functor functor, | |||||||
|   // a scoped_refptr because BindState<> itself takes care of AddRef() for |   // a scoped_refptr because BindState<> itself takes care of AddRef() for | ||||||
|   // methods. We also disallow binding of an array as the method's target |   // methods. We also disallow binding of an array as the method's target | ||||||
|   // object. |   // object. | ||||||
|   COMPILE_ASSERT(cef_internal::HasIsMethodTag<RunnableType>::value || |   COMPILE_ASSERT( | ||||||
|  |       cef_internal::HasIsMethodTag<RunnableType>::value || | ||||||
|           !cef_internal::NeedsScopedRefptrButGetsRawPtr<P1>::value, |           !cef_internal::NeedsScopedRefptrButGetsRawPtr<P1>::value, | ||||||
|       p1_is_refcounted_type_and_needs_scoped_refptr); |       p1_is_refcounted_type_and_needs_scoped_refptr); | ||||||
|   COMPILE_ASSERT(!cef_internal::HasIsMethodTag<RunnableType>::value || |   COMPILE_ASSERT(!cef_internal::HasIsMethodTag<RunnableType>::value || | ||||||
| @@ -553,19 +526,19 @@ Bind(Functor functor, | |||||||
|                  p6_is_refcounted_type_and_needs_scoped_refptr); |                  p6_is_refcounted_type_and_needs_scoped_refptr); | ||||||
|   COMPILE_ASSERT(!cef_internal::NeedsScopedRefptrButGetsRawPtr<P7>::value, |   COMPILE_ASSERT(!cef_internal::NeedsScopedRefptrButGetsRawPtr<P7>::value, | ||||||
|                  p7_is_refcounted_type_and_needs_scoped_refptr); |                  p7_is_refcounted_type_and_needs_scoped_refptr); | ||||||
|   typedef cef_internal::BindState< |   typedef cef_internal::BindState<RunnableType, RunType, | ||||||
|       RunnableType, RunType, |  | ||||||
|       void(typename cef_internal::CallbackParamTraits<P1>::StorageType, |       void(typename cef_internal::CallbackParamTraits<P1>::StorageType, | ||||||
|       typename cef_internal::CallbackParamTraits<P2>::StorageType, |       typename cef_internal::CallbackParamTraits<P2>::StorageType, | ||||||
|       typename cef_internal::CallbackParamTraits<P3>::StorageType, |       typename cef_internal::CallbackParamTraits<P3>::StorageType, | ||||||
|       typename cef_internal::CallbackParamTraits<P4>::StorageType, |       typename cef_internal::CallbackParamTraits<P4>::StorageType, | ||||||
|       typename cef_internal::CallbackParamTraits<P5>::StorageType, |       typename cef_internal::CallbackParamTraits<P5>::StorageType, | ||||||
|       typename cef_internal::CallbackParamTraits<P6>::StorageType, |       typename cef_internal::CallbackParamTraits<P6>::StorageType, | ||||||
|            typename cef_internal::CallbackParamTraits<P7>::StorageType)> |       typename cef_internal::CallbackParamTraits<P7>::StorageType)> BindState; | ||||||
|       BindState; |  | ||||||
|  |  | ||||||
|   return Callback<typename BindState::UnboundRunType>(new BindState( |  | ||||||
|       cef_internal::MakeRunnable(functor), p1, p2, p3, p4, p5, p6, p7)); |   return Callback<typename BindState::UnboundRunType>( | ||||||
|  |       new BindState(cef_internal::MakeRunnable(functor), p1, p2, p3, p4, p5, p6, | ||||||
|  |           p7)); | ||||||
| } | } | ||||||
|  |  | ||||||
| }  // namespace base | }  // namespace base | ||||||
|   | |||||||
| @@ -276,13 +276,13 @@ class SupportsAddRefAndRelease { | |||||||
| #pragma warning(push) | #pragma warning(push) | ||||||
| #pragma warning(disable:4624) | #pragma warning(disable:4624) | ||||||
| #endif | #endif | ||||||
|   struct Base : public T, public BaseMixin {}; |   struct Base : public T, public BaseMixin { | ||||||
|  |   }; | ||||||
| #if defined(OS_WIN) | #if defined(OS_WIN) | ||||||
| #pragma warning(pop) | #pragma warning(pop) | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|   template <void (BaseMixin::*)(void)> |   template <void(BaseMixin::*)(void)> struct Helper {}; | ||||||
|   struct Helper {}; |  | ||||||
|  |  | ||||||
|   template <typename C> |   template <typename C> | ||||||
|   static No& Check(Helper<&C::AddRef>*); |   static No& Check(Helper<&C::AddRef>*); | ||||||
| @@ -297,18 +297,22 @@ class SupportsAddRefAndRelease { | |||||||
| // Helpers to assert that arguments of a recounted type are bound with a | // Helpers to assert that arguments of a recounted type are bound with a | ||||||
| // scoped_refptr. | // scoped_refptr. | ||||||
| template <bool IsClasstype, typename T> | template <bool IsClasstype, typename T> | ||||||
| struct UnsafeBindtoRefCountedArgHelper : false_type {}; | struct UnsafeBindtoRefCountedArgHelper : false_type { | ||||||
|  | }; | ||||||
|  |  | ||||||
| template <typename T> | template <typename T> | ||||||
| struct UnsafeBindtoRefCountedArgHelper<true, T> | struct UnsafeBindtoRefCountedArgHelper<true, T> | ||||||
|     : integral_constant<bool, SupportsAddRefAndRelease<T>::value> {}; |     : integral_constant<bool, SupportsAddRefAndRelease<T>::value> { | ||||||
|  | }; | ||||||
|  |  | ||||||
| template <typename T> | template <typename T> | ||||||
| struct UnsafeBindtoRefCountedArg : false_type {}; | struct UnsafeBindtoRefCountedArg : false_type { | ||||||
|  | }; | ||||||
|  |  | ||||||
| template <typename T> | template <typename T> | ||||||
| struct UnsafeBindtoRefCountedArg<T*> | struct UnsafeBindtoRefCountedArg<T*> | ||||||
|     : UnsafeBindtoRefCountedArgHelper<is_class<T>::value, T> {}; |     : UnsafeBindtoRefCountedArgHelper<is_class<T>::value, T> { | ||||||
|  | }; | ||||||
|  |  | ||||||
| template <typename T> | template <typename T> | ||||||
| class HasIsMethodTag { | class HasIsMethodTag { | ||||||
| @@ -330,7 +334,6 @@ class UnretainedWrapper { | |||||||
|  public: |  public: | ||||||
|   explicit UnretainedWrapper(T* o) : ptr_(o) {} |   explicit UnretainedWrapper(T* o) : ptr_(o) {} | ||||||
|   T* get() const { return ptr_; } |   T* get() const { return ptr_; } | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   T* ptr_; |   T* ptr_; | ||||||
| }; | }; | ||||||
| @@ -340,7 +343,6 @@ class ConstRefWrapper { | |||||||
|  public: |  public: | ||||||
|   explicit ConstRefWrapper(const T& o) : ptr_(&o) {} |   explicit ConstRefWrapper(const T& o) : ptr_(&o) {} | ||||||
|   const T& get() const { return *ptr_; } |   const T& get() const { return *ptr_; } | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   const T* ptr_; |   const T* ptr_; | ||||||
| }; | }; | ||||||
| @@ -407,7 +409,8 @@ class PassedWrapper { | |||||||
|  public: |  public: | ||||||
|   explicit PassedWrapper(T scoper) : is_valid_(true), scoper_(scoper.Pass()) {} |   explicit PassedWrapper(T scoper) : is_valid_(true), scoper_(scoper.Pass()) {} | ||||||
|   PassedWrapper(const PassedWrapper& other) |   PassedWrapper(const PassedWrapper& other) | ||||||
|       : is_valid_(other.is_valid_), scoper_(other.scoper_.Pass()) {} |       : is_valid_(other.is_valid_), scoper_(other.scoper_.Pass()) { | ||||||
|  |   } | ||||||
|   T Pass() const { |   T Pass() const { | ||||||
|     CHECK(is_valid_); |     CHECK(is_valid_); | ||||||
|     is_valid_ = false; |     is_valid_ = false; | ||||||
| @@ -457,13 +460,17 @@ struct UnwrapTraits<WeakPtr<T>> { | |||||||
| template <typename T> | template <typename T> | ||||||
| struct UnwrapTraits<OwnedWrapper<T> > { | struct UnwrapTraits<OwnedWrapper<T> > { | ||||||
|   typedef T* ForwardType; |   typedef T* ForwardType; | ||||||
|   static ForwardType Unwrap(const OwnedWrapper<T>& o) { return o.get(); } |   static ForwardType Unwrap(const OwnedWrapper<T>& o) { | ||||||
|  |     return o.get(); | ||||||
|  |   } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <typename T> | template <typename T> | ||||||
| struct UnwrapTraits<PassedWrapper<T> > { | struct UnwrapTraits<PassedWrapper<T> > { | ||||||
|   typedef T ForwardType; |   typedef T ForwardType; | ||||||
|   static T Unwrap(PassedWrapper<T>& o) { return o.Pass(); } |   static T Unwrap(PassedWrapper<T>& o) { | ||||||
|  |     return o.Pass(); | ||||||
|  |   } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // Utility for handling different refcounting semantics in the Bind() | // Utility for handling different refcounting semantics in the Bind() | ||||||
| @@ -560,8 +567,8 @@ static inline cef_internal::IgnoreResultHelper<T> IgnoreResult(T data) { | |||||||
| } | } | ||||||
|  |  | ||||||
| template <typename T> | template <typename T> | ||||||
| static inline cef_internal::IgnoreResultHelper<Callback<T>> IgnoreResult( | static inline cef_internal::IgnoreResultHelper<Callback<T> > | ||||||
|     const Callback<T>& data) { | IgnoreResult(const Callback<T>& data) { | ||||||
|   return cef_internal::IgnoreResultHelper<Callback<T> >(data); |   return cef_internal::IgnoreResultHelper<Callback<T> >(data); | ||||||
| } | } | ||||||
|  |  | ||||||
|   | |||||||
| @@ -27,6 +27,7 @@ | |||||||
| // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||||
| // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_BASE_CEF_BUILD_H_ | #ifndef CEF_INCLUDE_BASE_CEF_BUILD_H_ | ||||||
| #define CEF_INCLUDE_BASE_CEF_BUILD_H_ | #define CEF_INCLUDE_BASE_CEF_BUILD_H_ | ||||||
| #pragma once | #pragma once | ||||||
| @@ -115,10 +116,12 @@ | |||||||
| // Type detection for wchar_t. | // Type detection for wchar_t. | ||||||
| #if defined(OS_WIN) | #if defined(OS_WIN) | ||||||
| #define WCHAR_T_IS_UTF16 | #define WCHAR_T_IS_UTF16 | ||||||
| #elif defined(OS_POSIX) && defined(COMPILER_GCC) && defined(__WCHAR_MAX__) && \ | #elif defined(OS_POSIX) && defined(COMPILER_GCC) && \ | ||||||
|  |     defined(__WCHAR_MAX__) && \ | ||||||
|     (__WCHAR_MAX__ == 0x7fffffff || __WCHAR_MAX__ == 0xffffffff) |     (__WCHAR_MAX__ == 0x7fffffff || __WCHAR_MAX__ == 0xffffffff) | ||||||
| #define WCHAR_T_IS_UTF32 | #define WCHAR_T_IS_UTF32 | ||||||
| #elif defined(OS_POSIX) && defined(COMPILER_GCC) && defined(__WCHAR_MAX__) && \ | #elif defined(OS_POSIX) && defined(COMPILER_GCC) && \ | ||||||
|  |     defined(__WCHAR_MAX__) && \ | ||||||
|     (__WCHAR_MAX__ == 0x7fff || __WCHAR_MAX__ == 0xffff) |     (__WCHAR_MAX__ == 0x7fff || __WCHAR_MAX__ == 0xffff) | ||||||
| // On Posix, we'll detect short wchar_t, but projects aren't guaranteed to | // On Posix, we'll detect short wchar_t, but projects aren't guaranteed to | ||||||
| // compile in this mode (in particular, Chrome doesn't). This is intended for | // compile in this mode (in particular, Chrome doesn't). This is intended for | ||||||
| @@ -186,12 +189,4 @@ | |||||||
| #endif | #endif | ||||||
| #endif  // OVERRIDE | #endif  // OVERRIDE | ||||||
|  |  | ||||||
| // Check for C++11 template alias support which was added in VS2013 and GCC4.7. |  | ||||||
| // http://www.open-std.org/jtc1/sc22/wg21/docs/papers/2007/n2258.pdf |  | ||||||
| #if __cplusplus > 199711L || (defined(_MSC_VER) && _MSC_VER >= 1800) || \ |  | ||||||
|     (defined(__GNUC__) &&                                               \ |  | ||||||
|      (__GNUC__ * 10000 + __GNUC_MINOR__ * 100 + __GNUC_PATCHLEVEL__ >= 40700)) |  | ||||||
| #define HAS_CPP11_TEMPLATE_ALIAS_SUPPORT |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #endif  // CEF_INCLUDE_BASE_CEF_BUILD_H_ | #endif  // CEF_INCLUDE_BASE_CEF_BUILD_H_ | ||||||
|   | |||||||
| @@ -45,9 +45,9 @@ | |||||||
| // If the Chromium implementation diverges the below implementation should be | // If the Chromium implementation diverges the below implementation should be | ||||||
| // updated to match. | // updated to match. | ||||||
|  |  | ||||||
|  | #include "include/base/internal/cef_callback_internal.h" | ||||||
| #include "include/base/cef_callback_forward.h" | #include "include/base/cef_callback_forward.h" | ||||||
| #include "include/base/cef_template_util.h" | #include "include/base/cef_template_util.h" | ||||||
| #include "include/base/internal/cef_callback_internal.h" |  | ||||||
|  |  | ||||||
| // NOTE: Header files that do not require the full definition of Callback or | // NOTE: Header files that do not require the full definition of Callback or | ||||||
| // Closure should #include "base/cef_callback_forward.h" instead of this file. | // Closure should #include "base/cef_callback_forward.h" instead of this file. | ||||||
| @@ -412,15 +412,16 @@ class Callback<R(void)> : public cef_internal::CallbackBase { | |||||||
|   // Note that this constructor CANNOT be explicit, and that Bind() CANNOT |   // Note that this constructor CANNOT be explicit, and that Bind() CANNOT | ||||||
|   // return the exact Callback<> type.  See base/bind.h for details. |   // return the exact Callback<> type.  See base/bind.h for details. | ||||||
|   template <typename Runnable, typename BindRunType, typename BoundArgsType> |   template <typename Runnable, typename BindRunType, typename BoundArgsType> | ||||||
|   Callback( |   Callback(cef_internal::BindState<Runnable, BindRunType, | ||||||
|       cef_internal::BindState<Runnable, BindRunType, BoundArgsType>* bind_state) |            BoundArgsType>* bind_state) | ||||||
|       : CallbackBase(bind_state) { |       : CallbackBase(bind_state) { | ||||||
|  |  | ||||||
|     // Force the assignment to a local variable of PolymorphicInvoke |     // Force the assignment to a local variable of PolymorphicInvoke | ||||||
|     // so the compiler will typecheck that the passed in Run() method has |     // so the compiler will typecheck that the passed in Run() method has | ||||||
|     // the correct type. |     // the correct type. | ||||||
|     PolymorphicInvoke invoke_func = |     PolymorphicInvoke invoke_func = | ||||||
|         &cef_internal::BindState<Runnable, BindRunType, |         &cef_internal::BindState<Runnable, BindRunType, BoundArgsType> | ||||||
|                                  BoundArgsType>::InvokerType::Run; |             ::InvokerType::Run; | ||||||
|     polymorphic_invoke_ = reinterpret_cast<InvokeFuncStorage>(invoke_func); |     polymorphic_invoke_ = reinterpret_cast<InvokeFuncStorage>(invoke_func); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -436,7 +437,9 @@ class Callback<R(void)> : public cef_internal::CallbackBase { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   typedef R (*PolymorphicInvoke)(cef_internal::BindStateBase*); |   typedef R(*PolymorphicInvoke)( | ||||||
|  |       cef_internal::BindStateBase*); | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <typename R, typename A1> | template <typename R, typename A1> | ||||||
| @@ -449,15 +452,16 @@ class Callback<R(A1)> : public cef_internal::CallbackBase { | |||||||
|   // Note that this constructor CANNOT be explicit, and that Bind() CANNOT |   // Note that this constructor CANNOT be explicit, and that Bind() CANNOT | ||||||
|   // return the exact Callback<> type.  See base/bind.h for details. |   // return the exact Callback<> type.  See base/bind.h for details. | ||||||
|   template <typename Runnable, typename BindRunType, typename BoundArgsType> |   template <typename Runnable, typename BindRunType, typename BoundArgsType> | ||||||
|   Callback( |   Callback(cef_internal::BindState<Runnable, BindRunType, | ||||||
|       cef_internal::BindState<Runnable, BindRunType, BoundArgsType>* bind_state) |            BoundArgsType>* bind_state) | ||||||
|       : CallbackBase(bind_state) { |       : CallbackBase(bind_state) { | ||||||
|  |  | ||||||
|     // Force the assignment to a local variable of PolymorphicInvoke |     // Force the assignment to a local variable of PolymorphicInvoke | ||||||
|     // so the compiler will typecheck that the passed in Run() method has |     // so the compiler will typecheck that the passed in Run() method has | ||||||
|     // the correct type. |     // the correct type. | ||||||
|     PolymorphicInvoke invoke_func = |     PolymorphicInvoke invoke_func = | ||||||
|         &cef_internal::BindState<Runnable, BindRunType, |         &cef_internal::BindState<Runnable, BindRunType, BoundArgsType> | ||||||
|                                  BoundArgsType>::InvokerType::Run; |             ::InvokerType::Run; | ||||||
|     polymorphic_invoke_ = reinterpret_cast<InvokeFuncStorage>(invoke_func); |     polymorphic_invoke_ = reinterpret_cast<InvokeFuncStorage>(invoke_func); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -476,6 +480,7 @@ class Callback<R(A1)> : public cef_internal::CallbackBase { | |||||||
|   typedef R(*PolymorphicInvoke)( |   typedef R(*PolymorphicInvoke)( | ||||||
|       cef_internal::BindStateBase*, |       cef_internal::BindStateBase*, | ||||||
|           typename cef_internal::CallbackParamTraits<A1>::ForwardType); |           typename cef_internal::CallbackParamTraits<A1>::ForwardType); | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <typename R, typename A1, typename A2> | template <typename R, typename A1, typename A2> | ||||||
| @@ -488,15 +493,16 @@ class Callback<R(A1, A2)> : public cef_internal::CallbackBase { | |||||||
|   // Note that this constructor CANNOT be explicit, and that Bind() CANNOT |   // Note that this constructor CANNOT be explicit, and that Bind() CANNOT | ||||||
|   // return the exact Callback<> type.  See base/bind.h for details. |   // return the exact Callback<> type.  See base/bind.h for details. | ||||||
|   template <typename Runnable, typename BindRunType, typename BoundArgsType> |   template <typename Runnable, typename BindRunType, typename BoundArgsType> | ||||||
|   Callback( |   Callback(cef_internal::BindState<Runnable, BindRunType, | ||||||
|       cef_internal::BindState<Runnable, BindRunType, BoundArgsType>* bind_state) |            BoundArgsType>* bind_state) | ||||||
|       : CallbackBase(bind_state) { |       : CallbackBase(bind_state) { | ||||||
|  |  | ||||||
|     // Force the assignment to a local variable of PolymorphicInvoke |     // Force the assignment to a local variable of PolymorphicInvoke | ||||||
|     // so the compiler will typecheck that the passed in Run() method has |     // so the compiler will typecheck that the passed in Run() method has | ||||||
|     // the correct type. |     // the correct type. | ||||||
|     PolymorphicInvoke invoke_func = |     PolymorphicInvoke invoke_func = | ||||||
|         &cef_internal::BindState<Runnable, BindRunType, |         &cef_internal::BindState<Runnable, BindRunType, BoundArgsType> | ||||||
|                                  BoundArgsType>::InvokerType::Run; |             ::InvokerType::Run; | ||||||
|     polymorphic_invoke_ = reinterpret_cast<InvokeFuncStorage>(invoke_func); |     polymorphic_invoke_ = reinterpret_cast<InvokeFuncStorage>(invoke_func); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -518,6 +524,7 @@ class Callback<R(A1, A2)> : public cef_internal::CallbackBase { | |||||||
|       cef_internal::BindStateBase*, |       cef_internal::BindStateBase*, | ||||||
|           typename cef_internal::CallbackParamTraits<A1>::ForwardType, |           typename cef_internal::CallbackParamTraits<A1>::ForwardType, | ||||||
|           typename cef_internal::CallbackParamTraits<A2>::ForwardType); |           typename cef_internal::CallbackParamTraits<A2>::ForwardType); | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <typename R, typename A1, typename A2, typename A3> | template <typename R, typename A1, typename A2, typename A3> | ||||||
| @@ -530,15 +537,16 @@ class Callback<R(A1, A2, A3)> : public cef_internal::CallbackBase { | |||||||
|   // Note that this constructor CANNOT be explicit, and that Bind() CANNOT |   // Note that this constructor CANNOT be explicit, and that Bind() CANNOT | ||||||
|   // return the exact Callback<> type.  See base/bind.h for details. |   // return the exact Callback<> type.  See base/bind.h for details. | ||||||
|   template <typename Runnable, typename BindRunType, typename BoundArgsType> |   template <typename Runnable, typename BindRunType, typename BoundArgsType> | ||||||
|   Callback( |   Callback(cef_internal::BindState<Runnable, BindRunType, | ||||||
|       cef_internal::BindState<Runnable, BindRunType, BoundArgsType>* bind_state) |            BoundArgsType>* bind_state) | ||||||
|       : CallbackBase(bind_state) { |       : CallbackBase(bind_state) { | ||||||
|  |  | ||||||
|     // Force the assignment to a local variable of PolymorphicInvoke |     // Force the assignment to a local variable of PolymorphicInvoke | ||||||
|     // so the compiler will typecheck that the passed in Run() method has |     // so the compiler will typecheck that the passed in Run() method has | ||||||
|     // the correct type. |     // the correct type. | ||||||
|     PolymorphicInvoke invoke_func = |     PolymorphicInvoke invoke_func = | ||||||
|         &cef_internal::BindState<Runnable, BindRunType, |         &cef_internal::BindState<Runnable, BindRunType, BoundArgsType> | ||||||
|                                  BoundArgsType>::InvokerType::Run; |             ::InvokerType::Run; | ||||||
|     polymorphic_invoke_ = reinterpret_cast<InvokeFuncStorage>(invoke_func); |     polymorphic_invoke_ = reinterpret_cast<InvokeFuncStorage>(invoke_func); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -563,6 +571,7 @@ class Callback<R(A1, A2, A3)> : public cef_internal::CallbackBase { | |||||||
|           typename cef_internal::CallbackParamTraits<A1>::ForwardType, |           typename cef_internal::CallbackParamTraits<A1>::ForwardType, | ||||||
|           typename cef_internal::CallbackParamTraits<A2>::ForwardType, |           typename cef_internal::CallbackParamTraits<A2>::ForwardType, | ||||||
|           typename cef_internal::CallbackParamTraits<A3>::ForwardType); |           typename cef_internal::CallbackParamTraits<A3>::ForwardType); | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <typename R, typename A1, typename A2, typename A3, typename A4> | template <typename R, typename A1, typename A2, typename A3, typename A4> | ||||||
| @@ -575,15 +584,16 @@ class Callback<R(A1, A2, A3, A4)> : public cef_internal::CallbackBase { | |||||||
|   // Note that this constructor CANNOT be explicit, and that Bind() CANNOT |   // Note that this constructor CANNOT be explicit, and that Bind() CANNOT | ||||||
|   // return the exact Callback<> type.  See base/bind.h for details. |   // return the exact Callback<> type.  See base/bind.h for details. | ||||||
|   template <typename Runnable, typename BindRunType, typename BoundArgsType> |   template <typename Runnable, typename BindRunType, typename BoundArgsType> | ||||||
|   Callback( |   Callback(cef_internal::BindState<Runnable, BindRunType, | ||||||
|       cef_internal::BindState<Runnable, BindRunType, BoundArgsType>* bind_state) |            BoundArgsType>* bind_state) | ||||||
|       : CallbackBase(bind_state) { |       : CallbackBase(bind_state) { | ||||||
|  |  | ||||||
|     // Force the assignment to a local variable of PolymorphicInvoke |     // Force the assignment to a local variable of PolymorphicInvoke | ||||||
|     // so the compiler will typecheck that the passed in Run() method has |     // so the compiler will typecheck that the passed in Run() method has | ||||||
|     // the correct type. |     // the correct type. | ||||||
|     PolymorphicInvoke invoke_func = |     PolymorphicInvoke invoke_func = | ||||||
|         &cef_internal::BindState<Runnable, BindRunType, |         &cef_internal::BindState<Runnable, BindRunType, BoundArgsType> | ||||||
|                                  BoundArgsType>::InvokerType::Run; |             ::InvokerType::Run; | ||||||
|     polymorphic_invoke_ = reinterpret_cast<InvokeFuncStorage>(invoke_func); |     polymorphic_invoke_ = reinterpret_cast<InvokeFuncStorage>(invoke_func); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -611,13 +621,10 @@ class Callback<R(A1, A2, A3, A4)> : public cef_internal::CallbackBase { | |||||||
|           typename cef_internal::CallbackParamTraits<A2>::ForwardType, |           typename cef_internal::CallbackParamTraits<A2>::ForwardType, | ||||||
|           typename cef_internal::CallbackParamTraits<A3>::ForwardType, |           typename cef_internal::CallbackParamTraits<A3>::ForwardType, | ||||||
|           typename cef_internal::CallbackParamTraits<A4>::ForwardType); |           typename cef_internal::CallbackParamTraits<A4>::ForwardType); | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <typename R, | template <typename R, typename A1, typename A2, typename A3, typename A4, | ||||||
|           typename A1, |  | ||||||
|           typename A2, |  | ||||||
|           typename A3, |  | ||||||
|           typename A4, |  | ||||||
|     typename A5> |     typename A5> | ||||||
| class Callback<R(A1, A2, A3, A4, A5)> : public cef_internal::CallbackBase { | class Callback<R(A1, A2, A3, A4, A5)> : public cef_internal::CallbackBase { | ||||||
|  public: |  public: | ||||||
| @@ -628,15 +635,16 @@ class Callback<R(A1, A2, A3, A4, A5)> : public cef_internal::CallbackBase { | |||||||
|   // Note that this constructor CANNOT be explicit, and that Bind() CANNOT |   // Note that this constructor CANNOT be explicit, and that Bind() CANNOT | ||||||
|   // return the exact Callback<> type.  See base/bind.h for details. |   // return the exact Callback<> type.  See base/bind.h for details. | ||||||
|   template <typename Runnable, typename BindRunType, typename BoundArgsType> |   template <typename Runnable, typename BindRunType, typename BoundArgsType> | ||||||
|   Callback( |   Callback(cef_internal::BindState<Runnable, BindRunType, | ||||||
|       cef_internal::BindState<Runnable, BindRunType, BoundArgsType>* bind_state) |            BoundArgsType>* bind_state) | ||||||
|       : CallbackBase(bind_state) { |       : CallbackBase(bind_state) { | ||||||
|  |  | ||||||
|     // Force the assignment to a local variable of PolymorphicInvoke |     // Force the assignment to a local variable of PolymorphicInvoke | ||||||
|     // so the compiler will typecheck that the passed in Run() method has |     // so the compiler will typecheck that the passed in Run() method has | ||||||
|     // the correct type. |     // the correct type. | ||||||
|     PolymorphicInvoke invoke_func = |     PolymorphicInvoke invoke_func = | ||||||
|         &cef_internal::BindState<Runnable, BindRunType, |         &cef_internal::BindState<Runnable, BindRunType, BoundArgsType> | ||||||
|                                  BoundArgsType>::InvokerType::Run; |             ::InvokerType::Run; | ||||||
|     polymorphic_invoke_ = reinterpret_cast<InvokeFuncStorage>(invoke_func); |     polymorphic_invoke_ = reinterpret_cast<InvokeFuncStorage>(invoke_func); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -652,10 +660,11 @@ class Callback<R(A1, A2, A3, A4, A5)> : public cef_internal::CallbackBase { | |||||||
|     PolymorphicInvoke f = |     PolymorphicInvoke f = | ||||||
|         reinterpret_cast<PolymorphicInvoke>(polymorphic_invoke_); |         reinterpret_cast<PolymorphicInvoke>(polymorphic_invoke_); | ||||||
|  |  | ||||||
|     return f( |     return f(bind_state_.get(), cef_internal::CallbackForward(a1), | ||||||
|         bind_state_.get(), cef_internal::CallbackForward(a1), |              cef_internal::CallbackForward(a2), | ||||||
|         cef_internal::CallbackForward(a2), cef_internal::CallbackForward(a3), |              cef_internal::CallbackForward(a3), | ||||||
|         cef_internal::CallbackForward(a4), cef_internal::CallbackForward(a5)); |              cef_internal::CallbackForward(a4), | ||||||
|  |              cef_internal::CallbackForward(a5)); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
| @@ -666,15 +675,11 @@ class Callback<R(A1, A2, A3, A4, A5)> : public cef_internal::CallbackBase { | |||||||
|           typename cef_internal::CallbackParamTraits<A3>::ForwardType, |           typename cef_internal::CallbackParamTraits<A3>::ForwardType, | ||||||
|           typename cef_internal::CallbackParamTraits<A4>::ForwardType, |           typename cef_internal::CallbackParamTraits<A4>::ForwardType, | ||||||
|           typename cef_internal::CallbackParamTraits<A5>::ForwardType); |           typename cef_internal::CallbackParamTraits<A5>::ForwardType); | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <typename R, | template <typename R, typename A1, typename A2, typename A3, typename A4, | ||||||
|           typename A1, |     typename A5, typename A6> | ||||||
|           typename A2, |  | ||||||
|           typename A3, |  | ||||||
|           typename A4, |  | ||||||
|           typename A5, |  | ||||||
|           typename A6> |  | ||||||
| class Callback<R(A1, A2, A3, A4, A5, A6)> : public cef_internal::CallbackBase { | class Callback<R(A1, A2, A3, A4, A5, A6)> : public cef_internal::CallbackBase { | ||||||
|  public: |  public: | ||||||
|   typedef R(RunType)(A1, A2, A3, A4, A5, A6); |   typedef R(RunType)(A1, A2, A3, A4, A5, A6); | ||||||
| @@ -684,15 +689,16 @@ class Callback<R(A1, A2, A3, A4, A5, A6)> : public cef_internal::CallbackBase { | |||||||
|   // Note that this constructor CANNOT be explicit, and that Bind() CANNOT |   // Note that this constructor CANNOT be explicit, and that Bind() CANNOT | ||||||
|   // return the exact Callback<> type.  See base/bind.h for details. |   // return the exact Callback<> type.  See base/bind.h for details. | ||||||
|   template <typename Runnable, typename BindRunType, typename BoundArgsType> |   template <typename Runnable, typename BindRunType, typename BoundArgsType> | ||||||
|   Callback( |   Callback(cef_internal::BindState<Runnable, BindRunType, | ||||||
|       cef_internal::BindState<Runnable, BindRunType, BoundArgsType>* bind_state) |            BoundArgsType>* bind_state) | ||||||
|       : CallbackBase(bind_state) { |       : CallbackBase(bind_state) { | ||||||
|  |  | ||||||
|     // Force the assignment to a local variable of PolymorphicInvoke |     // Force the assignment to a local variable of PolymorphicInvoke | ||||||
|     // so the compiler will typecheck that the passed in Run() method has |     // so the compiler will typecheck that the passed in Run() method has | ||||||
|     // the correct type. |     // the correct type. | ||||||
|     PolymorphicInvoke invoke_func = |     PolymorphicInvoke invoke_func = | ||||||
|         &cef_internal::BindState<Runnable, BindRunType, |         &cef_internal::BindState<Runnable, BindRunType, BoundArgsType> | ||||||
|                                  BoundArgsType>::InvokerType::Run; |             ::InvokerType::Run; | ||||||
|     polymorphic_invoke_ = reinterpret_cast<InvokeFuncStorage>(invoke_func); |     polymorphic_invoke_ = reinterpret_cast<InvokeFuncStorage>(invoke_func); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -709,10 +715,11 @@ class Callback<R(A1, A2, A3, A4, A5, A6)> : public cef_internal::CallbackBase { | |||||||
|     PolymorphicInvoke f = |     PolymorphicInvoke f = | ||||||
|         reinterpret_cast<PolymorphicInvoke>(polymorphic_invoke_); |         reinterpret_cast<PolymorphicInvoke>(polymorphic_invoke_); | ||||||
|  |  | ||||||
|     return f( |     return f(bind_state_.get(), cef_internal::CallbackForward(a1), | ||||||
|         bind_state_.get(), cef_internal::CallbackForward(a1), |              cef_internal::CallbackForward(a2), | ||||||
|         cef_internal::CallbackForward(a2), cef_internal::CallbackForward(a3), |              cef_internal::CallbackForward(a3), | ||||||
|         cef_internal::CallbackForward(a4), cef_internal::CallbackForward(a5), |              cef_internal::CallbackForward(a4), | ||||||
|  |              cef_internal::CallbackForward(a5), | ||||||
|              cef_internal::CallbackForward(a6)); |              cef_internal::CallbackForward(a6)); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -725,18 +732,12 @@ class Callback<R(A1, A2, A3, A4, A5, A6)> : public cef_internal::CallbackBase { | |||||||
|           typename cef_internal::CallbackParamTraits<A4>::ForwardType, |           typename cef_internal::CallbackParamTraits<A4>::ForwardType, | ||||||
|           typename cef_internal::CallbackParamTraits<A5>::ForwardType, |           typename cef_internal::CallbackParamTraits<A5>::ForwardType, | ||||||
|           typename cef_internal::CallbackParamTraits<A6>::ForwardType); |           typename cef_internal::CallbackParamTraits<A6>::ForwardType); | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <typename R, | template <typename R, typename A1, typename A2, typename A3, typename A4, | ||||||
|           typename A1, |     typename A5, typename A6, typename A7> | ||||||
|           typename A2, | class Callback<R(A1, A2, A3, A4, A5, A6, A7)> : public cef_internal::CallbackBase { | ||||||
|           typename A3, |  | ||||||
|           typename A4, |  | ||||||
|           typename A5, |  | ||||||
|           typename A6, |  | ||||||
|           typename A7> |  | ||||||
| class Callback<R(A1, A2, A3, A4, A5, A6, A7)> |  | ||||||
|     : public cef_internal::CallbackBase { |  | ||||||
|  public: |  public: | ||||||
|   typedef R(RunType)(A1, A2, A3, A4, A5, A6, A7); |   typedef R(RunType)(A1, A2, A3, A4, A5, A6, A7); | ||||||
|  |  | ||||||
| @@ -745,15 +746,16 @@ class Callback<R(A1, A2, A3, A4, A5, A6, A7)> | |||||||
|   // Note that this constructor CANNOT be explicit, and that Bind() CANNOT |   // Note that this constructor CANNOT be explicit, and that Bind() CANNOT | ||||||
|   // return the exact Callback<> type.  See base/bind.h for details. |   // return the exact Callback<> type.  See base/bind.h for details. | ||||||
|   template <typename Runnable, typename BindRunType, typename BoundArgsType> |   template <typename Runnable, typename BindRunType, typename BoundArgsType> | ||||||
|   Callback( |   Callback(cef_internal::BindState<Runnable, BindRunType, | ||||||
|       cef_internal::BindState<Runnable, BindRunType, BoundArgsType>* bind_state) |            BoundArgsType>* bind_state) | ||||||
|       : CallbackBase(bind_state) { |       : CallbackBase(bind_state) { | ||||||
|  |  | ||||||
|     // Force the assignment to a local variable of PolymorphicInvoke |     // Force the assignment to a local variable of PolymorphicInvoke | ||||||
|     // so the compiler will typecheck that the passed in Run() method has |     // so the compiler will typecheck that the passed in Run() method has | ||||||
|     // the correct type. |     // the correct type. | ||||||
|     PolymorphicInvoke invoke_func = |     PolymorphicInvoke invoke_func = | ||||||
|         &cef_internal::BindState<Runnable, BindRunType, |         &cef_internal::BindState<Runnable, BindRunType, BoundArgsType> | ||||||
|                                  BoundArgsType>::InvokerType::Run; |             ::InvokerType::Run; | ||||||
|     polymorphic_invoke_ = reinterpret_cast<InvokeFuncStorage>(invoke_func); |     polymorphic_invoke_ = reinterpret_cast<InvokeFuncStorage>(invoke_func); | ||||||
|   } |   } | ||||||
|  |  | ||||||
| @@ -771,11 +773,13 @@ class Callback<R(A1, A2, A3, A4, A5, A6, A7)> | |||||||
|     PolymorphicInvoke f = |     PolymorphicInvoke f = | ||||||
|         reinterpret_cast<PolymorphicInvoke>(polymorphic_invoke_); |         reinterpret_cast<PolymorphicInvoke>(polymorphic_invoke_); | ||||||
|  |  | ||||||
|     return f( |     return f(bind_state_.get(), cef_internal::CallbackForward(a1), | ||||||
|         bind_state_.get(), cef_internal::CallbackForward(a1), |              cef_internal::CallbackForward(a2), | ||||||
|         cef_internal::CallbackForward(a2), cef_internal::CallbackForward(a3), |              cef_internal::CallbackForward(a3), | ||||||
|         cef_internal::CallbackForward(a4), cef_internal::CallbackForward(a5), |              cef_internal::CallbackForward(a4), | ||||||
|         cef_internal::CallbackForward(a6), cef_internal::CallbackForward(a7)); |              cef_internal::CallbackForward(a5), | ||||||
|  |              cef_internal::CallbackForward(a6), | ||||||
|  |              cef_internal::CallbackForward(a7)); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
| @@ -788,8 +792,10 @@ class Callback<R(A1, A2, A3, A4, A5, A6, A7)> | |||||||
|           typename cef_internal::CallbackParamTraits<A5>::ForwardType, |           typename cef_internal::CallbackParamTraits<A5>::ForwardType, | ||||||
|           typename cef_internal::CallbackParamTraits<A6>::ForwardType, |           typename cef_internal::CallbackParamTraits<A6>::ForwardType, | ||||||
|           typename cef_internal::CallbackParamTraits<A7>::ForwardType); |           typename cef_internal::CallbackParamTraits<A7>::ForwardType); | ||||||
|  |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
|  |  | ||||||
| // Syntactic sugar to make Callbacks<void(void)> easier to declare since it | // Syntactic sugar to make Callbacks<void(void)> easier to declare since it | ||||||
| // will be used in a lot of APIs with delayed execution. | // will be used in a lot of APIs with delayed execution. | ||||||
| typedef Callback<void(void)> Closure; | typedef Callback<void(void)> Closure; | ||||||
|   | |||||||
| @@ -48,12 +48,12 @@ | |||||||
| #include <list> | #include <list> | ||||||
|  |  | ||||||
| #include "include/base/cef_basictypes.h" | #include "include/base/cef_basictypes.h" | ||||||
| #include "include/base/cef_build.h" |  | ||||||
| #include "include/base/cef_callback.h" | #include "include/base/cef_callback.h" | ||||||
|  | #include "include/base/internal/cef_callback_internal.h" | ||||||
|  | #include "include/base/cef_build.h" | ||||||
| #include "include/base/cef_logging.h" | #include "include/base/cef_logging.h" | ||||||
| #include "include/base/cef_macros.h" | #include "include/base/cef_macros.h" | ||||||
| #include "include/base/cef_scoped_ptr.h" | #include "include/base/cef_scoped_ptr.h" | ||||||
| #include "include/base/internal/cef_callback_internal.h" |  | ||||||
|  |  | ||||||
| // OVERVIEW: | // OVERVIEW: | ||||||
| // | // | ||||||
| @@ -120,7 +120,9 @@ class CallbackListBase { | |||||||
|    public: |    public: | ||||||
|     Subscription(CallbackListBase<CallbackType>* list, |     Subscription(CallbackListBase<CallbackType>* list, | ||||||
|                  typename std::list<CallbackType>::iterator iter) |                  typename std::list<CallbackType>::iterator iter) | ||||||
|         : list_(list), iter_(iter) {} |         : list_(list), | ||||||
|  |           iter_(iter) { | ||||||
|  |     } | ||||||
|  |  | ||||||
|     ~Subscription() { |     ~Subscription() { | ||||||
|       if (list_->active_iterator_count_) { |       if (list_->active_iterator_count_) { | ||||||
| @@ -165,12 +167,14 @@ class CallbackListBase { | |||||||
|   class Iterator { |   class Iterator { | ||||||
|    public: |    public: | ||||||
|     explicit Iterator(CallbackListBase<CallbackType>* list) |     explicit Iterator(CallbackListBase<CallbackType>* list) | ||||||
|         : list_(list), list_iter_(list_->callbacks_.begin()) { |         : list_(list), | ||||||
|  |           list_iter_(list_->callbacks_.begin()) { | ||||||
|       ++list_->active_iterator_count_; |       ++list_->active_iterator_count_; | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     Iterator(const Iterator& iter) |     Iterator(const Iterator& iter) | ||||||
|         : list_(iter.list_), list_iter_(iter.list_iter_) { |         : list_(iter.list_), | ||||||
|  |           list_iter_(iter.list_iter_) { | ||||||
|       ++list_->active_iterator_count_; |       ++list_->active_iterator_count_; | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -206,7 +210,9 @@ class CallbackListBase { | |||||||
|  |  | ||||||
|   // Returns an instance of a CallbackListBase::Iterator which can be used |   // Returns an instance of a CallbackListBase::Iterator which can be used | ||||||
|   // to run callbacks. |   // to run callbacks. | ||||||
|   Iterator GetIterator() { return Iterator(this); } |   Iterator GetIterator() { | ||||||
|  |     return Iterator(this); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   // Compact the list: remove any entries which were NULLed out during |   // Compact the list: remove any entries which were NULLed out during | ||||||
|   // iteration. |   // iteration. | ||||||
| @@ -236,8 +242,7 @@ class CallbackListBase { | |||||||
|  |  | ||||||
| }  // namespace cef_internal | }  // namespace cef_internal | ||||||
|  |  | ||||||
| template <typename Sig> | template <typename Sig> class CallbackList; | ||||||
| class CallbackList; |  | ||||||
|  |  | ||||||
| template <> | template <> | ||||||
| class CallbackList<void(void)> | class CallbackList<void(void)> | ||||||
| @@ -352,8 +357,7 @@ class CallbackList<void(A1, A2, A3, A4)> | |||||||
|  |  | ||||||
| template <typename A1, typename A2, typename A3, typename A4, typename A5> | template <typename A1, typename A2, typename A3, typename A4, typename A5> | ||||||
| class CallbackList<void(A1, A2, A3, A4, A5)> | class CallbackList<void(A1, A2, A3, A4, A5)> | ||||||
|     : public cef_internal::CallbackListBase< |     : public cef_internal::CallbackListBase<Callback<void(A1, A2, A3, A4, A5)> > { | ||||||
|           Callback<void(A1, A2, A3, A4, A5)>> { |  | ||||||
|  public: |  public: | ||||||
|   typedef Callback<void(A1, A2, A3, A4, A5)> CallbackType; |   typedef Callback<void(A1, A2, A3, A4, A5)> CallbackType; | ||||||
|  |  | ||||||
| @@ -376,15 +380,11 @@ class CallbackList<void(A1, A2, A3, A4, A5)> | |||||||
|   DISALLOW_COPY_AND_ASSIGN(CallbackList); |   DISALLOW_COPY_AND_ASSIGN(CallbackList); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <typename A1, | template <typename A1, typename A2, typename A3, typename A4, typename A5, | ||||||
|           typename A2, |  | ||||||
|           typename A3, |  | ||||||
|           typename A4, |  | ||||||
|           typename A5, |  | ||||||
|     typename A6> |     typename A6> | ||||||
| class CallbackList<void(A1, A2, A3, A4, A5, A6)> | class CallbackList<void(A1, A2, A3, A4, A5, A6)> | ||||||
|     : public cef_internal::CallbackListBase< |     : public cef_internal::CallbackListBase<Callback<void(A1, A2, A3, A4, A5, | ||||||
|           Callback<void(A1, A2, A3, A4, A5, A6)>> { |         A6)> > { | ||||||
|  public: |  public: | ||||||
|   typedef Callback<void(A1, A2, A3, A4, A5, A6)> CallbackType; |   typedef Callback<void(A1, A2, A3, A4, A5, A6)> CallbackType; | ||||||
|  |  | ||||||
| @@ -408,16 +408,11 @@ class CallbackList<void(A1, A2, A3, A4, A5, A6)> | |||||||
|   DISALLOW_COPY_AND_ASSIGN(CallbackList); |   DISALLOW_COPY_AND_ASSIGN(CallbackList); | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <typename A1, | template <typename A1, typename A2, typename A3, typename A4, typename A5, | ||||||
|           typename A2, |     typename A6, typename A7> | ||||||
|           typename A3, |  | ||||||
|           typename A4, |  | ||||||
|           typename A5, |  | ||||||
|           typename A6, |  | ||||||
|           typename A7> |  | ||||||
| class CallbackList<void(A1, A2, A3, A4, A5, A6, A7)> | class CallbackList<void(A1, A2, A3, A4, A5, A6, A7)> | ||||||
|     : public cef_internal::CallbackListBase< |     : public cef_internal::CallbackListBase<Callback<void(A1, A2, A3, A4, A5, A6, | ||||||
|           Callback<void(A1, A2, A3, A4, A5, A6, A7)>> { |         A7)> > { | ||||||
|  public: |  public: | ||||||
|   typedef Callback<void(A1, A2, A3, A4, A5, A6, A7)> CallbackType; |   typedef Callback<void(A1, A2, A3, A4, A5, A6, A7)> CallbackType; | ||||||
|  |  | ||||||
|   | |||||||
| @@ -83,8 +83,8 @@ | |||||||
| // updated to match. | // updated to match. | ||||||
|  |  | ||||||
| #include "include/base/cef_bind.h" | #include "include/base/cef_bind.h" | ||||||
| #include "include/base/cef_build.h" |  | ||||||
| #include "include/base/cef_callback.h" | #include "include/base/cef_callback.h" | ||||||
|  | #include "include/base/cef_build.h" | ||||||
| #include "include/base/cef_logging.h" | #include "include/base/cef_logging.h" | ||||||
| #include "include/base/cef_macros.h" | #include "include/base/cef_macros.h" | ||||||
| #include "include/base/cef_weak_ptr.h" | #include "include/base/cef_weak_ptr.h" | ||||||
| @@ -102,7 +102,8 @@ class CancelableCallback<void(void)> { | |||||||
|  |  | ||||||
|   // |callback| must not be null. |   // |callback| must not be null. | ||||||
|   explicit CancelableCallback(const base::Callback<void(void)>& callback) |   explicit CancelableCallback(const base::Callback<void(void)>& callback) | ||||||
|       : weak_factory_(this), callback_(callback) { |       : weak_factory_(this), | ||||||
|  |         callback_(callback) { | ||||||
|     DCHECK(!callback.is_null()); |     DCHECK(!callback.is_null()); | ||||||
|     InitializeForwarder(); |     InitializeForwarder(); | ||||||
|   } |   } | ||||||
| @@ -117,7 +118,9 @@ class CancelableCallback<void(void)> { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Returns true if the wrapped callback has been cancelled. |   // Returns true if the wrapped callback has been cancelled. | ||||||
|   bool IsCancelled() const { return callback_.is_null(); } |   bool IsCancelled() const { | ||||||
|  |     return callback_.is_null(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   // Sets |callback| as the closure that may be cancelled. |callback| may not |   // Sets |callback| as the closure that may be cancelled. |callback| may not | ||||||
|   // be null. Outstanding and any previously wrapped callbacks are cancelled. |   // be null. Outstanding and any previously wrapped callbacks are cancelled. | ||||||
| @@ -134,10 +137,14 @@ class CancelableCallback<void(void)> { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Returns a callback that can be disabled by calling Cancel(). |   // Returns a callback that can be disabled by calling Cancel(). | ||||||
|   const base::Callback<void(void)>& callback() const { return forwarder_; } |   const base::Callback<void(void)>& callback() const { | ||||||
|  |     return forwarder_; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   void Forward() { callback_.Run(); } |   void Forward() { | ||||||
|  |     callback_.Run(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   // Helper method to bind |forwarder_| using a weak pointer from |   // Helper method to bind |forwarder_| using a weak pointer from | ||||||
|   // |weak_factory_|. |   // |weak_factory_|. | ||||||
| @@ -165,7 +172,8 @@ class CancelableCallback<void(A1)> { | |||||||
|  |  | ||||||
|   // |callback| must not be null. |   // |callback| must not be null. | ||||||
|   explicit CancelableCallback(const base::Callback<void(A1)>& callback) |   explicit CancelableCallback(const base::Callback<void(A1)>& callback) | ||||||
|       : weak_factory_(this), callback_(callback) { |       : weak_factory_(this), | ||||||
|  |         callback_(callback) { | ||||||
|     DCHECK(!callback.is_null()); |     DCHECK(!callback.is_null()); | ||||||
|     InitializeForwarder(); |     InitializeForwarder(); | ||||||
|   } |   } | ||||||
| @@ -180,7 +188,9 @@ class CancelableCallback<void(A1)> { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Returns true if the wrapped callback has been cancelled. |   // Returns true if the wrapped callback has been cancelled. | ||||||
|   bool IsCancelled() const { return callback_.is_null(); } |   bool IsCancelled() const { | ||||||
|  |     return callback_.is_null(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   // Sets |callback| as the closure that may be cancelled. |callback| may not |   // Sets |callback| as the closure that may be cancelled. |callback| may not | ||||||
|   // be null. Outstanding and any previously wrapped callbacks are cancelled. |   // be null. Outstanding and any previously wrapped callbacks are cancelled. | ||||||
| @@ -197,10 +207,14 @@ class CancelableCallback<void(A1)> { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Returns a callback that can be disabled by calling Cancel(). |   // Returns a callback that can be disabled by calling Cancel(). | ||||||
|   const base::Callback<void(A1)>& callback() const { return forwarder_; } |   const base::Callback<void(A1)>& callback() const { | ||||||
|  |     return forwarder_; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   void Forward(A1 a1) const { callback_.Run(a1); } |   void Forward(A1 a1) const { | ||||||
|  |     callback_.Run(a1); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   // Helper method to bind |forwarder_| using a weak pointer from |   // Helper method to bind |forwarder_| using a weak pointer from | ||||||
|   // |weak_factory_|. |   // |weak_factory_|. | ||||||
| @@ -228,7 +242,8 @@ class CancelableCallback<void(A1, A2)> { | |||||||
|  |  | ||||||
|   // |callback| must not be null. |   // |callback| must not be null. | ||||||
|   explicit CancelableCallback(const base::Callback<void(A1, A2)>& callback) |   explicit CancelableCallback(const base::Callback<void(A1, A2)>& callback) | ||||||
|       : weak_factory_(this), callback_(callback) { |       : weak_factory_(this), | ||||||
|  |         callback_(callback) { | ||||||
|     DCHECK(!callback.is_null()); |     DCHECK(!callback.is_null()); | ||||||
|     InitializeForwarder(); |     InitializeForwarder(); | ||||||
|   } |   } | ||||||
| @@ -243,7 +258,9 @@ class CancelableCallback<void(A1, A2)> { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Returns true if the wrapped callback has been cancelled. |   // Returns true if the wrapped callback has been cancelled. | ||||||
|   bool IsCancelled() const { return callback_.is_null(); } |   bool IsCancelled() const { | ||||||
|  |     return callback_.is_null(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   // Sets |callback| as the closure that may be cancelled. |callback| may not |   // Sets |callback| as the closure that may be cancelled. |callback| may not | ||||||
|   // be null. Outstanding and any previously wrapped callbacks are cancelled. |   // be null. Outstanding and any previously wrapped callbacks are cancelled. | ||||||
| @@ -260,10 +277,14 @@ class CancelableCallback<void(A1, A2)> { | |||||||
|   } |   } | ||||||
|  |  | ||||||
|   // Returns a callback that can be disabled by calling Cancel(). |   // Returns a callback that can be disabled by calling Cancel(). | ||||||
|   const base::Callback<void(A1, A2)>& callback() const { return forwarder_; } |   const base::Callback<void(A1, A2)>& callback() const { | ||||||
|  |     return forwarder_; | ||||||
|  |   } | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   void Forward(A1 a1, A2 a2) const { callback_.Run(a1, a2); } |   void Forward(A1 a1, A2 a2) const { | ||||||
|  |     callback_.Run(a1, a2); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   // Helper method to bind |forwarder_| using a weak pointer from |   // Helper method to bind |forwarder_| using a weak pointer from | ||||||
|   // |weak_factory_|. |   // |weak_factory_|. | ||||||
|   | |||||||
| @@ -125,7 +125,9 @@ class AutoLock { | |||||||
|  public: |  public: | ||||||
|   struct AlreadyAcquired {}; |   struct AlreadyAcquired {}; | ||||||
|  |  | ||||||
|   explicit AutoLock(Lock& lock) : lock_(lock) { lock_.Acquire(); } |   explicit AutoLock(Lock& lock) : lock_(lock) { | ||||||
|  |     lock_.Acquire(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   AutoLock(Lock& lock, const AlreadyAcquired&) : lock_(lock) { |   AutoLock(Lock& lock, const AlreadyAcquired&) : lock_(lock) { | ||||||
|     lock_.AssertAcquired(); |     lock_.AssertAcquired(); | ||||||
| @@ -151,7 +153,9 @@ class AutoUnlock { | |||||||
|     lock_.Release(); |     lock_.Release(); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   ~AutoUnlock() { lock_.Acquire(); } |   ~AutoUnlock() { | ||||||
|  |     lock_.Acquire(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   Lock& lock_; |   Lock& lock_; | ||||||
|   | |||||||
| @@ -158,9 +158,9 @@ | |||||||
| // updated to match. | // updated to match. | ||||||
|  |  | ||||||
| #include <cassert> | #include <cassert> | ||||||
|  | #include <string> | ||||||
| #include <cstring> | #include <cstring> | ||||||
| #include <sstream> | #include <sstream> | ||||||
| #include <string> |  | ||||||
|  |  | ||||||
| #include "include/base/cef_build.h" | #include "include/base/cef_build.h" | ||||||
| #include "include/base/cef_macros.h" | #include "include/base/cef_macros.h" | ||||||
| @@ -217,11 +217,16 @@ const LogSeverity LOG_DFATAL = LOG_FATAL; | |||||||
|   cef::logging::ClassName(__FILE__, __LINE__, cef::logging::LOG_DFATAL , \ |   cef::logging::ClassName(__FILE__, __LINE__, cef::logging::LOG_DFATAL , \ | ||||||
|                          ##__VA_ARGS__) |                          ##__VA_ARGS__) | ||||||
|  |  | ||||||
| #define COMPACT_GOOGLE_LOG_INFO COMPACT_GOOGLE_LOG_EX_INFO(LogMessage) | #define COMPACT_GOOGLE_LOG_INFO \ | ||||||
| #define COMPACT_GOOGLE_LOG_WARNING COMPACT_GOOGLE_LOG_EX_WARNING(LogMessage) |   COMPACT_GOOGLE_LOG_EX_INFO(LogMessage) | ||||||
| #define COMPACT_GOOGLE_LOG_ERROR COMPACT_GOOGLE_LOG_EX_ERROR(LogMessage) | #define COMPACT_GOOGLE_LOG_WARNING \ | ||||||
| #define COMPACT_GOOGLE_LOG_FATAL COMPACT_GOOGLE_LOG_EX_FATAL(LogMessage) |   COMPACT_GOOGLE_LOG_EX_WARNING(LogMessage) | ||||||
| #define COMPACT_GOOGLE_LOG_DFATAL COMPACT_GOOGLE_LOG_EX_DFATAL(LogMessage) | #define COMPACT_GOOGLE_LOG_ERROR \ | ||||||
|  |   COMPACT_GOOGLE_LOG_EX_ERROR(LogMessage) | ||||||
|  | #define COMPACT_GOOGLE_LOG_FATAL \ | ||||||
|  |   COMPACT_GOOGLE_LOG_EX_FATAL(LogMessage) | ||||||
|  | #define COMPACT_GOOGLE_LOG_DFATAL \ | ||||||
|  |   COMPACT_GOOGLE_LOG_EX_DFATAL(LogMessage) | ||||||
|  |  | ||||||
| #if defined(OS_WIN) | #if defined(OS_WIN) | ||||||
| // wingdi.h defines ERROR to be 0. When we call LOG(ERROR), it gets | // wingdi.h defines ERROR to be 0. When we call LOG(ERROR), it gets | ||||||
| @@ -286,13 +291,11 @@ const LogSeverity LOG_0 = LOG_ERROR; | |||||||
| #if defined (OS_WIN) | #if defined (OS_WIN) | ||||||
| #define VPLOG_STREAM(verbose_level) \ | #define VPLOG_STREAM(verbose_level) \ | ||||||
|   cef::logging::Win32ErrorLogMessage(__FILE__, __LINE__, -verbose_level, \ |   cef::logging::Win32ErrorLogMessage(__FILE__, __LINE__, -verbose_level, \ | ||||||
|                                      ::cef::logging::GetLastSystemErrorCode()) \ |     ::cef::logging::GetLastSystemErrorCode()).stream() | ||||||
|       .stream() |  | ||||||
| #elif defined(OS_POSIX) | #elif defined(OS_POSIX) | ||||||
| #define VPLOG_STREAM(verbose_level) \ | #define VPLOG_STREAM(verbose_level) \ | ||||||
|   cef::logging::ErrnoLogMessage(__FILE__, __LINE__, -verbose_level, \ |   cef::logging::ErrnoLogMessage(__FILE__, __LINE__, -verbose_level, \ | ||||||
|                                 ::cef::logging::GetLastSystemErrorCode()) \ |     ::cef::logging::GetLastSystemErrorCode()).stream() | ||||||
|       .stream() |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #define VPLOG(verbose_level) \ | #define VPLOG(verbose_level) \ | ||||||
| @@ -312,16 +315,15 @@ const LogSeverity LOG_0 = LOG_ERROR; | |||||||
| #if defined(OS_WIN) | #if defined(OS_WIN) | ||||||
| #define PLOG_STREAM(severity) \ | #define PLOG_STREAM(severity) \ | ||||||
|   COMPACT_GOOGLE_LOG_EX_ ## severity(Win32ErrorLogMessage, \ |   COMPACT_GOOGLE_LOG_EX_ ## severity(Win32ErrorLogMessage, \ | ||||||
|                                    ::cef::logging::GetLastSystemErrorCode()) \ |       ::cef::logging::GetLastSystemErrorCode()).stream() | ||||||
|       .stream() |  | ||||||
| #elif defined(OS_POSIX) | #elif defined(OS_POSIX) | ||||||
| #define PLOG_STREAM(severity) \ | #define PLOG_STREAM(severity) \ | ||||||
|   COMPACT_GOOGLE_LOG_EX_ ## severity(ErrnoLogMessage, \ |   COMPACT_GOOGLE_LOG_EX_ ## severity(ErrnoLogMessage, \ | ||||||
|                                    ::cef::logging::GetLastSystemErrorCode()) \ |       ::cef::logging::GetLastSystemErrorCode()).stream() | ||||||
|       .stream() |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| #define PLOG(severity) LAZY_STREAM(PLOG_STREAM(severity), LOG_IS_ON(severity)) | #define PLOG(severity)                                          \ | ||||||
|  |   LAZY_STREAM(PLOG_STREAM(severity), LOG_IS_ON(severity)) | ||||||
|  |  | ||||||
| #define PLOG_IF(severity, condition) \ | #define PLOG_IF(severity, condition) \ | ||||||
|   LAZY_STREAM(PLOG_STREAM(severity), LOG_IS_ON(severity) && (condition)) |   LAZY_STREAM(PLOG_STREAM(severity), LOG_IS_ON(severity) && (condition)) | ||||||
| @@ -351,8 +353,9 @@ const LogSeverity LOG_0 = LOG_ERROR; | |||||||
| // TODO(akalin): Rewrite this so that constructs like if (...) | // TODO(akalin): Rewrite this so that constructs like if (...) | ||||||
| // CHECK_EQ(...) else { ... } work properly. | // CHECK_EQ(...) else { ... } work properly. | ||||||
| #define CHECK_OP(name, op, val1, val2)                          \ | #define CHECK_OP(name, op, val1, val2)                          \ | ||||||
|   if (std::string* _result = cef::logging::Check##name##Impl( \ |   if (std::string* _result =                                    \ | ||||||
|           (val1), (val2), #val1 " " #op " " #val2))           \ |       cef::logging::Check##name##Impl((val1), (val2),                \ | ||||||
|  |                                  #val1 " " #op " " #val2))      \ | ||||||
|     cef::logging::LogMessage(__FILE__, __LINE__, _result).stream() |     cef::logging::LogMessage(__FILE__, __LINE__, _result).stream() | ||||||
|  |  | ||||||
| // Build the error message string.  This is separate from the "Impl" | // Build the error message string.  This is separate from the "Impl" | ||||||
| @@ -371,25 +374,20 @@ std::string* MakeCheckOpString(const t1& v1, const t2& v2, const char* names) { | |||||||
| #if !defined(COMPILER_MSVC) | #if !defined(COMPILER_MSVC) | ||||||
| // Commonly used instantiations of MakeCheckOpString<>. Explicitly instantiated | // Commonly used instantiations of MakeCheckOpString<>. Explicitly instantiated | ||||||
| // in logging.cc. | // in logging.cc. | ||||||
| extern template std::string* MakeCheckOpString<int, int>(const int&, | extern template std::string* MakeCheckOpString<int, int>( | ||||||
|                                                          const int&, |     const int&, const int&, const char* names); | ||||||
|                                                          const char* names); | extern template | ||||||
| extern template std::string* MakeCheckOpString<unsigned long, unsigned long>( | std::string* MakeCheckOpString<unsigned long, unsigned long>( | ||||||
|     const unsigned long&, |     const unsigned long&, const unsigned long&, const char* names); | ||||||
|     const unsigned long&, | extern template | ||||||
|     const char* names); | std::string* MakeCheckOpString<unsigned long, unsigned int>( | ||||||
| extern template std::string* MakeCheckOpString<unsigned long, unsigned int>( |     const unsigned long&, const unsigned int&, const char* names); | ||||||
|     const unsigned long&, | extern template | ||||||
|     const unsigned int&, | std::string* MakeCheckOpString<unsigned int, unsigned long>( | ||||||
|     const char* names); |     const unsigned int&, const unsigned long&, const char* names); | ||||||
| extern template std::string* MakeCheckOpString<unsigned int, unsigned long>( | extern template | ||||||
|     const unsigned int&, | std::string* MakeCheckOpString<std::string, std::string>( | ||||||
|     const unsigned long&, |     const std::string&, const std::string&, const char* name); | ||||||
|     const char* names); |  | ||||||
| extern template std::string* MakeCheckOpString<std::string, std::string>( |  | ||||||
|     const std::string&, |  | ||||||
|     const std::string&, |  | ||||||
|     const char* name); |  | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| // Helper functions for CHECK_OP macro. | // Helper functions for CHECK_OP macro. | ||||||
| @@ -400,16 +398,12 @@ extern template std::string* MakeCheckOpString<std::string, std::string>( | |||||||
|   template <class t1, class t2> \ |   template <class t1, class t2> \ | ||||||
|   inline std::string* Check##name##Impl(const t1& v1, const t2& v2, \ |   inline std::string* Check##name##Impl(const t1& v1, const t2& v2, \ | ||||||
|                                         const char* names) { \ |                                         const char* names) { \ | ||||||
|     if (v1 op v2)                                                            \ |     if (v1 op v2) return NULL; \ | ||||||
|       return NULL;                                                           \ |     else return MakeCheckOpString(v1, v2, names); \ | ||||||
|     else                                                                     \ |  | ||||||
|       return MakeCheckOpString(v1, v2, names);                               \ |  | ||||||
|   } \ |   } \ | ||||||
|   inline std::string* Check##name##Impl(int v1, int v2, const char* names) { \ |   inline std::string* Check##name##Impl(int v1, int v2, const char* names) { \ | ||||||
|     if (v1 op v2)                                                            \ |     if (v1 op v2) return NULL; \ | ||||||
|       return NULL;                                                           \ |     else return MakeCheckOpString(v1, v2, names); \ | ||||||
|     else                                                                     \ |  | ||||||
|       return MakeCheckOpString(v1, v2, names);                               \ |  | ||||||
|   } |   } | ||||||
| DEFINE_CHECK_OP_IMPL(EQ, ==) | DEFINE_CHECK_OP_IMPL(EQ, ==) | ||||||
| DEFINE_CHECK_OP_IMPL(NE, !=) | DEFINE_CHECK_OP_IMPL(NE, !=) | ||||||
| @@ -477,9 +471,11 @@ enum { DEBUG_MODE = ENABLE_DLOG }; | |||||||
|  |  | ||||||
| #undef ENABLE_DLOG | #undef ENABLE_DLOG | ||||||
|  |  | ||||||
| #define DLOG(severity) LAZY_STREAM(LOG_STREAM(severity), DLOG_IS_ON(severity)) | #define DLOG(severity)                                          \ | ||||||
|  |   LAZY_STREAM(LOG_STREAM(severity), DLOG_IS_ON(severity)) | ||||||
|  |  | ||||||
| #define DPLOG(severity) LAZY_STREAM(PLOG_STREAM(severity), DLOG_IS_ON(severity)) | #define DPLOG(severity)                                         \ | ||||||
|  |   LAZY_STREAM(PLOG_STREAM(severity), DLOG_IS_ON(severity)) | ||||||
|  |  | ||||||
| #define DVLOG(verboselevel) DVLOG_IF(verboselevel, VLOG_IS_ON(verboselevel)) | #define DVLOG(verboselevel) DVLOG_IF(verboselevel, VLOG_IS_ON(verboselevel)) | ||||||
|  |  | ||||||
| @@ -523,9 +519,8 @@ const LogSeverity LOG_DCHECK = LOG_INFO; | |||||||
|   if (DCHECK_IS_ON())                                                     \ |   if (DCHECK_IS_ON())                                                     \ | ||||||
|     if (std::string* _result = cef::logging::Check##name##Impl(           \ |     if (std::string* _result = cef::logging::Check##name##Impl(           \ | ||||||
|             (val1), (val2), #val1 " " #op " " #val2))                     \ |             (val1), (val2), #val1 " " #op " " #val2))                     \ | ||||||
|   cef::logging::LogMessage(__FILE__, __LINE__, ::cef::logging::LOG_DCHECK, \ |   cef::logging::LogMessage(__FILE__, __LINE__,                            \ | ||||||
|                            _result)                                        \ |       ::cef::logging::LOG_DCHECK, _result).stream() | ||||||
|       .stream() |  | ||||||
|  |  | ||||||
| // Equality/Inequality checks - compare two values, and log a | // Equality/Inequality checks - compare two values, and log a | ||||||
| // LOG_DCHECK message including the two values when the result is not | // LOG_DCHECK message including the two values when the result is not | ||||||
| @@ -554,8 +549,8 @@ const LogSeverity LOG_DCHECK = LOG_INFO; | |||||||
| #define DCHECK_GT(val1, val2) DCHECK_OP(GT, > , val1, val2) | #define DCHECK_GT(val1, val2) DCHECK_OP(GT, > , val1, val2) | ||||||
|  |  | ||||||
| #if defined(NDEBUG) && defined(OS_CHROMEOS) | #if defined(NDEBUG) && defined(OS_CHROMEOS) | ||||||
| #define NOTREACHED() \ | #define NOTREACHED() LOG(ERROR) << "NOTREACHED() hit in " << \ | ||||||
|   LOG(ERROR) << "NOTREACHED() hit in " << __FUNCTION__ << ". " |     __FUNCTION__ << ". " | ||||||
| #else | #else | ||||||
| #define NOTREACHED() DCHECK(false) | #define NOTREACHED() DCHECK(false) | ||||||
| #endif | #endif | ||||||
| @@ -582,9 +577,7 @@ class LogMessage { | |||||||
|   LogMessage(const char* file, int line, std::string* result); |   LogMessage(const char* file, int line, std::string* result); | ||||||
|  |  | ||||||
|   // Used for DCHECK_EQ(), etc. Takes ownership of the given string. |   // Used for DCHECK_EQ(), etc. Takes ownership of the given string. | ||||||
|   LogMessage(const char* file, |   LogMessage(const char* file, int line, LogSeverity severity, | ||||||
|              int line, |  | ||||||
|              LogSeverity severity, |  | ||||||
|              std::string* result); |              std::string* result); | ||||||
|  |  | ||||||
|   ~LogMessage(); |   ~LogMessage(); | ||||||
| @@ -746,8 +739,7 @@ inline std::ostream& operator<<(std::ostream& out, const std::wstring& wstr) { | |||||||
| #elif NOTIMPLEMENTED_POLICY == 4 | #elif NOTIMPLEMENTED_POLICY == 4 | ||||||
| #define NOTIMPLEMENTED() LOG(ERROR) << NOTIMPLEMENTED_MSG | #define NOTIMPLEMENTED() LOG(ERROR) << NOTIMPLEMENTED_MSG | ||||||
| #elif NOTIMPLEMENTED_POLICY == 5 | #elif NOTIMPLEMENTED_POLICY == 5 | ||||||
| #define NOTIMPLEMENTED()                               \ | #define NOTIMPLEMENTED() do {\ | ||||||
|   do {                                                 \ |  | ||||||
|   static bool logged_once = false;\ |   static bool logged_once = false;\ | ||||||
|   LOG_IF(ERROR, !logged_once) << NOTIMPLEMENTED_MSG;\ |   LOG_IF(ERROR, !logged_once) << NOTIMPLEMENTED_MSG;\ | ||||||
|   logged_once = true;\ |   logged_once = true;\ | ||||||
|   | |||||||
| @@ -126,13 +126,14 @@ char (&ArraySizeHelper(const T (&array)[N]))[N]; | |||||||
| namespace cef { | namespace cef { | ||||||
|  |  | ||||||
| template <bool> | template <bool> | ||||||
| struct CompileAssert {}; | struct CompileAssert { | ||||||
|  | }; | ||||||
|  |  | ||||||
| }  // namespace cef | }  // namespace cef | ||||||
|  |  | ||||||
| #define COMPILE_ASSERT(expr, msg) \ | #define COMPILE_ASSERT(expr, msg) \ | ||||||
|   typedef cef::CompileAssert<(bool(expr))> \ |   typedef cef::CompileAssert<(bool(expr))> msg[bool(expr) ? 1 : -1] \ | ||||||
|       msg[bool(expr) ? 1 : -1] ALLOW_UNUSED_TYPE |       ALLOW_UNUSED_TYPE | ||||||
|  |  | ||||||
| // Implementation details of COMPILE_ASSERT: | // Implementation details of COMPILE_ASSERT: | ||||||
| // | // | ||||||
| @@ -181,12 +182,13 @@ struct CompileAssert {}; | |||||||
|  |  | ||||||
| #endif  // !USING_CHROMIUM_INCLUDES | #endif  // !USING_CHROMIUM_INCLUDES | ||||||
|  |  | ||||||
| #if !defined(MSVC_PUSH_DISABLE_WARNING) && defined(COMPILER_MSVC) | #if !defined(ALLOW_THIS_IN_INITIALIZER_LIST) | ||||||
|  | #if defined(COMPILER_MSVC) | ||||||
|  |  | ||||||
| // MSVC_PUSH_DISABLE_WARNING pushes |n| onto a stack of warnings to be disabled. | // MSVC_PUSH_DISABLE_WARNING pushes |n| onto a stack of warnings to be disabled. | ||||||
| // The warning remains disabled until popped by MSVC_POP_WARNING. | // The warning remains disabled until popped by MSVC_POP_WARNING. | ||||||
| #define MSVC_PUSH_DISABLE_WARNING(n) \ | #define MSVC_PUSH_DISABLE_WARNING(n) __pragma(warning(push)) \ | ||||||
|   __pragma(warning(push)) __pragma(warning(disable : n)) |                                      __pragma(warning(disable:n)) | ||||||
|  |  | ||||||
| // MSVC_PUSH_WARNING_LEVEL pushes |n| as the global warning level.  The level | // MSVC_PUSH_WARNING_LEVEL pushes |n| as the global warning level.  The level | ||||||
| // remains in effect until popped by MSVC_POP_WARNING().  Use 0 to disable all | // remains in effect until popped by MSVC_POP_WARNING().  Use 0 to disable all | ||||||
| @@ -196,10 +198,6 @@ struct CompileAssert {}; | |||||||
| // Pop effects of innermost MSVC_PUSH_* macro. | // Pop effects of innermost MSVC_PUSH_* macro. | ||||||
| #define MSVC_POP_WARNING() __pragma(warning(pop)) | #define MSVC_POP_WARNING() __pragma(warning(pop)) | ||||||
|  |  | ||||||
| #endif  // !defined(MSVC_PUSH_DISABLE_WARNING) && defined(COMPILER_MSVC) |  | ||||||
|  |  | ||||||
| #if !defined(ALLOW_THIS_IN_INITIALIZER_LIST) |  | ||||||
| #if defined(COMPILER_MSVC) |  | ||||||
| // Allows |this| to be passed as an argument in constructor initializer lists. | // Allows |this| to be passed as an argument in constructor initializer lists. | ||||||
| // This uses push/pop instead of the seemingly simpler suppress feature to avoid | // This uses push/pop instead of the seemingly simpler suppress feature to avoid | ||||||
| // having the warning be disabled for more than just |code|. | // having the warning be disabled for more than just |code|. | ||||||
| @@ -209,11 +207,13 @@ struct CompileAssert {}; | |||||||
| // | // | ||||||
| // Compiler warning C4355: 'this': used in base member initializer list: | // Compiler warning C4355: 'this': used in base member initializer list: | ||||||
| // http://msdn.microsoft.com/en-us/library/3c594ae3(VS.80).aspx | // http://msdn.microsoft.com/en-us/library/3c594ae3(VS.80).aspx | ||||||
| #define ALLOW_THIS_IN_INITIALIZER_LIST(code) \ | #define ALLOW_THIS_IN_INITIALIZER_LIST(code) MSVC_PUSH_DISABLE_WARNING(4355) \ | ||||||
|   MSVC_PUSH_DISABLE_WARNING(4355)            \ |                                              code \ | ||||||
|   code MSVC_POP_WARNING() |                                              MSVC_POP_WARNING() | ||||||
| #else  // !COMPILER_MSVC | #else  // !COMPILER_MSVC | ||||||
|  |  | ||||||
| #define ALLOW_THIS_IN_INITIALIZER_LIST(code) code | #define ALLOW_THIS_IN_INITIALIZER_LIST(code) code | ||||||
|  |  | ||||||
| #endif  // !COMPILER_MSVC | #endif  // !COMPILER_MSVC | ||||||
| #endif  // !ALLOW_THIS_IN_INITIALIZER_LIST | #endif  // !ALLOW_THIS_IN_INITIALIZER_LIST | ||||||
|  |  | ||||||
|   | |||||||
| @@ -248,12 +248,10 @@ | |||||||
|   }; \ |   }; \ | ||||||
|   type(type&); \ |   type(type&); \ | ||||||
|   void operator=(type&); \ |   void operator=(type&); \ | ||||||
|                                                            \ |  | ||||||
|  public: \ |  public: \ | ||||||
|   operator rvalue_type() { return rvalue_type(this); } \ |   operator rvalue_type() { return rvalue_type(this); } \ | ||||||
|   type Pass() { return type(rvalue_type(this)); } \ |   type Pass() { return type(rvalue_type(this)); } \ | ||||||
|   typedef void MoveOnlyTypeForCPP03; \ |   typedef void MoveOnlyTypeForCPP03; \ | ||||||
|                                                            \ |  | ||||||
|  private: |  private: | ||||||
|   |   | ||||||
| #endif  // !USING_CHROMIUM_INCLUDES | #endif  // !USING_CHROMIUM_INCLUDES | ||||||
|   | |||||||
| @@ -69,14 +69,21 @@ class PlatformThreadRef { | |||||||
|  public: |  public: | ||||||
|   typedef cef_platform_thread_handle_t RefType; |   typedef cef_platform_thread_handle_t RefType; | ||||||
|  |  | ||||||
|   PlatformThreadRef() : id_(0) {} |   PlatformThreadRef() | ||||||
|  |       : id_(0) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   explicit PlatformThreadRef(RefType id) : id_(id) {} |   explicit PlatformThreadRef(RefType id) | ||||||
|  |       : id_(id) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   bool operator==(PlatformThreadRef other) const { return id_ == other.id_; } |   bool operator==(PlatformThreadRef other) const { | ||||||
|  |     return id_ == other.id_; | ||||||
|   bool is_null() const { return id_ == 0; } |   } | ||||||
|  |  | ||||||
|  |   bool is_null() const { | ||||||
|  |     return id_ == 0; | ||||||
|  |   } | ||||||
|  private: |  private: | ||||||
|   RefType id_; |   RefType id_; | ||||||
| }; | }; | ||||||
|   | |||||||
| @@ -65,8 +65,7 @@ class RefCountedBase { | |||||||
|   RefCountedBase() |   RefCountedBase() | ||||||
|       : ref_count_(0) |       : ref_count_(0) | ||||||
|   #if DCHECK_IS_ON() |   #if DCHECK_IS_ON() | ||||||
|         , |       , in_dtor_(false) | ||||||
|         in_dtor_(false) |  | ||||||
|   #endif |   #endif | ||||||
|       { |       { | ||||||
|   } |   } | ||||||
| @@ -77,6 +76,7 @@ class RefCountedBase { | |||||||
|   #endif |   #endif | ||||||
|   } |   } | ||||||
|  |  | ||||||
|  |  | ||||||
|   void AddRef() const { |   void AddRef() const { | ||||||
|     // TODO(maruel): Add back once it doesn't assert 500 times/sec. |     // TODO(maruel): Add back once it doesn't assert 500 times/sec. | ||||||
|     // Current thread books the critical section "AddRelease" |     // Current thread books the critical section "AddRelease" | ||||||
| @@ -160,7 +160,9 @@ class RefCounted : public cef_subtle::RefCountedBase { | |||||||
|  public: |  public: | ||||||
|   RefCounted() {} |   RefCounted() {} | ||||||
|  |  | ||||||
|   void AddRef() const { cef_subtle::RefCountedBase::AddRef(); } |   void AddRef() const { | ||||||
|  |     cef_subtle::RefCountedBase::AddRef(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   void Release() const { |   void Release() const { | ||||||
|     if (cef_subtle::RefCountedBase::Release()) { |     if (cef_subtle::RefCountedBase::Release()) { | ||||||
| @@ -176,8 +178,7 @@ class RefCounted : public cef_subtle::RefCountedBase { | |||||||
| }; | }; | ||||||
|  |  | ||||||
| // Forward declaration. | // Forward declaration. | ||||||
| template <class T, typename Traits> | template <class T, typename Traits> class RefCountedThreadSafe; | ||||||
| class RefCountedThreadSafe; |  | ||||||
|  |  | ||||||
| // Default traits for RefCountedThreadSafe<T>.  Deletes the object when its ref | // Default traits for RefCountedThreadSafe<T>.  Deletes the object when its ref | ||||||
| // count reaches 0.  Overload to delete it on a different thread etc. | // count reaches 0.  Overload to delete it on a different thread etc. | ||||||
| @@ -187,8 +188,8 @@ struct DefaultRefCountedThreadSafeTraits { | |||||||
|     // Delete through RefCountedThreadSafe to make child classes only need to be |     // Delete through RefCountedThreadSafe to make child classes only need to be | ||||||
|     // friend with RefCountedThreadSafe instead of this struct, which is an |     // friend with RefCountedThreadSafe instead of this struct, which is an | ||||||
|     // implementation detail. |     // implementation detail. | ||||||
|     RefCountedThreadSafe<T, DefaultRefCountedThreadSafeTraits>::DeleteInternal( |     RefCountedThreadSafe<T, | ||||||
|         x); |                          DefaultRefCountedThreadSafeTraits>::DeleteInternal(x); | ||||||
|   } |   } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -209,7 +210,9 @@ class RefCountedThreadSafe : public cef_subtle::RefCountedThreadSafeBase { | |||||||
|  public: |  public: | ||||||
|   RefCountedThreadSafe() {} |   RefCountedThreadSafe() {} | ||||||
|  |  | ||||||
|   void AddRef() const { cef_subtle::RefCountedThreadSafeBase::AddRef(); } |   void AddRef() const { | ||||||
|  |     cef_subtle::RefCountedThreadSafeBase::AddRef(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   void Release() const { |   void Release() const { | ||||||
|     if (cef_subtle::RefCountedThreadSafeBase::Release()) { |     if (cef_subtle::RefCountedThreadSafeBase::Release()) { | ||||||
| @@ -300,7 +303,8 @@ class scoped_refptr { | |||||||
|  public: |  public: | ||||||
|   typedef T element_type; |   typedef T element_type; | ||||||
|  |  | ||||||
|   scoped_refptr() : ptr_(NULL) {} |   scoped_refptr() : ptr_(NULL) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   scoped_refptr(T* p) : ptr_(p) { |   scoped_refptr(T* p) : ptr_(p) { | ||||||
|     if (ptr_) |     if (ptr_) | ||||||
| @@ -360,7 +364,9 @@ class scoped_refptr { | |||||||
|     *pp = p; |     *pp = p; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   void swap(scoped_refptr<T>& r) { swap(&r.ptr_); } |   void swap(scoped_refptr<T>& r) { | ||||||
|  |     swap(&r.ptr_); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  protected: |  protected: | ||||||
|   T* ptr_; |   T* ptr_; | ||||||
|   | |||||||
| @@ -154,8 +154,7 @@ class RefCountedThreadSafeBase; | |||||||
| template <class T> | template <class T> | ||||||
| struct DefaultDeleter { | struct DefaultDeleter { | ||||||
|   DefaultDeleter() {} |   DefaultDeleter() {} | ||||||
|   template <typename U> |   template <typename U> DefaultDeleter(const DefaultDeleter<U>& other) { | ||||||
|   DefaultDeleter(const DefaultDeleter<U>& other) { |  | ||||||
|     // IMPLEMENTATION NOTE: C++11 20.7.1.1.2p2 only provides this constructor |     // IMPLEMENTATION NOTE: C++11 20.7.1.1.2p2 only provides this constructor | ||||||
|     // if U* is implicitly convertible to T* and U is not an array type. |     // if U* is implicitly convertible to T* and U is not an array type. | ||||||
|     // |     // | ||||||
| @@ -195,8 +194,7 @@ struct DefaultDeleter<T[]> { | |||||||
|   // References: |   // References: | ||||||
|   //   C++98 [expr.delete]p3 |   //   C++98 [expr.delete]p3 | ||||||
|   //   http://cplusplus.github.com/LWG/lwg-defects.html#938 |   //   http://cplusplus.github.com/LWG/lwg-defects.html#938 | ||||||
|   template <typename U> |   template <typename U> void operator()(U* array) const; | ||||||
|   void operator()(U* array) const; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class T, int n> | template <class T, int n> | ||||||
| @@ -211,18 +209,18 @@ struct DefaultDeleter<T[n]> { | |||||||
| // scoped_ptr<int, base::FreeDeleter> foo_ptr( | // scoped_ptr<int, base::FreeDeleter> foo_ptr( | ||||||
| //     static_cast<int*>(malloc(sizeof(int)))); | //     static_cast<int*>(malloc(sizeof(int)))); | ||||||
| struct FreeDeleter { | struct FreeDeleter { | ||||||
|   inline void operator()(void* ptr) const { free(ptr); } |   inline void operator()(void* ptr) const { | ||||||
|  |     free(ptr); | ||||||
|  |   } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| namespace cef_internal { | namespace cef_internal { | ||||||
|  |  | ||||||
| template <typename T> | template <typename T> struct IsNotRefCounted { | ||||||
| struct IsNotRefCounted { |  | ||||||
|   enum { |   enum { | ||||||
|     value = |     value = !base::is_convertible<T*, base::subtle::RefCountedBase*>::value && | ||||||
|         !base::is_convertible<T*, base::subtle::RefCountedBase*>::value && |         !base::is_convertible<T*, base::subtle::RefCountedThreadSafeBase*>:: | ||||||
|         !base::is_convertible<T*, |             value | ||||||
|                               base::subtle::RefCountedThreadSafeBase*>::value |  | ||||||
|   }; |   }; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| @@ -311,8 +309,7 @@ class scoped_ptr_impl { | |||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   // Needed to allow type-converting constructor. |   // Needed to allow type-converting constructor. | ||||||
|   template <typename U, typename V> |   template <typename U, typename V> friend class scoped_ptr_impl; | ||||||
|   friend class scoped_ptr_impl; |  | ||||||
|  |  | ||||||
|   // Use the empty base class optimization to allow us to have a D |   // Use the empty base class optimization to allow us to have a D | ||||||
|   // member, while avoiding any space overhead for it when D is an |   // member, while avoiding any space overhead for it when D is an | ||||||
| @@ -446,14 +443,18 @@ class scoped_ptr { | |||||||
|   bool operator!=(const element_type* p) const { return impl_.get() != p; } |   bool operator!=(const element_type* p) const { return impl_.get() != p; } | ||||||
|  |  | ||||||
|   // Swap two scoped pointers. |   // Swap two scoped pointers. | ||||||
|   void swap(scoped_ptr& p2) { impl_.swap(p2.impl_); } |   void swap(scoped_ptr& p2) { | ||||||
|  |     impl_.swap(p2.impl_); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   // Release a pointer. |   // Release a pointer. | ||||||
|   // The return value is the current pointer held by this object. |   // The return value is the current pointer held by this object. | ||||||
|   // If this object holds a NULL pointer, the return value is NULL. |   // If this object holds a NULL pointer, the return value is NULL. | ||||||
|   // After this operation, this object will hold a NULL pointer, |   // After this operation, this object will hold a NULL pointer, | ||||||
|   // and will not own the object any more. |   // and will not own the object any more. | ||||||
|   element_type* release() WARN_UNUSED_RESULT { return impl_.release(); } |   element_type* release() WARN_UNUSED_RESULT { | ||||||
|  |     return impl_.release(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   // C++98 doesn't support functions templates with default parameters which |   // C++98 doesn't support functions templates with default parameters which | ||||||
|   // makes it hard to write a PassAs() that understands converting the deleter |   // makes it hard to write a PassAs() that understands converting the deleter | ||||||
| @@ -468,8 +469,7 @@ class scoped_ptr { | |||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   // Needed to reach into |impl_| in the constructor. |   // Needed to reach into |impl_| in the constructor. | ||||||
|   template <typename U, typename V> |   template <typename U, typename V> friend class scoped_ptr; | ||||||
|   friend class scoped_ptr; |  | ||||||
|   base::cef_internal::scoped_ptr_impl<element_type, deleter_type> impl_; |   base::cef_internal::scoped_ptr_impl<element_type, deleter_type> impl_; | ||||||
|  |  | ||||||
|   // Forbidden for API compatibility with std::unique_ptr. |   // Forbidden for API compatibility with std::unique_ptr. | ||||||
| @@ -479,10 +479,8 @@ class scoped_ptr { | |||||||
|   // doesn't make sense, and if U == T, it still doesn't make sense |   // doesn't make sense, and if U == T, it still doesn't make sense | ||||||
|   // because you should never have the same object owned by two different |   // because you should never have the same object owned by two different | ||||||
|   // scoped_ptrs. |   // scoped_ptrs. | ||||||
|   template <class U> |   template <class U> bool operator==(scoped_ptr<U> const& p2) const; | ||||||
|   bool operator==(scoped_ptr<U> const& p2) const; |   template <class U> bool operator!=(scoped_ptr<U> const& p2) const; | ||||||
|   template <class U> |  | ||||||
|   bool operator!=(scoped_ptr<U> const& p2) const; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class T, class D> | template <class T, class D> | ||||||
| @@ -555,14 +553,18 @@ class scoped_ptr<T[], D> { | |||||||
|   bool operator!=(element_type* array) const { return impl_.get() != array; } |   bool operator!=(element_type* array) const { return impl_.get() != array; } | ||||||
|  |  | ||||||
|   // Swap two scoped pointers. |   // Swap two scoped pointers. | ||||||
|   void swap(scoped_ptr& p2) { impl_.swap(p2.impl_); } |   void swap(scoped_ptr& p2) { | ||||||
|  |     impl_.swap(p2.impl_); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   // Release a pointer. |   // Release a pointer. | ||||||
|   // The return value is the current pointer held by this object. |   // The return value is the current pointer held by this object. | ||||||
|   // If this object holds a NULL pointer, the return value is NULL. |   // If this object holds a NULL pointer, the return value is NULL. | ||||||
|   // After this operation, this object will hold a NULL pointer, |   // After this operation, this object will hold a NULL pointer, | ||||||
|   // and will not own the object any more. |   // and will not own the object any more. | ||||||
|   element_type* release() WARN_UNUSED_RESULT { return impl_.release(); } |   element_type* release() WARN_UNUSED_RESULT { | ||||||
|  |     return impl_.release(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   // Force element_type to be a complete type. |   // Force element_type to be a complete type. | ||||||
| @@ -576,24 +578,20 @@ class scoped_ptr<T[], D> { | |||||||
|   // private and has no definition. This is disabled because it is not safe to |   // private and has no definition. This is disabled because it is not safe to | ||||||
|   // call delete[] on an array whose static type does not match its dynamic |   // call delete[] on an array whose static type does not match its dynamic | ||||||
|   // type. |   // type. | ||||||
|   template <typename U> |   template <typename U> explicit scoped_ptr(U* array); | ||||||
|   explicit scoped_ptr(U* array); |  | ||||||
|   explicit scoped_ptr(int disallow_construction_from_null); |   explicit scoped_ptr(int disallow_construction_from_null); | ||||||
|  |  | ||||||
|   // Disable reset() from any type other than element_type*, for the same |   // Disable reset() from any type other than element_type*, for the same | ||||||
|   // reasons as the constructor above. |   // reasons as the constructor above. | ||||||
|   template <typename U> |   template <typename U> void reset(U* array); | ||||||
|   void reset(U* array); |  | ||||||
|   void reset(int disallow_reset_from_null); |   void reset(int disallow_reset_from_null); | ||||||
|  |  | ||||||
|   // Forbid comparison of scoped_ptr types.  If U != T, it totally |   // Forbid comparison of scoped_ptr types.  If U != T, it totally | ||||||
|   // doesn't make sense, and if U == T, it still doesn't make sense |   // doesn't make sense, and if U == T, it still doesn't make sense | ||||||
|   // because you should never have the same object owned by two different |   // because you should never have the same object owned by two different | ||||||
|   // scoped_ptrs. |   // scoped_ptrs. | ||||||
|   template <class U> |   template <class U> bool operator==(scoped_ptr<U> const& p2) const; | ||||||
|   bool operator==(scoped_ptr<U> const& p2) const; |   template <class U> bool operator!=(scoped_ptr<U> const& p2) const; | ||||||
|   template <class U> |  | ||||||
|   bool operator!=(scoped_ptr<U> const& p2) const; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // Free functions | // Free functions | ||||||
|   | |||||||
| @@ -86,7 +86,6 @@ typedef std::char_traits<wchar_t> string16_char_traits; | |||||||
|  |  | ||||||
| #include "include/base/cef_macros.h" | #include "include/base/cef_macros.h" | ||||||
|  |  | ||||||
| namespace cef { |  | ||||||
| namespace base { | namespace base { | ||||||
|  |  | ||||||
| typedef uint16_t char16; | typedef uint16_t char16; | ||||||
| @@ -113,19 +112,26 @@ struct string16_char_traits { | |||||||
|   typedef mbstate_t state_type; |   typedef mbstate_t state_type; | ||||||
|   typedef std::fpos<state_type> pos_type; |   typedef std::fpos<state_type> pos_type; | ||||||
|  |  | ||||||
|   static void assign(char_type& c1, const char_type& c2) { c1 = c2; } |   static void assign(char_type& c1, const char_type& c2) { | ||||||
|  |     c1 = c2; | ||||||
|  |   } | ||||||
|  |  | ||||||
|   static bool eq(const char_type& c1, const char_type& c2) { return c1 == c2; } |   static bool eq(const char_type& c1, const char_type& c2) { | ||||||
|   static bool lt(const char_type& c1, const char_type& c2) { return c1 < c2; } |     return c1 == c2; | ||||||
|  |   } | ||||||
|  |   static bool lt(const char_type& c1, const char_type& c2) { | ||||||
|  |     return c1 < c2; | ||||||
|  |   } | ||||||
|  |  | ||||||
|   static int compare(const char_type* s1, const char_type* s2, size_t n) { |   static int compare(const char_type* s1, const char_type* s2, size_t n) { | ||||||
|     return c16memcmp(s1, s2, n); |     return c16memcmp(s1, s2, n); | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   static size_t length(const char_type* s) { return c16len(s); } |   static size_t length(const char_type* s) { | ||||||
|  |     return c16len(s); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   static const char_type* find(const char_type* s, |   static const char_type* find(const char_type* s, size_t n, | ||||||
|                                size_t n, |  | ||||||
|                                const char_type& a) { |                                const char_type& a) { | ||||||
|     return c16memchr(s, a, n); |     return c16memchr(s, a, n); | ||||||
|   } |   } | ||||||
| @@ -146,26 +152,24 @@ struct string16_char_traits { | |||||||
|     return eq_int_type(c, eof()) ? 0 : c; |     return eq_int_type(c, eof()) ? 0 : c; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   static char_type to_char_type(const int_type& c) { return char_type(c); } |   static char_type to_char_type(const int_type& c) { | ||||||
|  |     return char_type(c); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   static int_type to_int_type(const char_type& c) { return int_type(c); } |   static int_type to_int_type(const char_type& c) { | ||||||
|  |     return int_type(c); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   static bool eq_int_type(const int_type& c1, const int_type& c2) { |   static bool eq_int_type(const int_type& c1, const int_type& c2) { | ||||||
|     return c1 == c2; |     return c1 == c2; | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   static int_type eof() { return static_cast<int_type>(EOF); } |   static int_type eof() { | ||||||
|  |     return static_cast<int_type>(EOF); | ||||||
|  |   } | ||||||
| }; | }; | ||||||
|  |  | ||||||
| typedef std::basic_string<char16, string16_char_traits> string16; | typedef std::basic_string<char16, base::string16_char_traits> string16; | ||||||
|  |  | ||||||
| }  // namespace base |  | ||||||
| }  // namespace cef |  | ||||||
|  |  | ||||||
| namespace base { |  | ||||||
|  |  | ||||||
| typedef cef::base::char16 char16; |  | ||||||
| typedef cef::base::string16 string16; |  | ||||||
|  |  | ||||||
| extern std::ostream& operator<<(std::ostream& out, const string16& str); | extern std::ostream& operator<<(std::ostream& out, const string16& str); | ||||||
|  |  | ||||||
| @@ -213,8 +217,8 @@ extern void PrintTo(const string16& str, std::ostream* out); | |||||||
| // | // | ||||||
| // TODO(mark): File this bug with Apple and update this note with a bug number. | // TODO(mark): File this bug with Apple and update this note with a bug number. | ||||||
|  |  | ||||||
| extern template class std::basic_string<cef::base::char16, | extern template | ||||||
|                                         cef::base::string16_char_traits>; | class std::basic_string<base::char16, base::string16_char_traits>; | ||||||
|  |  | ||||||
| #endif  // WCHAR_T_IS_UTF32 | #endif  // WCHAR_T_IS_UTF32 | ||||||
|  |  | ||||||
|   | |||||||
| @@ -60,16 +60,13 @@ struct integral_constant { | |||||||
|   typedef integral_constant<T, v> type; |   typedef integral_constant<T, v> type; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <class T, T v> | template <class T, T v> const T integral_constant<T, v>::value; | ||||||
| const T integral_constant<T, v>::value; |  | ||||||
|  |  | ||||||
| typedef integral_constant<bool, true> true_type; | typedef integral_constant<bool, true> true_type; | ||||||
| typedef integral_constant<bool, false> false_type; | typedef integral_constant<bool, false> false_type; | ||||||
|  |  | ||||||
| template <class T> | template <class T> struct is_pointer : false_type {}; | ||||||
| struct is_pointer : false_type {}; | template <class T> struct is_pointer<T*> : true_type {}; | ||||||
| template <class T> |  | ||||||
| struct is_pointer<T*> : true_type {}; |  | ||||||
|  |  | ||||||
| // Member function pointer detection up to four params. Add more as needed | // Member function pointer detection up to four params. Add more as needed | ||||||
| // below. This is built-in to C++ 11, and we can remove this when we switch. | // below. This is built-in to C++ 11, and we can remove this when we switch. | ||||||
| @@ -96,49 +93,30 @@ struct is_member_function_pointer<R (Z::*)(A, B, C)> : true_type {}; | |||||||
| template <typename R, typename Z, typename A, typename B, typename C> | template <typename R, typename Z, typename A, typename B, typename C> | ||||||
| struct is_member_function_pointer<R(Z::*)(A, B, C) const> : true_type {}; | struct is_member_function_pointer<R(Z::*)(A, B, C) const> : true_type {}; | ||||||
|  |  | ||||||
| template <typename R, | template <typename R, typename Z, typename A, typename B, typename C, | ||||||
|           typename Z, |  | ||||||
|           typename A, |  | ||||||
|           typename B, |  | ||||||
|           typename C, |  | ||||||
|           typename D> |           typename D> | ||||||
| struct is_member_function_pointer<R(Z::*)(A, B, C, D)> : true_type {}; | struct is_member_function_pointer<R(Z::*)(A, B, C, D)> : true_type {}; | ||||||
| template <typename R, | template <typename R, typename Z, typename A, typename B, typename C, | ||||||
|           typename Z, |  | ||||||
|           typename A, |  | ||||||
|           typename B, |  | ||||||
|           typename C, |  | ||||||
|           typename D> |           typename D> | ||||||
| struct is_member_function_pointer<R(Z::*)(A, B, C, D) const> : true_type {}; | struct is_member_function_pointer<R(Z::*)(A, B, C, D) const> : true_type {}; | ||||||
|  |  | ||||||
| template <class T, class U> |  | ||||||
| struct is_same : public false_type {}; |  | ||||||
| template <class T> |  | ||||||
| struct is_same<T, T> : true_type {}; |  | ||||||
|  |  | ||||||
| template <class> | template <class T, class U> struct is_same : public false_type {}; | ||||||
| struct is_array : public false_type {}; | template <class T> struct is_same<T,T> : true_type {}; | ||||||
| template <class T, size_t n> |  | ||||||
| struct is_array<T[n]> : public true_type {}; |  | ||||||
| template <class T> |  | ||||||
| struct is_array<T[]> : public true_type {}; |  | ||||||
|  |  | ||||||
| template <class T> | template<class> struct is_array : public false_type {}; | ||||||
| struct is_non_const_reference : false_type {}; | template<class T, size_t n> struct is_array<T[n]> : public true_type {}; | ||||||
| template <class T> | template<class T> struct is_array<T[]> : public true_type {}; | ||||||
| struct is_non_const_reference<T&> : true_type {}; |  | ||||||
| template <class T> |  | ||||||
| struct is_non_const_reference<const T&> : false_type {}; |  | ||||||
|  |  | ||||||
| template <class T> | template <class T> struct is_non_const_reference : false_type {}; | ||||||
| struct is_const : false_type {}; | template <class T> struct is_non_const_reference<T&> : true_type {}; | ||||||
| template <class T> | template <class T> struct is_non_const_reference<const T&> : false_type {}; | ||||||
| struct is_const<const T> : true_type {}; |  | ||||||
|  |  | ||||||
| template <class T> | template <class T> struct is_const : false_type {}; | ||||||
| struct is_void : false_type {}; | template <class T> struct is_const<const T> : true_type {}; | ||||||
| template <> |  | ||||||
| struct is_void<void> : true_type {}; | template <class T> struct is_void : false_type {}; | ||||||
|  | template <> struct is_void<void> : true_type {}; | ||||||
|  |  | ||||||
| namespace cef_internal { | namespace cef_internal { | ||||||
|  |  | ||||||
| @@ -191,21 +169,21 @@ struct is_convertible | |||||||
|     : integral_constant<bool, |     : integral_constant<bool, | ||||||
|                         sizeof(cef_internal::ConvertHelper::Test<To>( |                         sizeof(cef_internal::ConvertHelper::Test<To>( | ||||||
|                                    cef_internal::ConvertHelper::Create<From>())) == |                                    cef_internal::ConvertHelper::Create<From>())) == | ||||||
|                             sizeof(cef_internal::YesType)> {}; |                         sizeof(cef_internal::YesType)> { | ||||||
|  | }; | ||||||
|  |  | ||||||
| template <typename T> | template <typename T> | ||||||
| struct is_class | struct is_class | ||||||
|     : integral_constant<bool, |     : integral_constant<bool, | ||||||
|                         sizeof(cef_internal::IsClassHelper::Test<T>(0)) == |                         sizeof(cef_internal::IsClassHelper::Test<T>(0)) == | ||||||
|                             sizeof(cef_internal::YesType)> {}; |                             sizeof(cef_internal::YesType)> { | ||||||
|  | }; | ||||||
|  |  | ||||||
| template<bool B, class T = void> | template<bool B, class T = void> | ||||||
| struct enable_if {}; | struct enable_if {}; | ||||||
|  |  | ||||||
| template<class T> | template<class T> | ||||||
| struct enable_if<true, T> { | struct enable_if<true, T> { typedef T type; }; | ||||||
|   typedef T type; |  | ||||||
| }; |  | ||||||
|  |  | ||||||
| }  // namespace base | }  // namespace base | ||||||
|  |  | ||||||
|   | |||||||
| @@ -58,6 +58,7 @@ | |||||||
| #define ENABLE_THREAD_CHECKER 0 | #define ENABLE_THREAD_CHECKER 0 | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| namespace base { | namespace base { | ||||||
|  |  | ||||||
| namespace cef_internal { | namespace cef_internal { | ||||||
| @@ -68,7 +69,9 @@ namespace cef_internal { | |||||||
| // right version for your build configuration. | // right version for your build configuration. | ||||||
| class ThreadCheckerDoNothing { | class ThreadCheckerDoNothing { | ||||||
|  public: |  public: | ||||||
|   bool CalledOnValidThread() const { return true; } |   bool CalledOnValidThread() const { | ||||||
|  |     return true; | ||||||
|  |   } | ||||||
|  |  | ||||||
|   void DetachFromThread() {} |   void DetachFromThread() {} | ||||||
| }; | }; | ||||||
| @@ -107,9 +110,11 @@ class ThreadCheckerDoNothing { | |||||||
| // | // | ||||||
| // In Release mode, CalledOnValidThread will always return true. | // In Release mode, CalledOnValidThread will always return true. | ||||||
| #if ENABLE_THREAD_CHECKER | #if ENABLE_THREAD_CHECKER | ||||||
| class ThreadChecker : public cef_internal::ThreadCheckerImpl {}; | class ThreadChecker : public cef_internal::ThreadCheckerImpl { | ||||||
|  | }; | ||||||
| #else | #else | ||||||
| class ThreadChecker : public cef_internal::ThreadCheckerDoNothing {}; | class ThreadChecker : public cef_internal::ThreadCheckerDoNothing { | ||||||
|  | }; | ||||||
| #endif  // ENABLE_THREAD_CHECKER | #endif  // ENABLE_THREAD_CHECKER | ||||||
|  |  | ||||||
| #undef ENABLE_THREAD_CHECKER | #undef ENABLE_THREAD_CHECKER | ||||||
|   | |||||||
| @@ -139,11 +139,13 @@ | |||||||
| //   DFAKE_MUTEX(shareable_section_); | //   DFAKE_MUTEX(shareable_section_); | ||||||
| // }; | // }; | ||||||
|  |  | ||||||
|  |  | ||||||
| #if DCHECK_IS_ON() | #if DCHECK_IS_ON() | ||||||
|  |  | ||||||
| // Defines a class member that acts like a mutex. It is used only as a | // Defines a class member that acts like a mutex. It is used only as a | ||||||
| // verification tool. | // verification tool. | ||||||
| #define DFAKE_MUTEX(obj) mutable base::ThreadCollisionWarner obj | #define DFAKE_MUTEX(obj) \ | ||||||
|  |      mutable base::ThreadCollisionWarner obj | ||||||
| // Asserts the call is never called simultaneously in two threads. Used at | // Asserts the call is never called simultaneously in two threads. Used at | ||||||
| // member function scope. | // member function scope. | ||||||
| #define DFAKE_SCOPED_LOCK(obj) \ | #define DFAKE_SCOPED_LOCK(obj) \ | ||||||
| @@ -185,9 +187,13 @@ class ThreadCollisionWarner { | |||||||
|  public: |  public: | ||||||
|   // The parameter asserter is there only for test purpose |   // The parameter asserter is there only for test purpose | ||||||
|   explicit ThreadCollisionWarner(AsserterBase* asserter = new DCheckAsserter()) |   explicit ThreadCollisionWarner(AsserterBase* asserter = new DCheckAsserter()) | ||||||
|       : valid_thread_id_(0), counter_(0), asserter_(asserter) {} |       : valid_thread_id_(0), | ||||||
|  |         counter_(0), | ||||||
|  |         asserter_(asserter) {} | ||||||
|  |  | ||||||
|   ~ThreadCollisionWarner() { delete asserter_; } |   ~ThreadCollisionWarner() { | ||||||
|  |     delete asserter_; | ||||||
|  |   } | ||||||
|  |  | ||||||
|   // This class is meant to be used through the macro |   // This class is meant to be used through the macro | ||||||
|   // DFAKE_SCOPED_LOCK_THREAD_LOCKED |   // DFAKE_SCOPED_LOCK_THREAD_LOCKED | ||||||
| @@ -196,7 +202,8 @@ class ThreadCollisionWarner { | |||||||
|   // from one thread |   // from one thread | ||||||
|   class Check { |   class Check { | ||||||
|    public: |    public: | ||||||
|     explicit Check(ThreadCollisionWarner* warner) : warner_(warner) { |     explicit Check(ThreadCollisionWarner* warner) | ||||||
|  |         : warner_(warner) { | ||||||
|       warner_->EnterSelf(); |       warner_->EnterSelf(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
| @@ -212,11 +219,14 @@ class ThreadCollisionWarner { | |||||||
|   // DFAKE_SCOPED_LOCK |   // DFAKE_SCOPED_LOCK | ||||||
|   class ScopedCheck { |   class ScopedCheck { | ||||||
|    public: |    public: | ||||||
|     explicit ScopedCheck(ThreadCollisionWarner* warner) : warner_(warner) { |     explicit ScopedCheck(ThreadCollisionWarner* warner) | ||||||
|  |         : warner_(warner) { | ||||||
|       warner_->Enter(); |       warner_->Enter(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     ~ScopedCheck() { warner_->Leave(); } |     ~ScopedCheck() { | ||||||
|  |       warner_->Leave(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|    private: |    private: | ||||||
|     ThreadCollisionWarner* warner_; |     ThreadCollisionWarner* warner_; | ||||||
| @@ -233,7 +243,9 @@ class ThreadCollisionWarner { | |||||||
|       warner_->EnterSelf(); |       warner_->EnterSelf(); | ||||||
|     } |     } | ||||||
|  |  | ||||||
|     ~ScopedRecursiveCheck() { warner_->Leave(); } |     ~ScopedRecursiveCheck() { | ||||||
|  |       warner_->Leave(); | ||||||
|  |     } | ||||||
|  |  | ||||||
|    private: |    private: | ||||||
|     ThreadCollisionWarner* warner_; |     ThreadCollisionWarner* warner_; | ||||||
|   | |||||||
| @@ -166,23 +166,26 @@ | |||||||
| #define TRACE_EVENT1(category, name, arg1_name, arg1_val) \ | #define TRACE_EVENT1(category, name, arg1_name, arg1_val) \ | ||||||
|   cef_trace_event_begin(category, name, arg1_name, arg1_val, NULL, 0, false); \ |   cef_trace_event_begin(category, name, arg1_name, arg1_val, NULL, 0, false); \ | ||||||
|   CEF_INTERNAL_TRACE_END_ON_SCOPE_CLOSE(category, name) |   CEF_INTERNAL_TRACE_END_ON_SCOPE_CLOSE(category, name) | ||||||
| #define TRACE_EVENT2(category, name, arg1_name, arg1_val, arg2_name, arg2_val) \ | #define TRACE_EVENT2(category, name, arg1_name, arg1_val, arg2_name, \ | ||||||
|   cef_trace_event_begin(category, name, arg1_name, arg1_val, arg2_name,        \ |       arg2_val) \ | ||||||
|                         arg2_val, false);                                      \ |   cef_trace_event_begin(category, name, arg1_name, arg1_val, \ | ||||||
|  |                                         arg2_name, arg2_val, false); \ | ||||||
|   CEF_INTERNAL_TRACE_END_ON_SCOPE_CLOSE(category, name) |   CEF_INTERNAL_TRACE_END_ON_SCOPE_CLOSE(category, name) | ||||||
|  |  | ||||||
| // Implementation detail: trace event macros create temporary variable names. | // Implementation detail: trace event macros create temporary variable names. | ||||||
| // These macros give each temporary variable a unique name based on the line | // These macros give each temporary variable a unique name based on the line | ||||||
| // number to prevent name collisions. | // number to prevent name collisions. | ||||||
| #define CEF_INTERNAL_TRACE_EVENT_UID3(a, b) cef_trace_event_unique_##a##b | #define CEF_INTERNAL_TRACE_EVENT_UID3(a,b) \ | ||||||
| #define CEF_INTERNAL_TRACE_EVENT_UID2(a, b) CEF_INTERNAL_TRACE_EVENT_UID3(a, b) |   cef_trace_event_unique_##a##b | ||||||
|  | #define CEF_INTERNAL_TRACE_EVENT_UID2(a,b) \ | ||||||
|  |   CEF_INTERNAL_TRACE_EVENT_UID3(a,b) | ||||||
| #define CEF_INTERNAL_TRACE_EVENT_UID(name_prefix) \ | #define CEF_INTERNAL_TRACE_EVENT_UID(name_prefix) \ | ||||||
|   CEF_INTERNAL_TRACE_EVENT_UID2(name_prefix, __LINE__) |   CEF_INTERNAL_TRACE_EVENT_UID2(name_prefix, __LINE__) | ||||||
|  |  | ||||||
| // Implementation detail: internal macro to end end event when the scope ends. | // Implementation detail: internal macro to end end event when the scope ends. | ||||||
| #define CEF_INTERNAL_TRACE_END_ON_SCOPE_CLOSE(category, name) \ | #define CEF_INTERNAL_TRACE_END_ON_SCOPE_CLOSE(category, name) \ | ||||||
|   cef_trace_event::CefTraceEndOnScopeClose CEF_INTERNAL_TRACE_EVENT_UID( \ |    cef_trace_event::CefTraceEndOnScopeClose \ | ||||||
|       profileScope)(category, name) |        CEF_INTERNAL_TRACE_EVENT_UID(profileScope)(category, name) | ||||||
|  |  | ||||||
| // Records a single event called "name" immediately, with 0, 1 or 2 | // Records a single event called "name" immediately, with 0, 1 or 2 | ||||||
| // associated arguments. If the category is not enabled, then this | // associated arguments. If the category is not enabled, then this | ||||||
| @@ -193,8 +196,8 @@ | |||||||
|   cef_trace_event_instant(category, name, NULL, 0, NULL, 0, false) |   cef_trace_event_instant(category, name, NULL, 0, NULL, 0, false) | ||||||
| #define TRACE_EVENT_INSTANT1(category, name, arg1_name, arg1_val) \ | #define TRACE_EVENT_INSTANT1(category, name, arg1_name, arg1_val) \ | ||||||
|   cef_trace_event_instant(category, name, arg1_name, arg1_val, NULL, 0, false) |   cef_trace_event_instant(category, name, arg1_name, arg1_val, NULL, 0, false) | ||||||
| #define TRACE_EVENT_INSTANT2(category, name, arg1_name, arg1_val, arg2_name, \ | #define TRACE_EVENT_INSTANT2(category, name, arg1_name, arg1_val, \ | ||||||
|                              arg2_val)                                       \ |       arg2_name, arg2_val) \ | ||||||
|   cef_trace_event_instant(category, name, arg1_name, arg1_val, arg2_name, \ |   cef_trace_event_instant(category, name, arg1_name, arg1_val, arg2_name, \ | ||||||
|       arg2_val, false) |       arg2_val, false) | ||||||
| #define TRACE_EVENT_COPY_INSTANT0(category, name) \ | #define TRACE_EVENT_COPY_INSTANT0(category, name) \ | ||||||
| @@ -215,8 +218,8 @@ | |||||||
|   cef_trace_event_begin(category, name, NULL, 0, NULL, 0, false) |   cef_trace_event_begin(category, name, NULL, 0, NULL, 0, false) | ||||||
| #define TRACE_EVENT_BEGIN1(category, name, arg1_name, arg1_val) \ | #define TRACE_EVENT_BEGIN1(category, name, arg1_name, arg1_val) \ | ||||||
|   cef_trace_event_begin(category, name, arg1_name, arg1_val, NULL, 0, false) |   cef_trace_event_begin(category, name, arg1_name, arg1_val, NULL, 0, false) | ||||||
| #define TRACE_EVENT_BEGIN2(category, name, arg1_name, arg1_val, arg2_name, \ | #define TRACE_EVENT_BEGIN2(category, name, arg1_name, arg1_val, \ | ||||||
|                            arg2_val)                                       \ |       arg2_name, arg2_val) \ | ||||||
|   cef_trace_event_begin(category, name, arg1_name, arg1_val, arg2_name, \ |   cef_trace_event_begin(category, name, arg1_name, arg1_val, arg2_name, \ | ||||||
|       arg2_val, false) |       arg2_val, false) | ||||||
| #define TRACE_EVENT_COPY_BEGIN0(category, name) \ | #define TRACE_EVENT_COPY_BEGIN0(category, name) \ | ||||||
| @@ -236,16 +239,16 @@ | |||||||
|   cef_trace_event_end(category, name, NULL, 0, NULL, 0, false) |   cef_trace_event_end(category, name, NULL, 0, NULL, 0, false) | ||||||
| #define TRACE_EVENT_END1(category, name, arg1_name, arg1_val) \ | #define TRACE_EVENT_END1(category, name, arg1_name, arg1_val) \ | ||||||
|   cef_trace_event_end(category, name, arg1_name, arg1_val, NULL, 0, false) |   cef_trace_event_end(category, name, arg1_name, arg1_val, NULL, 0, false) | ||||||
| #define TRACE_EVENT_END2(category, name, arg1_name, arg1_val, arg2_name, \ | #define TRACE_EVENT_END2(category, name, arg1_name, arg1_val, \ | ||||||
|                          arg2_val)                                       \ |       arg2_name, arg2_val) \ | ||||||
|   cef_trace_event_end(category, name, arg1_name, arg1_val, arg2_name, \ |   cef_trace_event_end(category, name, arg1_name, arg1_val, arg2_name, \ | ||||||
|       arg2_val, false) |       arg2_val, false) | ||||||
| #define TRACE_EVENT_COPY_END0(category, name) \ | #define TRACE_EVENT_COPY_END0(category, name) \ | ||||||
|   cef_trace_event_end(category, name, NULL, 0, NULL, 0, true) |   cef_trace_event_end(category, name, NULL, 0, NULL, 0, true) | ||||||
| #define TRACE_EVENT_COPY_END1(category, name, arg1_name, arg1_val) \ | #define TRACE_EVENT_COPY_END1(category, name, arg1_name, arg1_val) \ | ||||||
|   cef_trace_event_end(category, name, arg1_name, arg1_val, NULL, 0, true) |   cef_trace_event_end(category, name, arg1_name, arg1_val, NULL, 0, true) | ||||||
| #define TRACE_EVENT_COPY_END2(category, name, arg1_name, arg1_val, arg2_name, \ | #define TRACE_EVENT_COPY_END2(category, name, arg1_name, arg1_val, \ | ||||||
|                               arg2_val)                                       \ |       arg2_name, arg2_val) \ | ||||||
|   cef_trace_event_end(category, name, arg1_name, arg1_val, arg2_name, \ |   cef_trace_event_end(category, name, arg1_name, arg1_val, arg2_name, \ | ||||||
|       arg2_val, true) |       arg2_val, true) | ||||||
|  |  | ||||||
| @@ -263,8 +266,8 @@ | |||||||
| // values as a stacked-bar chart. | // values as a stacked-bar chart. | ||||||
| // - category and name strings must have application lifetime (statics or | // - category and name strings must have application lifetime (statics or | ||||||
| //   literals). They may not include " chars. | //   literals). They may not include " chars. | ||||||
| #define TRACE_COUNTER2(category, name, value1_name, value1_val, value2_name, \ | #define TRACE_COUNTER2(category, name, value1_name, value1_val, \ | ||||||
|                        value2_val)                                           \ |       value2_name, value2_val) \ | ||||||
|   cef_trace_counter(category, name, value1_name, value1_val, value2_name, \ |   cef_trace_counter(category, name, value1_name, value1_val, value2_name, \ | ||||||
|       value2_val, false) |       value2_val, false) | ||||||
| #define TRACE_COPY_COUNTER2(category, name, value1_name, value1_val, \ | #define TRACE_COPY_COUNTER2(category, name, value1_name, value1_val, \ | ||||||
| @@ -298,11 +301,12 @@ | |||||||
|       value2_name, value2_val) \ |       value2_name, value2_val) \ | ||||||
|   cef_trace_counter_id(category, name, id, value1_name, value1_val, \ |   cef_trace_counter_id(category, name, id, value1_name, value1_val, \ | ||||||
|       value2_name, value2_val, false) |       value2_name, value2_val, false) | ||||||
| #define TRACE_COPY_COUNTER_ID2(category, name, id, value1_name, value1_val, \ | #define TRACE_COPY_COUNTER_ID2(category, name, id, value1_name, \ | ||||||
|                                value2_name, value2_val)                     \ |       value1_val, value2_name, value2_val) \ | ||||||
|   cef_trace_counter_id(category, name, id, value1_name, value1_val, \ |   cef_trace_counter_id(category, name, id, value1_name, value1_val, \ | ||||||
|       value2_name, value2_val, true) |       value2_name, value2_val, true) | ||||||
|  |  | ||||||
|  |  | ||||||
| // Records a single ASYNC_BEGIN event called "name" immediately, with 0, 1 or 2 | // Records a single ASYNC_BEGIN event called "name" immediately, with 0, 1 or 2 | ||||||
| // associated arguments. If the category is not enabled, then this | // associated arguments. If the category is not enabled, then this | ||||||
| // does nothing. | // does nothing. | ||||||
| @@ -330,11 +334,12 @@ | |||||||
|       arg2_name, arg2_val, false) |       arg2_name, arg2_val, false) | ||||||
| #define TRACE_EVENT_COPY_ASYNC_BEGIN0(category, name, id) \ | #define TRACE_EVENT_COPY_ASYNC_BEGIN0(category, name, id) \ | ||||||
|   cef_trace_event_async_begin(category, name, id, NULL, 0, NULL, 0, true) |   cef_trace_event_async_begin(category, name, id, NULL, 0, NULL, 0, true) | ||||||
| #define TRACE_EVENT_COPY_ASYNC_BEGIN1(category, name, id, arg1_name, arg1_val) \ | #define TRACE_EVENT_COPY_ASYNC_BEGIN1(category, name, id, arg1_name, \ | ||||||
|  |       arg1_val) \ | ||||||
|   cef_trace_event_async_begin(category, name, id, arg1_name, arg1_val, NULL, \ |   cef_trace_event_async_begin(category, name, id, arg1_name, arg1_val, NULL, \ | ||||||
|       0, true) |       0, true) | ||||||
| #define TRACE_EVENT_COPY_ASYNC_BEGIN2(category, name, id, arg1_name, arg1_val, \ | #define TRACE_EVENT_COPY_ASYNC_BEGIN2(category, name, id, arg1_name, \ | ||||||
|                                       arg2_name, arg2_val)                     \ |       arg1_val, arg2_name, arg2_val) \ | ||||||
|   cef_trace_event_async_begin(category, name, id, arg1_name, arg1_val, \ |   cef_trace_event_async_begin(category, name, id, arg1_name, arg1_val, \ | ||||||
|       arg2_name, arg2_val, true) |       arg2_name, arg2_val, true) | ||||||
|  |  | ||||||
| @@ -346,14 +351,14 @@ | |||||||
| // ASYNC_STEP_PAST events. | // ASYNC_STEP_PAST events. | ||||||
| #define TRACE_EVENT_ASYNC_STEP_INTO0(category, name, id, step) \ | #define TRACE_EVENT_ASYNC_STEP_INTO0(category, name, id, step) \ | ||||||
|   cef_trace_event_async_step_into(category, name, id, step, NULL, 0, false) |   cef_trace_event_async_step_into(category, name, id, step, NULL, 0, false) | ||||||
| #define TRACE_EVENT_ASYNC_STEP_INTO1(category, name, id, step, arg1_name, \ | #define TRACE_EVENT_ASYNC_STEP_INTO1(category, name, id, step, \ | ||||||
|                                      arg1_val)                            \ |       arg1_name, arg1_val) \ | ||||||
|   cef_trace_event_async_step_into(category, name, id, step, arg1_name, \ |   cef_trace_event_async_step_into(category, name, id, step, arg1_name, \ | ||||||
|       arg1_val, false) |       arg1_val, false) | ||||||
| #define TRACE_EVENT_COPY_ASYNC_STEP_INTO0(category, name, id, step) \ | #define TRACE_EVENT_COPY_ASYNC_STEP_INTO0(category, name, id, step) \ | ||||||
|   cef_trace_event_async_step_into(category, name, id, step, NULL, 0, true) |   cef_trace_event_async_step_into(category, name, id, step, NULL, 0, true) | ||||||
| #define TRACE_EVENT_COPY_ASYNC_STEP_INTO1(category, name, id, step, arg1_name, \ | #define TRACE_EVENT_COPY_ASYNC_STEP_INTO1(category, name, id, step, \ | ||||||
|                                           arg1_val)                            \ |       arg1_name, arg1_val) \ | ||||||
|   cef_trace_event_async_step_into(category, name, id, step, arg1_name, \ |   cef_trace_event_async_step_into(category, name, id, step, arg1_name, \ | ||||||
|       arg1_val, true) |       arg1_val, true) | ||||||
|  |  | ||||||
| @@ -365,14 +370,14 @@ | |||||||
| // ASYNC_STEP_INTO events. | // ASYNC_STEP_INTO events. | ||||||
| #define TRACE_EVENT_ASYNC_STEP_PAST0(category, name, id, step) \ | #define TRACE_EVENT_ASYNC_STEP_PAST0(category, name, id, step) \ | ||||||
|   cef_trace_event_async_step_past(category, name, id, step, NULL, 0, false) |   cef_trace_event_async_step_past(category, name, id, step, NULL, 0, false) | ||||||
| #define TRACE_EVENT_ASYNC_STEP_PAST1(category, name, id, step, arg1_name, \ | #define TRACE_EVENT_ASYNC_STEP_PAST1(category, name, id, step, \ | ||||||
|                                      arg1_val)                            \ |       arg1_name, arg1_val) \ | ||||||
|   cef_trace_event_async_step_past(category, name, id, step, arg1_name, \ |   cef_trace_event_async_step_past(category, name, id, step, arg1_name, \ | ||||||
|       arg1_val, false) |       arg1_val, false) | ||||||
| #define TRACE_EVENT_COPY_ASYNC_STEP_PAST0(category, name, id, step) \ | #define TRACE_EVENT_COPY_ASYNC_STEP_PAST0(category, name, id, step) \ | ||||||
|   cef_trace_event_async_step_past(category, name, id, step, NULL, 0, true) |   cef_trace_event_async_step_past(category, name, id, step, NULL, 0, true) | ||||||
| #define TRACE_EVENT_COPY_ASYNC_STEP_PAST1(category, name, id, step, arg1_name, \ | #define TRACE_EVENT_COPY_ASYNC_STEP_PAST1(category, name, id, step, \ | ||||||
|                                           arg1_val)                            \ |       arg1_name, arg1_val) \ | ||||||
|   cef_trace_event_async_step_past(category, name, id, step, arg1_name, \ |   cef_trace_event_async_step_past(category, name, id, step, arg1_name, \ | ||||||
|       arg1_val, true) |       arg1_val, true) | ||||||
|  |  | ||||||
| @@ -389,11 +394,12 @@ | |||||||
|       arg2_name, arg2_val, false) |       arg2_name, arg2_val, false) | ||||||
| #define TRACE_EVENT_COPY_ASYNC_END0(category, name, id) \ | #define TRACE_EVENT_COPY_ASYNC_END0(category, name, id) \ | ||||||
|   cef_trace_event_async_end(category, name, id, NULL, 0, NULL, 0, true) |   cef_trace_event_async_end(category, name, id, NULL, 0, NULL, 0, true) | ||||||
| #define TRACE_EVENT_COPY_ASYNC_END1(category, name, id, arg1_name, arg1_val)  \ | #define TRACE_EVENT_COPY_ASYNC_END1(category, name, id, arg1_name, \ | ||||||
|  |       arg1_val) \ | ||||||
|   cef_trace_event_async_end(category, name, id, arg1_name, arg1_val, NULL, 0, \ |   cef_trace_event_async_end(category, name, id, arg1_name, arg1_val, NULL, 0, \ | ||||||
|       true) |       true) | ||||||
| #define TRACE_EVENT_COPY_ASYNC_END2(category, name, id, arg1_name, arg1_val, \ | #define TRACE_EVENT_COPY_ASYNC_END2(category, name, id, arg1_name, \ | ||||||
|                                     arg2_name, arg2_val)                     \ |       arg1_val, arg2_name, arg2_val) \ | ||||||
|   cef_trace_event_async_end(category, name, id, arg1_name, arg1_val, \ |   cef_trace_event_async_end(category, name, id, arg1_name, arg1_val, \ | ||||||
|       arg2_name, arg2_val, true) |       arg2_name, arg2_val, true) | ||||||
|  |  | ||||||
| @@ -403,7 +409,8 @@ namespace cef_trace_event { | |||||||
| class CefTraceEndOnScopeClose { | class CefTraceEndOnScopeClose { | ||||||
|  public: |  public: | ||||||
|   CefTraceEndOnScopeClose(const char* category, const char* name) |   CefTraceEndOnScopeClose(const char* category, const char* name) | ||||||
|       : category_(category), name_(name) {} |       : category_(category), name_(name) { | ||||||
|  |   } | ||||||
|   ~CefTraceEndOnScopeClose() { |   ~CefTraceEndOnScopeClose() { | ||||||
|     cef_trace_event_end(category_, name_, NULL, 0, NULL, 0, false); |     cef_trace_event_end(category_, name_, NULL, 0, NULL, 0, false); | ||||||
|   } |   } | ||||||
|   | |||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -117,10 +117,8 @@ | |||||||
|  |  | ||||||
| namespace base { | namespace base { | ||||||
|  |  | ||||||
| template <typename T> | template <typename T> class SupportsWeakPtr; | ||||||
| class SupportsWeakPtr; | template <typename T> class WeakPtr; | ||||||
| template <typename T> |  | ||||||
| class WeakPtr; |  | ||||||
|  |  | ||||||
| namespace cef_internal { | namespace cef_internal { | ||||||
| // These classes are part of the WeakPtr implementation. | // These classes are part of the WeakPtr implementation. | ||||||
| @@ -166,7 +164,9 @@ class WeakReferenceOwner { | |||||||
|  |  | ||||||
|   WeakReference GetRef() const; |   WeakReference GetRef() const; | ||||||
|  |  | ||||||
|   bool HasRefs() const { return flag_.get() && !flag_->HasOneRef(); } |   bool HasRefs() const { | ||||||
|  |     return flag_.get() && !flag_->HasOneRef(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|   void Invalidate(); |   void Invalidate(); | ||||||
|  |  | ||||||
| @@ -200,8 +200,8 @@ class SupportsWeakPtrBase { | |||||||
|   // function that makes calling this easier. |   // function that makes calling this easier. | ||||||
|   template<typename Derived> |   template<typename Derived> | ||||||
|   static WeakPtr<Derived> StaticAsWeakPtr(Derived* t) { |   static WeakPtr<Derived> StaticAsWeakPtr(Derived* t) { | ||||||
|     typedef is_convertible<Derived, cef_internal::SupportsWeakPtrBase&> |     typedef | ||||||
|         convertible; |         is_convertible<Derived, cef_internal::SupportsWeakPtrBase&> convertible; | ||||||
|     COMPILE_ASSERT(convertible::value, |     COMPILE_ASSERT(convertible::value, | ||||||
|                    AsWeakPtr_argument_inherits_from_SupportsWeakPtr); |                    AsWeakPtr_argument_inherits_from_SupportsWeakPtr); | ||||||
|     return AsWeakPtrImpl<Derived>(t, *t); |     return AsWeakPtrImpl<Derived>(t, *t); | ||||||
| @@ -212,8 +212,8 @@ class SupportsWeakPtrBase { | |||||||
|   // which is an instance of SupportsWeakPtr<Base>. We can then safely |   // which is an instance of SupportsWeakPtr<Base>. We can then safely | ||||||
|   // static_cast the Base* to a Derived*. |   // static_cast the Base* to a Derived*. | ||||||
|   template <typename Derived, typename Base> |   template <typename Derived, typename Base> | ||||||
|   static WeakPtr<Derived> AsWeakPtrImpl(Derived* t, |   static WeakPtr<Derived> AsWeakPtrImpl( | ||||||
|                                         const SupportsWeakPtr<Base>&) { |       Derived* t, const SupportsWeakPtr<Base>&) { | ||||||
|     WeakPtr<Base> ptr = t->Base::AsWeakPtr(); |     WeakPtr<Base> ptr = t->Base::AsWeakPtr(); | ||||||
|     return WeakPtr<Derived>(ptr.ref_, static_cast<Derived*>(ptr.ptr_)); |     return WeakPtr<Derived>(ptr.ref_, static_cast<Derived*>(ptr.ptr_)); | ||||||
|   } |   } | ||||||
| @@ -221,8 +221,7 @@ class SupportsWeakPtrBase { | |||||||
|  |  | ||||||
| }  // namespace cef_internal | }  // namespace cef_internal | ||||||
|  |  | ||||||
| template <typename T> | template <typename T> class WeakPtrFactory; | ||||||
| class WeakPtrFactory; |  | ||||||
|  |  | ||||||
| // The WeakPtr class holds a weak reference to |T*|. | // The WeakPtr class holds a weak reference to |T*|. | ||||||
| // | // | ||||||
| @@ -240,12 +239,14 @@ class WeakPtrFactory; | |||||||
| template <typename T> | template <typename T> | ||||||
| class WeakPtr : public cef_internal::WeakPtrBase { | class WeakPtr : public cef_internal::WeakPtrBase { | ||||||
|  public: |  public: | ||||||
|   WeakPtr() : ptr_(NULL) {} |   WeakPtr() : ptr_(NULL) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   // Allow conversion from U to T provided U "is a" T. Note that this |   // Allow conversion from U to T provided U "is a" T. Note that this | ||||||
|   // is separate from the (implicit) copy constructor. |   // is separate from the (implicit) copy constructor. | ||||||
|   template <typename U> |   template <typename U> | ||||||
|   WeakPtr(const WeakPtr<U>& other) : WeakPtrBase(other), ptr_(other.ptr_) {} |   WeakPtr(const WeakPtr<U>& other) : WeakPtrBase(other), ptr_(other.ptr_) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   T* get() const { return ref_.is_valid() ? ptr_ : NULL; } |   T* get() const { return ref_.is_valid() ? ptr_ : NULL; } | ||||||
|  |  | ||||||
| @@ -279,19 +280,18 @@ class WeakPtr : public cef_internal::WeakPtrBase { | |||||||
|  private: |  private: | ||||||
|   // Explicitly declare comparison operators as required by the bool |   // Explicitly declare comparison operators as required by the bool | ||||||
|   // trick, but keep them private. |   // trick, but keep them private. | ||||||
|   template <class U> |   template <class U> bool operator==(WeakPtr<U> const&) const; | ||||||
|   bool operator==(WeakPtr<U> const&) const; |   template <class U> bool operator!=(WeakPtr<U> const&) const; | ||||||
|   template <class U> |  | ||||||
|   bool operator!=(WeakPtr<U> const&) const; |  | ||||||
|  |  | ||||||
|   friend class cef_internal::SupportsWeakPtrBase; |   friend class cef_internal::SupportsWeakPtrBase; | ||||||
|   template <typename U> |   template <typename U> friend class WeakPtr; | ||||||
|   friend class WeakPtr; |  | ||||||
|   friend class SupportsWeakPtr<T>; |   friend class SupportsWeakPtr<T>; | ||||||
|   friend class WeakPtrFactory<T>; |   friend class WeakPtrFactory<T>; | ||||||
|  |  | ||||||
|   WeakPtr(const cef_internal::WeakReference& ref, T* ptr) |   WeakPtr(const cef_internal::WeakReference& ref, T* ptr) | ||||||
|       : WeakPtrBase(ref), ptr_(ptr) {} |       : WeakPtrBase(ref), | ||||||
|  |         ptr_(ptr) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   // This pointer is only valid when ref_.is_valid() is true.  Otherwise, its |   // This pointer is only valid when ref_.is_valid() is true.  Otherwise, its | ||||||
|   // value is undefined (as opposed to NULL). |   // value is undefined (as opposed to NULL). | ||||||
| @@ -306,9 +306,12 @@ class WeakPtr : public cef_internal::WeakPtrBase { | |||||||
| template <class T> | template <class T> | ||||||
| class WeakPtrFactory { | class WeakPtrFactory { | ||||||
|  public: |  public: | ||||||
|   explicit WeakPtrFactory(T* ptr) : ptr_(ptr) {} |   explicit WeakPtrFactory(T* ptr) : ptr_(ptr) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   ~WeakPtrFactory() { ptr_ = NULL; } |   ~WeakPtrFactory() { | ||||||
|  |     ptr_ = NULL; | ||||||
|  |   } | ||||||
|  |  | ||||||
|   WeakPtr<T> GetWeakPtr() { |   WeakPtr<T> GetWeakPtr() { | ||||||
|     DCHECK(ptr_); |     DCHECK(ptr_); | ||||||
|   | |||||||
| @@ -103,8 +103,7 @@ inline Atomic32 NoBarrier_CompareAndSwap(volatile Atomic32* ptr, | |||||||
|     //   reloop = 0 |     //   reloop = 0 | ||||||
|     //   if (prev_value != old_value) |     //   if (prev_value != old_value) | ||||||
|     //      reloop = STREX(ptr, new_value) |     //      reloop = STREX(ptr, new_value) | ||||||
|     __asm__ __volatile__( |     __asm__ __volatile__("    ldrex %0, [%3]\n" | ||||||
|         "    ldrex %0, [%3]\n" |  | ||||||
|                          "    mov %1, #0\n" |                          "    mov %1, #0\n" | ||||||
|                          "    cmp %0, %4\n" |                          "    cmp %0, %4\n" | ||||||
| #ifdef __thumb2__ | #ifdef __thumb2__ | ||||||
| @@ -144,8 +143,7 @@ inline Atomic32 NoBarrier_AtomicIncrement(volatile Atomic32* ptr, | |||||||
|     //  value += increment |     //  value += increment | ||||||
|     //  reloop = STREX(ptr, value) |     //  reloop = STREX(ptr, value) | ||||||
|     // |     // | ||||||
|     __asm__ __volatile__( |     __asm__ __volatile__("    ldrex %0, [%3]\n" | ||||||
|         "    ldrex %0, [%3]\n" |  | ||||||
|                          "    add %0, %0, %4\n" |                          "    add %0, %0, %4\n" | ||||||
|                          "    strex %1, %0, [%3]\n" |                          "    strex %1, %0, [%3]\n" | ||||||
|                          : "=&r"(value), "=&r"(reloop), "+m"(*ptr) |                          : "=&r"(value), "=&r"(reloop), "+m"(*ptr) | ||||||
| @@ -173,8 +171,7 @@ inline Atomic32 NoBarrier_AtomicExchange(volatile Atomic32* ptr, | |||||||
|   do { |   do { | ||||||
|     // old_value = LDREX(ptr) |     // old_value = LDREX(ptr) | ||||||
|     // reloop = STREX(ptr, new_value) |     // reloop = STREX(ptr, new_value) | ||||||
|     __asm__ __volatile__( |     __asm__ __volatile__("   ldrex %0, [%3]\n" | ||||||
|         "   ldrex %0, [%3]\n" |  | ||||||
|                          "   strex %1, %4, [%3]\n" |                          "   strex %1, %4, [%3]\n" | ||||||
|                          : "=&r"(old_value), "=&r"(reloop), "+m"(*ptr) |                          : "=&r"(old_value), "=&r"(reloop), "+m"(*ptr) | ||||||
|                          : "r"(ptr), "r"(new_value) |                          : "r"(ptr), "r"(new_value) | ||||||
| @@ -304,9 +301,7 @@ inline void Release_Store(volatile Atomic32* ptr, Atomic32 value) { | |||||||
|   *ptr = value; |   *ptr = value; | ||||||
| } | } | ||||||
|  |  | ||||||
| inline Atomic32 NoBarrier_Load(volatile const Atomic32* ptr) { | inline Atomic32 NoBarrier_Load(volatile const Atomic32* ptr) { return *ptr; } | ||||||
|   return *ptr; |  | ||||||
| } |  | ||||||
|  |  | ||||||
| inline Atomic32 Acquire_Load(volatile const Atomic32* ptr) { | inline Atomic32 Acquire_Load(volatile const Atomic32* ptr) { | ||||||
|   Atomic32 value = *ptr; |   Atomic32 value = *ptr; | ||||||
|   | |||||||
| @@ -52,26 +52,26 @@ namespace subtle { | |||||||
| inline AtomicWord NoBarrier_CompareAndSwap(volatile AtomicWord* ptr, | inline AtomicWord NoBarrier_CompareAndSwap(volatile AtomicWord* ptr, | ||||||
|                                            AtomicWord old_value, |                                            AtomicWord old_value, | ||||||
|                                            AtomicWord new_value) { |                                            AtomicWord new_value) { | ||||||
|   return NoBarrier_CompareAndSwap(reinterpret_cast<volatile Atomic32*>(ptr), |   return NoBarrier_CompareAndSwap( | ||||||
|                                   old_value, new_value); |       reinterpret_cast<volatile Atomic32*>(ptr), old_value, new_value); | ||||||
| } | } | ||||||
|  |  | ||||||
| inline AtomicWord NoBarrier_AtomicExchange(volatile AtomicWord* ptr, | inline AtomicWord NoBarrier_AtomicExchange(volatile AtomicWord* ptr, | ||||||
|                                            AtomicWord new_value) { |                                            AtomicWord new_value) { | ||||||
|   return NoBarrier_AtomicExchange(reinterpret_cast<volatile Atomic32*>(ptr), |   return NoBarrier_AtomicExchange( | ||||||
|                                   new_value); |       reinterpret_cast<volatile Atomic32*>(ptr), new_value); | ||||||
| } | } | ||||||
|  |  | ||||||
| inline AtomicWord NoBarrier_AtomicIncrement(volatile AtomicWord* ptr, | inline AtomicWord NoBarrier_AtomicIncrement(volatile AtomicWord* ptr, | ||||||
|                                             AtomicWord increment) { |                                             AtomicWord increment) { | ||||||
|   return NoBarrier_AtomicIncrement(reinterpret_cast<volatile Atomic32*>(ptr), |   return NoBarrier_AtomicIncrement( | ||||||
|                                    increment); |       reinterpret_cast<volatile Atomic32*>(ptr), increment); | ||||||
| } | } | ||||||
|  |  | ||||||
| inline AtomicWord Barrier_AtomicIncrement(volatile AtomicWord* ptr, | inline AtomicWord Barrier_AtomicIncrement(volatile AtomicWord* ptr, | ||||||
|                                           AtomicWord increment) { |                                           AtomicWord increment) { | ||||||
|   return Barrier_AtomicIncrement(reinterpret_cast<volatile Atomic32*>(ptr), |   return Barrier_AtomicIncrement( | ||||||
|                                  increment); |       reinterpret_cast<volatile Atomic32*>(ptr), increment); | ||||||
| } | } | ||||||
|  |  | ||||||
| inline AtomicWord Acquire_CompareAndSwap(volatile AtomicWord* ptr, | inline AtomicWord Acquire_CompareAndSwap(volatile AtomicWord* ptr, | ||||||
| @@ -89,21 +89,23 @@ inline AtomicWord Release_CompareAndSwap(volatile AtomicWord* ptr, | |||||||
| } | } | ||||||
|  |  | ||||||
| inline void NoBarrier_Store(volatile AtomicWord *ptr, AtomicWord value) { | inline void NoBarrier_Store(volatile AtomicWord *ptr, AtomicWord value) { | ||||||
|   NoBarrier_Store(reinterpret_cast<volatile Atomic32*>(ptr), value); |   NoBarrier_Store( | ||||||
|  |       reinterpret_cast<volatile Atomic32*>(ptr), value); | ||||||
| } | } | ||||||
|  |  | ||||||
| inline void Acquire_Store(volatile AtomicWord* ptr, AtomicWord value) { | inline void Acquire_Store(volatile AtomicWord* ptr, AtomicWord value) { | ||||||
|   return base::subtle::Acquire_Store(reinterpret_cast<volatile Atomic32*>(ptr), |   return base::subtle::Acquire_Store( | ||||||
|                                      value); |       reinterpret_cast<volatile Atomic32*>(ptr), value); | ||||||
| } | } | ||||||
|  |  | ||||||
| inline void Release_Store(volatile AtomicWord* ptr, AtomicWord value) { | inline void Release_Store(volatile AtomicWord* ptr, AtomicWord value) { | ||||||
|   return base::subtle::Release_Store(reinterpret_cast<volatile Atomic32*>(ptr), |   return base::subtle::Release_Store( | ||||||
|                                      value); |       reinterpret_cast<volatile Atomic32*>(ptr), value); | ||||||
| } | } | ||||||
|  |  | ||||||
| inline AtomicWord NoBarrier_Load(volatile const AtomicWord *ptr) { | inline AtomicWord NoBarrier_Load(volatile const AtomicWord *ptr) { | ||||||
|   return NoBarrier_Load(reinterpret_cast<volatile const Atomic32*>(ptr)); |   return NoBarrier_Load( | ||||||
|  |       reinterpret_cast<volatile const Atomic32*>(ptr)); | ||||||
| } | } | ||||||
|  |  | ||||||
| inline AtomicWord Acquire_Load(volatile const AtomicWord* ptr) { | inline AtomicWord Acquire_Load(volatile const AtomicWord* ptr) { | ||||||
|   | |||||||
| @@ -41,7 +41,8 @@ struct AtomicOps_x86CPUFeatureStruct { | |||||||
|   bool has_amd_lock_mb_bug; // Processor has AMD memory-barrier bug; do lfence |   bool has_amd_lock_mb_bug; // Processor has AMD memory-barrier bug; do lfence | ||||||
|                             // after acquire compare-and-swap. |                             // after acquire compare-and-swap. | ||||||
| }; | }; | ||||||
| extern struct AtomicOps_x86CPUFeatureStruct AtomicOps_Internalx86CPUFeatures; | extern struct AtomicOps_x86CPUFeatureStruct | ||||||
|  |     AtomicOps_Internalx86CPUFeatures; | ||||||
|  |  | ||||||
| #define ATOMICOPS_COMPILER_BARRIER() __asm__ __volatile__("" : : : "memory") | #define ATOMICOPS_COMPILER_BARRIER() __asm__ __volatile__("" : : : "memory") | ||||||
|  |  | ||||||
| @@ -75,8 +76,7 @@ inline Atomic32 NoBarrier_AtomicIncrement(volatile Atomic32* ptr, | |||||||
|   Atomic32 temp = increment; |   Atomic32 temp = increment; | ||||||
|   __asm__ __volatile__("lock; xaddl %0,%1" |   __asm__ __volatile__("lock; xaddl %0,%1" | ||||||
|                        : "+r" (temp), "+m" (*ptr) |                        : "+r" (temp), "+m" (*ptr) | ||||||
|                        : |                        : : "memory"); | ||||||
|                        : "memory"); |  | ||||||
|   // temp now holds the old value of *ptr |   // temp now holds the old value of *ptr | ||||||
|   return temp + increment; |   return temp + increment; | ||||||
| } | } | ||||||
| @@ -86,8 +86,7 @@ inline Atomic32 Barrier_AtomicIncrement(volatile Atomic32* ptr, | |||||||
|   Atomic32 temp = increment; |   Atomic32 temp = increment; | ||||||
|   __asm__ __volatile__("lock; xaddl %0,%1" |   __asm__ __volatile__("lock; xaddl %0,%1" | ||||||
|                        : "+r" (temp), "+m" (*ptr) |                        : "+r" (temp), "+m" (*ptr) | ||||||
|                        : |                        : : "memory"); | ||||||
|                        : "memory"); |  | ||||||
|   // temp now holds the old value of *ptr |   // temp now holds the old value of *ptr | ||||||
|   if (AtomicOps_Internalx86CPUFeatures.has_amd_lock_mb_bug) { |   if (AtomicOps_Internalx86CPUFeatures.has_amd_lock_mb_bug) { | ||||||
|     __asm__ __volatile__("lfence" : : : "memory"); |     __asm__ __volatile__("lfence" : : : "memory"); | ||||||
| @@ -175,8 +174,7 @@ inline Atomic64 NoBarrier_AtomicIncrement(volatile Atomic64* ptr, | |||||||
|   Atomic64 temp = increment; |   Atomic64 temp = increment; | ||||||
|   __asm__ __volatile__("lock; xaddq %0,%1" |   __asm__ __volatile__("lock; xaddq %0,%1" | ||||||
|                        : "+r" (temp), "+m" (*ptr) |                        : "+r" (temp), "+m" (*ptr) | ||||||
|                        : |                        : : "memory"); | ||||||
|                        : "memory"); |  | ||||||
|   // temp now contains the previous value of *ptr |   // temp now contains the previous value of *ptr | ||||||
|   return temp + increment; |   return temp + increment; | ||||||
| } | } | ||||||
| @@ -186,8 +184,7 @@ inline Atomic64 Barrier_AtomicIncrement(volatile Atomic64* ptr, | |||||||
|   Atomic64 temp = increment; |   Atomic64 temp = increment; | ||||||
|   __asm__ __volatile__("lock; xaddq %0,%1" |   __asm__ __volatile__("lock; xaddq %0,%1" | ||||||
|                        : "+r" (temp), "+m" (*ptr) |                        : "+r" (temp), "+m" (*ptr) | ||||||
|                        : |                        : : "memory"); | ||||||
|                        : "memory"); |  | ||||||
|   // temp now contains the previous value of *ptr |   // temp now contains the previous value of *ptr | ||||||
|   if (AtomicOps_Internalx86CPUFeatures.has_amd_lock_mb_bug) { |   if (AtomicOps_Internalx86CPUFeatures.has_amd_lock_mb_bug) { | ||||||
|     __asm__ __volatile__("lfence" : : : "memory"); |     __asm__ __volatile__("lfence" : : : "memory"); | ||||||
|   | |||||||
| @@ -55,23 +55,25 @@ inline Atomic32 NoBarrier_CompareAndSwap(volatile Atomic32* ptr, | |||||||
|                                          Atomic32 old_value, |                                          Atomic32 old_value, | ||||||
|                                          Atomic32 new_value) { |                                          Atomic32 new_value) { | ||||||
|   LONG result = _InterlockedCompareExchange( |   LONG result = _InterlockedCompareExchange( | ||||||
|       reinterpret_cast<volatile LONG*>(ptr), static_cast<LONG>(new_value), |       reinterpret_cast<volatile LONG*>(ptr), | ||||||
|  |       static_cast<LONG>(new_value), | ||||||
|       static_cast<LONG>(old_value)); |       static_cast<LONG>(old_value)); | ||||||
|   return static_cast<Atomic32>(result); |   return static_cast<Atomic32>(result); | ||||||
| } | } | ||||||
|  |  | ||||||
| inline Atomic32 NoBarrier_AtomicExchange(volatile Atomic32* ptr, | inline Atomic32 NoBarrier_AtomicExchange(volatile Atomic32* ptr, | ||||||
|                                          Atomic32 new_value) { |                                          Atomic32 new_value) { | ||||||
|   LONG result = _InterlockedExchange(reinterpret_cast<volatile LONG*>(ptr), |   LONG result = _InterlockedExchange( | ||||||
|  |       reinterpret_cast<volatile LONG*>(ptr), | ||||||
|       static_cast<LONG>(new_value)); |       static_cast<LONG>(new_value)); | ||||||
|   return static_cast<Atomic32>(result); |   return static_cast<Atomic32>(result); | ||||||
| } | } | ||||||
|  |  | ||||||
| inline Atomic32 Barrier_AtomicIncrement(volatile Atomic32* ptr, | inline Atomic32 Barrier_AtomicIncrement(volatile Atomic32* ptr, | ||||||
|                                         Atomic32 increment) { |                                         Atomic32 increment) { | ||||||
|   return _InterlockedExchangeAdd(reinterpret_cast<volatile LONG*>(ptr), |   return _InterlockedExchangeAdd( | ||||||
|                                  static_cast<LONG>(increment)) + |       reinterpret_cast<volatile LONG*>(ptr), | ||||||
|          increment; |       static_cast<LONG>(increment)) + increment; | ||||||
| } | } | ||||||
|  |  | ||||||
| inline Atomic32 NoBarrier_AtomicIncrement(volatile Atomic32* ptr, | inline Atomic32 NoBarrier_AtomicIncrement(volatile Atomic32* ptr, | ||||||
| @@ -149,17 +151,17 @@ inline Atomic64 NoBarrier_CompareAndSwap(volatile Atomic64* ptr, | |||||||
|  |  | ||||||
| inline Atomic64 NoBarrier_AtomicExchange(volatile Atomic64* ptr, | inline Atomic64 NoBarrier_AtomicExchange(volatile Atomic64* ptr, | ||||||
|                                          Atomic64 new_value) { |                                          Atomic64 new_value) { | ||||||
|   PVOID result = |   PVOID result = InterlockedExchangePointer( | ||||||
|       InterlockedExchangePointer(reinterpret_cast<volatile PVOID*>(ptr), |     reinterpret_cast<volatile PVOID*>(ptr), | ||||||
|     reinterpret_cast<PVOID>(new_value)); |     reinterpret_cast<PVOID>(new_value)); | ||||||
|   return reinterpret_cast<Atomic64>(result); |   return reinterpret_cast<Atomic64>(result); | ||||||
| } | } | ||||||
|  |  | ||||||
| inline Atomic64 Barrier_AtomicIncrement(volatile Atomic64* ptr, | inline Atomic64 Barrier_AtomicIncrement(volatile Atomic64* ptr, | ||||||
|                                         Atomic64 increment) { |                                         Atomic64 increment) { | ||||||
|   return InterlockedExchangeAdd64(reinterpret_cast<volatile LONGLONG*>(ptr), |   return InterlockedExchangeAdd64( | ||||||
|                                   static_cast<LONGLONG>(increment)) + |       reinterpret_cast<volatile LONGLONG*>(ptr), | ||||||
|          increment; |       static_cast<LONGLONG>(increment)) + increment; | ||||||
| } | } | ||||||
|  |  | ||||||
| inline Atomic64 NoBarrier_AtomicIncrement(volatile Atomic64* ptr, | inline Atomic64 NoBarrier_AtomicIncrement(volatile Atomic64* ptr, | ||||||
| @@ -213,6 +215,7 @@ inline Atomic64 Release_CompareAndSwap(volatile Atomic64* ptr, | |||||||
|   return NoBarrier_CompareAndSwap(ptr, old_value, new_value); |   return NoBarrier_CompareAndSwap(ptr, old_value, new_value); | ||||||
| } | } | ||||||
|  |  | ||||||
|  |  | ||||||
| #endif  // defined(_WIN64) | #endif  // defined(_WIN64) | ||||||
|  |  | ||||||
| }  // namespace base::subtle | }  // namespace base::subtle | ||||||
|   | |||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -52,9 +52,13 @@ class RunnableAdapter<R(__stdcall*)()> { | |||||||
|  public: |  public: | ||||||
|   typedef R (RunType)(); |   typedef R (RunType)(); | ||||||
|  |  | ||||||
|   explicit RunnableAdapter(R(__stdcall* function)()) : function_(function) {} |   explicit RunnableAdapter(R(__stdcall *function)()) | ||||||
|  |       : function_(function) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   R Run() { return function_(); } |   R Run() { | ||||||
|  |     return function_(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   R (__stdcall *function_)(); |   R (__stdcall *function_)(); | ||||||
| @@ -66,9 +70,13 @@ class RunnableAdapter<R(__fastcall*)()> { | |||||||
|  public: |  public: | ||||||
|   typedef R (RunType)(); |   typedef R (RunType)(); | ||||||
|  |  | ||||||
|   explicit RunnableAdapter(R(__fastcall* function)()) : function_(function) {} |   explicit RunnableAdapter(R(__fastcall *function)()) | ||||||
|  |       : function_(function) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   R Run() { return function_(); } |   R Run() { | ||||||
|  |     return function_(); | ||||||
|  |   } | ||||||
|  |  | ||||||
|  private: |  private: | ||||||
|   R (__fastcall *function_)(); |   R (__fastcall *function_)(); | ||||||
| @@ -80,7 +88,9 @@ class RunnableAdapter<R(__stdcall*)(A1)> { | |||||||
|  public: |  public: | ||||||
|   typedef R (RunType)(A1); |   typedef R (RunType)(A1); | ||||||
|  |  | ||||||
|   explicit RunnableAdapter(R(__stdcall* function)(A1)) : function_(function) {} |   explicit RunnableAdapter(R(__stdcall *function)(A1)) | ||||||
|  |       : function_(function) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   R Run(typename CallbackParamTraits<A1>::ForwardType a1) { |   R Run(typename CallbackParamTraits<A1>::ForwardType a1) { | ||||||
|     return function_(a1); |     return function_(a1); | ||||||
| @@ -96,7 +106,9 @@ class RunnableAdapter<R(__fastcall*)(A1)> { | |||||||
|  public: |  public: | ||||||
|   typedef R (RunType)(A1); |   typedef R (RunType)(A1); | ||||||
|  |  | ||||||
|   explicit RunnableAdapter(R(__fastcall* function)(A1)) : function_(function) {} |   explicit RunnableAdapter(R(__fastcall *function)(A1)) | ||||||
|  |       : function_(function) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   R Run(typename CallbackParamTraits<A1>::ForwardType a1) { |   R Run(typename CallbackParamTraits<A1>::ForwardType a1) { | ||||||
|     return function_(a1); |     return function_(a1); | ||||||
| @@ -113,7 +125,8 @@ class RunnableAdapter<R(__stdcall*)(A1, A2)> { | |||||||
|   typedef R (RunType)(A1, A2); |   typedef R (RunType)(A1, A2); | ||||||
|  |  | ||||||
|   explicit RunnableAdapter(R(__stdcall *function)(A1, A2)) |   explicit RunnableAdapter(R(__stdcall *function)(A1, A2)) | ||||||
|       : function_(function) {} |       : function_(function) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   R Run(typename CallbackParamTraits<A1>::ForwardType a1, |   R Run(typename CallbackParamTraits<A1>::ForwardType a1, | ||||||
|       typename CallbackParamTraits<A2>::ForwardType a2) { |       typename CallbackParamTraits<A2>::ForwardType a2) { | ||||||
| @@ -131,7 +144,8 @@ class RunnableAdapter<R(__fastcall*)(A1, A2)> { | |||||||
|   typedef R (RunType)(A1, A2); |   typedef R (RunType)(A1, A2); | ||||||
|  |  | ||||||
|   explicit RunnableAdapter(R(__fastcall *function)(A1, A2)) |   explicit RunnableAdapter(R(__fastcall *function)(A1, A2)) | ||||||
|       : function_(function) {} |       : function_(function) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   R Run(typename CallbackParamTraits<A1>::ForwardType a1, |   R Run(typename CallbackParamTraits<A1>::ForwardType a1, | ||||||
|       typename CallbackParamTraits<A2>::ForwardType a2) { |       typename CallbackParamTraits<A2>::ForwardType a2) { | ||||||
| @@ -149,7 +163,8 @@ class RunnableAdapter<R(__stdcall*)(A1, A2, A3)> { | |||||||
|   typedef R (RunType)(A1, A2, A3); |   typedef R (RunType)(A1, A2, A3); | ||||||
|  |  | ||||||
|   explicit RunnableAdapter(R(__stdcall *function)(A1, A2, A3)) |   explicit RunnableAdapter(R(__stdcall *function)(A1, A2, A3)) | ||||||
|       : function_(function) {} |       : function_(function) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   R Run(typename CallbackParamTraits<A1>::ForwardType a1, |   R Run(typename CallbackParamTraits<A1>::ForwardType a1, | ||||||
|       typename CallbackParamTraits<A2>::ForwardType a2, |       typename CallbackParamTraits<A2>::ForwardType a2, | ||||||
| @@ -168,7 +183,8 @@ class RunnableAdapter<R(__fastcall*)(A1, A2, A3)> { | |||||||
|   typedef R (RunType)(A1, A2, A3); |   typedef R (RunType)(A1, A2, A3); | ||||||
|  |  | ||||||
|   explicit RunnableAdapter(R(__fastcall *function)(A1, A2, A3)) |   explicit RunnableAdapter(R(__fastcall *function)(A1, A2, A3)) | ||||||
|       : function_(function) {} |       : function_(function) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   R Run(typename CallbackParamTraits<A1>::ForwardType a1, |   R Run(typename CallbackParamTraits<A1>::ForwardType a1, | ||||||
|       typename CallbackParamTraits<A2>::ForwardType a2, |       typename CallbackParamTraits<A2>::ForwardType a2, | ||||||
| @@ -187,7 +203,8 @@ class RunnableAdapter<R(__stdcall*)(A1, A2, A3, A4)> { | |||||||
|   typedef R (RunType)(A1, A2, A3, A4); |   typedef R (RunType)(A1, A2, A3, A4); | ||||||
|  |  | ||||||
|   explicit RunnableAdapter(R(__stdcall *function)(A1, A2, A3, A4)) |   explicit RunnableAdapter(R(__stdcall *function)(A1, A2, A3, A4)) | ||||||
|       : function_(function) {} |       : function_(function) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   R Run(typename CallbackParamTraits<A1>::ForwardType a1, |   R Run(typename CallbackParamTraits<A1>::ForwardType a1, | ||||||
|       typename CallbackParamTraits<A2>::ForwardType a2, |       typename CallbackParamTraits<A2>::ForwardType a2, | ||||||
| @@ -207,7 +224,8 @@ class RunnableAdapter<R(__fastcall*)(A1, A2, A3, A4)> { | |||||||
|   typedef R (RunType)(A1, A2, A3, A4); |   typedef R (RunType)(A1, A2, A3, A4); | ||||||
|  |  | ||||||
|   explicit RunnableAdapter(R(__fastcall *function)(A1, A2, A3, A4)) |   explicit RunnableAdapter(R(__fastcall *function)(A1, A2, A3, A4)) | ||||||
|       : function_(function) {} |       : function_(function) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   R Run(typename CallbackParamTraits<A1>::ForwardType a1, |   R Run(typename CallbackParamTraits<A1>::ForwardType a1, | ||||||
|       typename CallbackParamTraits<A2>::ForwardType a2, |       typename CallbackParamTraits<A2>::ForwardType a2, | ||||||
| @@ -221,18 +239,15 @@ class RunnableAdapter<R(__fastcall*)(A1, A2, A3, A4)> { | |||||||
| }; | }; | ||||||
|  |  | ||||||
| // __stdcall Function: Arity 5. | // __stdcall Function: Arity 5. | ||||||
| template <typename R, | template <typename R, typename A1, typename A2, typename A3, typename A4, | ||||||
|           typename A1, |  | ||||||
|           typename A2, |  | ||||||
|           typename A3, |  | ||||||
|           typename A4, |  | ||||||
|     typename A5> |     typename A5> | ||||||
| class RunnableAdapter<R(__stdcall *)(A1, A2, A3, A4, A5)> { | class RunnableAdapter<R(__stdcall *)(A1, A2, A3, A4, A5)> { | ||||||
|  public: |  public: | ||||||
|   typedef R (RunType)(A1, A2, A3, A4, A5); |   typedef R (RunType)(A1, A2, A3, A4, A5); | ||||||
|  |  | ||||||
|   explicit RunnableAdapter(R(__stdcall *function)(A1, A2, A3, A4, A5)) |   explicit RunnableAdapter(R(__stdcall *function)(A1, A2, A3, A4, A5)) | ||||||
|       : function_(function) {} |       : function_(function) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   R Run(typename CallbackParamTraits<A1>::ForwardType a1, |   R Run(typename CallbackParamTraits<A1>::ForwardType a1, | ||||||
|       typename CallbackParamTraits<A2>::ForwardType a2, |       typename CallbackParamTraits<A2>::ForwardType a2, | ||||||
| @@ -247,18 +262,15 @@ class RunnableAdapter<R(__stdcall*)(A1, A2, A3, A4, A5)> { | |||||||
| }; | }; | ||||||
|  |  | ||||||
| // __fastcall Function: Arity 5. | // __fastcall Function: Arity 5. | ||||||
| template <typename R, | template <typename R, typename A1, typename A2, typename A3, typename A4, | ||||||
|           typename A1, |  | ||||||
|           typename A2, |  | ||||||
|           typename A3, |  | ||||||
|           typename A4, |  | ||||||
|     typename A5> |     typename A5> | ||||||
| class RunnableAdapter<R(__fastcall *)(A1, A2, A3, A4, A5)> { | class RunnableAdapter<R(__fastcall *)(A1, A2, A3, A4, A5)> { | ||||||
|  public: |  public: | ||||||
|   typedef R (RunType)(A1, A2, A3, A4, A5); |   typedef R (RunType)(A1, A2, A3, A4, A5); | ||||||
|  |  | ||||||
|   explicit RunnableAdapter(R(__fastcall *function)(A1, A2, A3, A4, A5)) |   explicit RunnableAdapter(R(__fastcall *function)(A1, A2, A3, A4, A5)) | ||||||
|       : function_(function) {} |       : function_(function) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   R Run(typename CallbackParamTraits<A1>::ForwardType a1, |   R Run(typename CallbackParamTraits<A1>::ForwardType a1, | ||||||
|       typename CallbackParamTraits<A2>::ForwardType a2, |       typename CallbackParamTraits<A2>::ForwardType a2, | ||||||
| @@ -273,19 +285,15 @@ class RunnableAdapter<R(__fastcall*)(A1, A2, A3, A4, A5)> { | |||||||
| }; | }; | ||||||
|  |  | ||||||
| // __stdcall Function: Arity 6. | // __stdcall Function: Arity 6. | ||||||
| template <typename R, | template <typename R, typename A1, typename A2, typename A3, typename A4, | ||||||
|           typename A1, |     typename A5, typename A6> | ||||||
|           typename A2, |  | ||||||
|           typename A3, |  | ||||||
|           typename A4, |  | ||||||
|           typename A5, |  | ||||||
|           typename A6> |  | ||||||
| class RunnableAdapter<R(__stdcall *)(A1, A2, A3, A4, A5, A6)> { | class RunnableAdapter<R(__stdcall *)(A1, A2, A3, A4, A5, A6)> { | ||||||
|  public: |  public: | ||||||
|   typedef R (RunType)(A1, A2, A3, A4, A5, A6); |   typedef R (RunType)(A1, A2, A3, A4, A5, A6); | ||||||
|  |  | ||||||
|   explicit RunnableAdapter(R(__stdcall *function)(A1, A2, A3, A4, A5, A6)) |   explicit RunnableAdapter(R(__stdcall *function)(A1, A2, A3, A4, A5, A6)) | ||||||
|       : function_(function) {} |       : function_(function) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   R Run(typename CallbackParamTraits<A1>::ForwardType a1, |   R Run(typename CallbackParamTraits<A1>::ForwardType a1, | ||||||
|       typename CallbackParamTraits<A2>::ForwardType a2, |       typename CallbackParamTraits<A2>::ForwardType a2, | ||||||
| @@ -301,19 +309,15 @@ class RunnableAdapter<R(__stdcall*)(A1, A2, A3, A4, A5, A6)> { | |||||||
| }; | }; | ||||||
|  |  | ||||||
| // __fastcall Function: Arity 6. | // __fastcall Function: Arity 6. | ||||||
| template <typename R, | template <typename R, typename A1, typename A2, typename A3, typename A4, | ||||||
|           typename A1, |     typename A5, typename A6> | ||||||
|           typename A2, |  | ||||||
|           typename A3, |  | ||||||
|           typename A4, |  | ||||||
|           typename A5, |  | ||||||
|           typename A6> |  | ||||||
| class RunnableAdapter<R(__fastcall *)(A1, A2, A3, A4, A5, A6)> { | class RunnableAdapter<R(__fastcall *)(A1, A2, A3, A4, A5, A6)> { | ||||||
|  public: |  public: | ||||||
|   typedef R (RunType)(A1, A2, A3, A4, A5, A6); |   typedef R (RunType)(A1, A2, A3, A4, A5, A6); | ||||||
|  |  | ||||||
|   explicit RunnableAdapter(R(__fastcall *function)(A1, A2, A3, A4, A5, A6)) |   explicit RunnableAdapter(R(__fastcall *function)(A1, A2, A3, A4, A5, A6)) | ||||||
|       : function_(function) {} |       : function_(function) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   R Run(typename CallbackParamTraits<A1>::ForwardType a1, |   R Run(typename CallbackParamTraits<A1>::ForwardType a1, | ||||||
|       typename CallbackParamTraits<A2>::ForwardType a2, |       typename CallbackParamTraits<A2>::ForwardType a2, | ||||||
| @@ -329,20 +333,15 @@ class RunnableAdapter<R(__fastcall*)(A1, A2, A3, A4, A5, A6)> { | |||||||
| }; | }; | ||||||
|  |  | ||||||
| // __stdcall Function: Arity 7. | // __stdcall Function: Arity 7. | ||||||
| template <typename R, | template <typename R, typename A1, typename A2, typename A3, typename A4, | ||||||
|           typename A1, |     typename A5, typename A6, typename A7> | ||||||
|           typename A2, |  | ||||||
|           typename A3, |  | ||||||
|           typename A4, |  | ||||||
|           typename A5, |  | ||||||
|           typename A6, |  | ||||||
|           typename A7> |  | ||||||
| class RunnableAdapter<R(__stdcall *)(A1, A2, A3, A4, A5, A6, A7)> { | class RunnableAdapter<R(__stdcall *)(A1, A2, A3, A4, A5, A6, A7)> { | ||||||
|  public: |  public: | ||||||
|   typedef R (RunType)(A1, A2, A3, A4, A5, A6, A7); |   typedef R (RunType)(A1, A2, A3, A4, A5, A6, A7); | ||||||
|  |  | ||||||
|   explicit RunnableAdapter(R(__stdcall *function)(A1, A2, A3, A4, A5, A6, A7)) |   explicit RunnableAdapter(R(__stdcall *function)(A1, A2, A3, A4, A5, A6, A7)) | ||||||
|       : function_(function) {} |       : function_(function) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   R Run(typename CallbackParamTraits<A1>::ForwardType a1, |   R Run(typename CallbackParamTraits<A1>::ForwardType a1, | ||||||
|       typename CallbackParamTraits<A2>::ForwardType a2, |       typename CallbackParamTraits<A2>::ForwardType a2, | ||||||
| @@ -359,20 +358,15 @@ class RunnableAdapter<R(__stdcall*)(A1, A2, A3, A4, A5, A6, A7)> { | |||||||
| }; | }; | ||||||
|  |  | ||||||
| // __fastcall Function: Arity 7. | // __fastcall Function: Arity 7. | ||||||
| template <typename R, | template <typename R, typename A1, typename A2, typename A3, typename A4, | ||||||
|           typename A1, |     typename A5, typename A6, typename A7> | ||||||
|           typename A2, |  | ||||||
|           typename A3, |  | ||||||
|           typename A4, |  | ||||||
|           typename A5, |  | ||||||
|           typename A6, |  | ||||||
|           typename A7> |  | ||||||
| class RunnableAdapter<R(__fastcall *)(A1, A2, A3, A4, A5, A6, A7)> { | class RunnableAdapter<R(__fastcall *)(A1, A2, A3, A4, A5, A6, A7)> { | ||||||
|  public: |  public: | ||||||
|   typedef R (RunType)(A1, A2, A3, A4, A5, A6, A7); |   typedef R (RunType)(A1, A2, A3, A4, A5, A6, A7); | ||||||
|  |  | ||||||
|   explicit RunnableAdapter(R(__fastcall *function)(A1, A2, A3, A4, A5, A6, A7)) |   explicit RunnableAdapter(R(__fastcall *function)(A1, A2, A3, A4, A5, A6, A7)) | ||||||
|       : function_(function) {} |       : function_(function) { | ||||||
|  |   } | ||||||
|  |  | ||||||
|   R Run(typename CallbackParamTraits<A1>::ForwardType a1, |   R Run(typename CallbackParamTraits<A1>::ForwardType a1, | ||||||
|       typename CallbackParamTraits<A2>::ForwardType a2, |       typename CallbackParamTraits<A2>::ForwardType a2, | ||||||
|   | |||||||
| @@ -115,16 +115,15 @@ class CallbackBase { | |||||||
| // A helper template to determine if given type is non-const move-only-type, | // A helper template to determine if given type is non-const move-only-type, | ||||||
| // i.e. if a value of the given type should be passed via .Pass() in a | // i.e. if a value of the given type should be passed via .Pass() in a | ||||||
| // destructive way. | // destructive way. | ||||||
| template <typename T> | template <typename T> struct IsMoveOnlyType { | ||||||
| struct IsMoveOnlyType { |  | ||||||
|   template <typename U> |   template <typename U> | ||||||
|   static YesType Test(const typename U::MoveOnlyTypeForCPP03*); |   static YesType Test(const typename U::MoveOnlyTypeForCPP03*); | ||||||
|  |  | ||||||
|   template <typename U> |   template <typename U> | ||||||
|   static NoType Test(...); |   static NoType Test(...); | ||||||
|  |  | ||||||
|   static const bool value = |   static const bool value = sizeof(Test<T>(0)) == sizeof(YesType) && | ||||||
|       sizeof(Test<T>(0)) == sizeof(YesType) && !is_const<T>::value; |                             !is_const<T>::value; | ||||||
| }; | }; | ||||||
|  |  | ||||||
| // This is a typetraits object that's used to take an argument type, and | // This is a typetraits object that's used to take an argument type, and | ||||||
|   | |||||||
| @@ -51,7 +51,9 @@ namespace cef_internal { | |||||||
| template <typename T> | template <typename T> | ||||||
| struct NeedsScopedRefptrButGetsRawPtr { | struct NeedsScopedRefptrButGetsRawPtr { | ||||||
| #if defined(OS_WIN) | #if defined(OS_WIN) | ||||||
|   enum { value = base::false_type::value }; |   enum { | ||||||
|  |     value = base::false_type::value | ||||||
|  |   }; | ||||||
| #else | #else | ||||||
|   enum { |   enum { | ||||||
|     // Human readable translation: you needed to be a scoped_refptr if you are a |     // Human readable translation: you needed to be a scoped_refptr if you are a | ||||||
| @@ -81,97 +83,68 @@ struct ParamsUseScopedRefptrCorrectly<Tuple1<A>> { | |||||||
|  |  | ||||||
| template <typename A, typename B> | template <typename A, typename B> | ||||||
| struct ParamsUseScopedRefptrCorrectly<Tuple2<A, B> > { | struct ParamsUseScopedRefptrCorrectly<Tuple2<A, B> > { | ||||||
|   enum { |   enum { value = !(NeedsScopedRefptrButGetsRawPtr<A>::value || | ||||||
|     value = !(NeedsScopedRefptrButGetsRawPtr<A>::value || |                    NeedsScopedRefptrButGetsRawPtr<B>::value) }; | ||||||
|               NeedsScopedRefptrButGetsRawPtr<B>::value) |  | ||||||
|   }; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <typename A, typename B, typename C> | template <typename A, typename B, typename C> | ||||||
| struct ParamsUseScopedRefptrCorrectly<Tuple3<A, B, C> > { | struct ParamsUseScopedRefptrCorrectly<Tuple3<A, B, C> > { | ||||||
|   enum { |   enum { value = !(NeedsScopedRefptrButGetsRawPtr<A>::value || | ||||||
|     value = !(NeedsScopedRefptrButGetsRawPtr<A>::value || |  | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<B>::value || |                    NeedsScopedRefptrButGetsRawPtr<B>::value || | ||||||
|               NeedsScopedRefptrButGetsRawPtr<C>::value) |                    NeedsScopedRefptrButGetsRawPtr<C>::value) }; | ||||||
|   }; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <typename A, typename B, typename C, typename D> | template <typename A, typename B, typename C, typename D> | ||||||
| struct ParamsUseScopedRefptrCorrectly<Tuple4<A, B, C, D> > { | struct ParamsUseScopedRefptrCorrectly<Tuple4<A, B, C, D> > { | ||||||
|   enum { |   enum { value = !(NeedsScopedRefptrButGetsRawPtr<A>::value || | ||||||
|     value = !(NeedsScopedRefptrButGetsRawPtr<A>::value || |  | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<B>::value || |                    NeedsScopedRefptrButGetsRawPtr<B>::value || | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<C>::value || |                    NeedsScopedRefptrButGetsRawPtr<C>::value || | ||||||
|               NeedsScopedRefptrButGetsRawPtr<D>::value) |                    NeedsScopedRefptrButGetsRawPtr<D>::value) }; | ||||||
|   }; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <typename A, typename B, typename C, typename D, typename E> | template <typename A, typename B, typename C, typename D, typename E> | ||||||
| struct ParamsUseScopedRefptrCorrectly<Tuple5<A, B, C, D, E> > { | struct ParamsUseScopedRefptrCorrectly<Tuple5<A, B, C, D, E> > { | ||||||
|   enum { |   enum { value = !(NeedsScopedRefptrButGetsRawPtr<A>::value || | ||||||
|     value = !(NeedsScopedRefptrButGetsRawPtr<A>::value || |  | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<B>::value || |                    NeedsScopedRefptrButGetsRawPtr<B>::value || | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<C>::value || |                    NeedsScopedRefptrButGetsRawPtr<C>::value || | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<D>::value || |                    NeedsScopedRefptrButGetsRawPtr<D>::value || | ||||||
|               NeedsScopedRefptrButGetsRawPtr<E>::value) |                    NeedsScopedRefptrButGetsRawPtr<E>::value) }; | ||||||
|   }; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <typename A, | template <typename A, typename B, typename C, typename D, typename E, | ||||||
|           typename B, |  | ||||||
|           typename C, |  | ||||||
|           typename D, |  | ||||||
|           typename E, |  | ||||||
|           typename F> |           typename F> | ||||||
| struct ParamsUseScopedRefptrCorrectly<Tuple6<A, B, C, D, E, F> > { | struct ParamsUseScopedRefptrCorrectly<Tuple6<A, B, C, D, E, F> > { | ||||||
|   enum { |   enum { value = !(NeedsScopedRefptrButGetsRawPtr<A>::value || | ||||||
|     value = !(NeedsScopedRefptrButGetsRawPtr<A>::value || |  | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<B>::value || |                    NeedsScopedRefptrButGetsRawPtr<B>::value || | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<C>::value || |                    NeedsScopedRefptrButGetsRawPtr<C>::value || | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<D>::value || |                    NeedsScopedRefptrButGetsRawPtr<D>::value || | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<E>::value || |                    NeedsScopedRefptrButGetsRawPtr<E>::value || | ||||||
|               NeedsScopedRefptrButGetsRawPtr<F>::value) |                    NeedsScopedRefptrButGetsRawPtr<F>::value) }; | ||||||
|   }; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <typename A, | template <typename A, typename B, typename C, typename D, typename E, | ||||||
|           typename B, |           typename F, typename G> | ||||||
|           typename C, |  | ||||||
|           typename D, |  | ||||||
|           typename E, |  | ||||||
|           typename F, |  | ||||||
|           typename G> |  | ||||||
| struct ParamsUseScopedRefptrCorrectly<Tuple7<A, B, C, D, E, F, G> > { | struct ParamsUseScopedRefptrCorrectly<Tuple7<A, B, C, D, E, F, G> > { | ||||||
|   enum { |   enum { value = !(NeedsScopedRefptrButGetsRawPtr<A>::value || | ||||||
|     value = !(NeedsScopedRefptrButGetsRawPtr<A>::value || |  | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<B>::value || |                    NeedsScopedRefptrButGetsRawPtr<B>::value || | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<C>::value || |                    NeedsScopedRefptrButGetsRawPtr<C>::value || | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<D>::value || |                    NeedsScopedRefptrButGetsRawPtr<D>::value || | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<E>::value || |                    NeedsScopedRefptrButGetsRawPtr<E>::value || | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<F>::value || |                    NeedsScopedRefptrButGetsRawPtr<F>::value || | ||||||
|               NeedsScopedRefptrButGetsRawPtr<G>::value) |                    NeedsScopedRefptrButGetsRawPtr<G>::value) }; | ||||||
|   }; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| template <typename A, | template <typename A, typename B, typename C, typename D, typename E, | ||||||
|           typename B, |           typename F, typename G, typename H> | ||||||
|           typename C, |  | ||||||
|           typename D, |  | ||||||
|           typename E, |  | ||||||
|           typename F, |  | ||||||
|           typename G, |  | ||||||
|           typename H> |  | ||||||
| struct ParamsUseScopedRefptrCorrectly<Tuple8<A, B, C, D, E, F, G, H> > { | struct ParamsUseScopedRefptrCorrectly<Tuple8<A, B, C, D, E, F, G, H> > { | ||||||
|   enum { |   enum { value = !(NeedsScopedRefptrButGetsRawPtr<A>::value || | ||||||
|     value = !(NeedsScopedRefptrButGetsRawPtr<A>::value || |  | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<B>::value || |                    NeedsScopedRefptrButGetsRawPtr<B>::value || | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<C>::value || |                    NeedsScopedRefptrButGetsRawPtr<C>::value || | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<D>::value || |                    NeedsScopedRefptrButGetsRawPtr<D>::value || | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<E>::value || |                    NeedsScopedRefptrButGetsRawPtr<E>::value || | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<F>::value || |                    NeedsScopedRefptrButGetsRawPtr<F>::value || | ||||||
|                    NeedsScopedRefptrButGetsRawPtr<G>::value || |                    NeedsScopedRefptrButGetsRawPtr<G>::value || | ||||||
|               NeedsScopedRefptrButGetsRawPtr<H>::value) |                    NeedsScopedRefptrButGetsRawPtr<H>::value) }; | ||||||
|   }; |  | ||||||
| }; | }; | ||||||
|  |  | ||||||
| }  // namespace cef_internal | }  // namespace cef_internal | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=ca069c86d9b09fb6f939ce72682e15ce95571ead$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_APP_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_APP_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_APP_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_APP_CAPI_H_ | ||||||
| @@ -61,7 +59,7 @@ typedef struct _cef_app_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Provides an opportunity to view and/or modify command-line arguments before |   // Provides an opportunity to view and/or modify command-line arguments before | ||||||
| @@ -75,8 +73,7 @@ typedef struct _cef_app_t { | |||||||
|   // in undefined behavior including crashes. |   // in undefined behavior including crashes. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_before_command_line_processing)( |   void (CEF_CALLBACK *on_before_command_line_processing)( | ||||||
|       struct _cef_app_t* self, |       struct _cef_app_t* self, const cef_string_t* process_type, | ||||||
|       const cef_string_t* process_type, |  | ||||||
|       struct _cef_command_line_t* command_line); |       struct _cef_command_line_t* command_line); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -85,8 +82,7 @@ typedef struct _cef_app_t { | |||||||
|   // each process and the registered schemes should be the same across all |   // each process and the registered schemes should be the same across all | ||||||
|   // processes. |   // processes. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* on_register_custom_schemes)( |   void (CEF_CALLBACK *on_register_custom_schemes)(struct _cef_app_t* self, | ||||||
|       struct _cef_app_t* self, |  | ||||||
|       struct _cef_scheme_registrar_t* registrar); |       struct _cef_scheme_registrar_t* registrar); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -113,6 +109,7 @@ typedef struct _cef_app_t { | |||||||
|       CEF_CALLBACK *get_render_process_handler)(struct _cef_app_t* self); |       CEF_CALLBACK *get_render_process_handler)(struct _cef_app_t* self); | ||||||
| } cef_app_t; | } cef_app_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // This function should be called from the application entry point function to | // This function should be called from the application entry point function to | ||||||
| // execute a secondary process. It can be used to run secondary processes from | // execute a secondary process. It can be used to run secondary processes from | ||||||
| @@ -126,8 +123,7 @@ typedef struct _cef_app_t { | |||||||
| // cef_sandbox_win.h for details). | // cef_sandbox_win.h for details). | ||||||
| /// | /// | ||||||
| CEF_EXPORT int cef_execute_process(const struct _cef_main_args_t* args, | CEF_EXPORT int cef_execute_process(const struct _cef_main_args_t* args, | ||||||
|                                    cef_app_t* application, |     cef_app_t* application, void* windows_sandbox_info); | ||||||
|                                    void* windows_sandbox_info); |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // This function should be called on the main application thread to initialize | // This function should be called on the main application thread to initialize | ||||||
| @@ -137,8 +133,7 @@ CEF_EXPORT int cef_execute_process(const struct _cef_main_args_t* args, | |||||||
| // be NULL (see cef_sandbox_win.h for details). | // be NULL (see cef_sandbox_win.h for details). | ||||||
| /// | /// | ||||||
| CEF_EXPORT int cef_initialize(const struct _cef_main_args_t* args, | CEF_EXPORT int cef_initialize(const struct _cef_main_args_t* args, | ||||||
|                               const struct _cef_settings_t* settings, |     const struct _cef_settings_t* settings, cef_app_t* application, | ||||||
|                               cef_app_t* application, |  | ||||||
|     void* windows_sandbox_info); |     void* windows_sandbox_info); | ||||||
|  |  | ||||||
| /// | /// | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=899e57614c5810d61b61d182ed823cfbd193b4d4$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_AUTH_CALLBACK_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_AUTH_CALLBACK_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_AUTH_CALLBACK_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_AUTH_CALLBACK_CAPI_H_ | ||||||
| @@ -46,6 +44,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Callback structure used for asynchronous continuation of authentication | // Callback structure used for asynchronous continuation of authentication | ||||||
| // requests. | // requests. | ||||||
| @@ -54,14 +53,13 @@ typedef struct _cef_auth_callback_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Continue the authentication request. |   // Continue the authentication request. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *cont)(struct _cef_auth_callback_t* self, |   void (CEF_CALLBACK *cont)(struct _cef_auth_callback_t* self, | ||||||
|                            const cef_string_t* username, |       const cef_string_t* username, const cef_string_t* password); | ||||||
|                            const cef_string_t* password); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Cancel the authentication request. |   // Cancel the authentication request. | ||||||
| @@ -69,6 +67,7 @@ typedef struct _cef_auth_callback_t { | |||||||
|   void (CEF_CALLBACK *cancel)(struct _cef_auth_callback_t* self); |   void (CEF_CALLBACK *cancel)(struct _cef_auth_callback_t* self); | ||||||
| } cef_auth_callback_t; | } cef_auth_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -27,6 +27,7 @@ | |||||||
| // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | ||||||
| // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_BASE_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_BASE_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_BASE_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_BASE_CAPI_H_ | ||||||
|  |  | ||||||
| @@ -44,9 +45,10 @@ extern "C" { | |||||||
| #endif | #endif | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // All ref-counted framework structures must include this structure first. | // Structure defining the reference count implementation functions. All | ||||||
|  | // framework structures must include the cef_base_t structure first. | ||||||
| /// | /// | ||||||
| typedef struct _cef_base_ref_counted_t { | typedef struct _cef_base_t { | ||||||
|   /// |   /// | ||||||
|   // Size of the data structure. |   // Size of the data structure. | ||||||
|   /// |   /// | ||||||
| @@ -56,45 +58,31 @@ typedef struct _cef_base_ref_counted_t { | |||||||
|   // Called to increment the reference count for the object. Should be called |   // Called to increment the reference count for the object. Should be called | ||||||
|   // for every new copy of a pointer to a given object. |   // for every new copy of a pointer to a given object. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* add_ref)(struct _cef_base_ref_counted_t* self); |   void (CEF_CALLBACK *add_ref)(struct _cef_base_t* self); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called to decrement the reference count for the object. If the reference |   // Called to decrement the reference count for the object. If the reference | ||||||
|   // count falls to 0 the object should self-delete. Returns true (1) if the |   // count falls to 0 the object should self-delete. Returns true (1) if the | ||||||
|   // resulting reference count is 0. |   // resulting reference count is 0. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* release)(struct _cef_base_ref_counted_t* self); |   int (CEF_CALLBACK *release)(struct _cef_base_t* self); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if the current reference count is 1. |   // Returns true (1) if the current reference count is 1. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* has_one_ref)(struct _cef_base_ref_counted_t* self); |   int (CEF_CALLBACK *has_one_ref)(struct _cef_base_t* self); | ||||||
| } cef_base_ref_counted_t; | } cef_base_t; | ||||||
|  |  | ||||||
| /// |  | ||||||
| // All scoped framework structures must include this structure first. |  | ||||||
| /// |  | ||||||
| typedef struct _cef_base_scoped_t { |  | ||||||
|   /// |  | ||||||
|   // Size of the data structure. |  | ||||||
|   /// |  | ||||||
|   size_t size; |  | ||||||
|  |  | ||||||
|   /// | // Check that the structure |s|, which is defined with a cef_base_t member named | ||||||
|   // Called to delete this object. May be NULL if the object is not owned. | // |base|, is large enough to contain the specified member |f|. | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* del)(struct _cef_base_scoped_t* self); |  | ||||||
|  |  | ||||||
| } cef_base_scoped_t; |  | ||||||
|  |  | ||||||
| // Check that the structure |s|, which is defined with a size_t member at the |  | ||||||
| // top, is large enough to contain the specified member |f|. |  | ||||||
| #define CEF_MEMBER_EXISTS(s, f)   \ | #define CEF_MEMBER_EXISTS(s, f)   \ | ||||||
|   ((intptr_t) &                 \ |   ((intptr_t)&((s)->f) - (intptr_t)(s) + sizeof((s)->f) <= \ | ||||||
|    ((s)->f) - (intptr_t)(s) + sizeof((s)->f) <= *reinterpret_cast<size_t*>(s)) |   reinterpret_cast<cef_base_t*>(s)->size) | ||||||
|  |  | ||||||
| #define CEF_MEMBER_MISSING(s, f)  (!CEF_MEMBER_EXISTS(s, f) || !((s)->f)) | #define CEF_MEMBER_MISSING(s, f)  (!CEF_MEMBER_EXISTS(s, f) || !((s)->f)) | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=ff3ebc51ed5743aabac0be94caf2edeedbd413b7$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_BROWSER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_BROWSER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_BROWSER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_BROWSER_CAPI_H_ | ||||||
| @@ -65,7 +63,7 @@ typedef struct _cef_browser_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the browser host object. This function can only be called in the |   // Returns the browser host object. This function can only be called in the | ||||||
| @@ -115,8 +113,7 @@ typedef struct _cef_browser_t { | |||||||
|   void (CEF_CALLBACK *stop_load)(struct _cef_browser_t* self); |   void (CEF_CALLBACK *stop_load)(struct _cef_browser_t* self); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the globally unique identifier for this browser. This value is also |   // Returns the globally unique identifier for this browser. | ||||||
|   // used as the tabId for extension APIs. |  | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *get_identifier)(struct _cef_browser_t* self); |   int (CEF_CALLBACK *get_identifier)(struct _cef_browser_t* self); | ||||||
|  |  | ||||||
| @@ -153,8 +150,7 @@ typedef struct _cef_browser_t { | |||||||
|   // Returns the frame with the specified identifier, or NULL if not found. |   // Returns the frame with the specified identifier, or NULL if not found. | ||||||
|   /// |   /// | ||||||
|   struct _cef_frame_t* (CEF_CALLBACK *get_frame_byident)( |   struct _cef_frame_t* (CEF_CALLBACK *get_frame_byident)( | ||||||
|       struct _cef_browser_t* self, |       struct _cef_browser_t* self, int64 identifier); | ||||||
|       int64 identifier); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the frame with the specified name, or NULL if not found. |   // Returns the frame with the specified name, or NULL if not found. | ||||||
| @@ -171,8 +167,7 @@ typedef struct _cef_browser_t { | |||||||
|   // Returns the identifiers of all existing frames. |   // Returns the identifiers of all existing frames. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *get_frame_identifiers)(struct _cef_browser_t* self, |   void (CEF_CALLBACK *get_frame_identifiers)(struct _cef_browser_t* self, | ||||||
|                                             size_t* identifiersCount, |       size_t* identifiersCount, int64* identifiers); | ||||||
|                                             int64* identifiers); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the names of all existing frames. |   // Returns the names of all existing frames. | ||||||
| @@ -184,12 +179,12 @@ typedef struct _cef_browser_t { | |||||||
|   // Send a message to the specified |target_process|. Returns true (1) if the |   // Send a message to the specified |target_process|. Returns true (1) if the | ||||||
|   // message was sent successfully. |   // message was sent successfully. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* send_process_message)( |   int (CEF_CALLBACK *send_process_message)(struct _cef_browser_t* self, | ||||||
|       struct _cef_browser_t* self, |  | ||||||
|       cef_process_id_t target_process, |       cef_process_id_t target_process, | ||||||
|       struct _cef_process_message_t* message); |       struct _cef_process_message_t* message); | ||||||
| } cef_browser_t; | } cef_browser_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Callback structure for cef_browser_host_t::RunFileDialog. The functions of | // Callback structure for cef_browser_host_t::RunFileDialog. The functions of | ||||||
| // this structure will be called on the browser process UI thread. | // this structure will be called on the browser process UI thread. | ||||||
| @@ -198,7 +193,7 @@ typedef struct _cef_run_file_dialog_callback_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called asynchronously after the file dialog is dismissed. |   // Called asynchronously after the file dialog is dismissed. | ||||||
| @@ -208,11 +203,11 @@ typedef struct _cef_run_file_dialog_callback_t { | |||||||
|   // dialog mode. If the selection was cancelled |file_paths| will be NULL. |   // dialog mode. If the selection was cancelled |file_paths| will be NULL. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_file_dialog_dismissed)( |   void (CEF_CALLBACK *on_file_dialog_dismissed)( | ||||||
|       struct _cef_run_file_dialog_callback_t* self, |       struct _cef_run_file_dialog_callback_t* self, int selected_accept_filter, | ||||||
|       int selected_accept_filter, |  | ||||||
|       cef_string_list_t file_paths); |       cef_string_list_t file_paths); | ||||||
| } cef_run_file_dialog_callback_t; | } cef_run_file_dialog_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Callback structure for cef_browser_host_t::GetNavigationEntries. The | // Callback structure for cef_browser_host_t::GetNavigationEntries. The | ||||||
| // functions of this structure will be called on the browser process UI thread. | // functions of this structure will be called on the browser process UI thread. | ||||||
| @@ -221,7 +216,7 @@ typedef struct _cef_navigation_entry_visitor_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Method that will be executed. Do not keep a reference to |entry| outside of |   // Method that will be executed. Do not keep a reference to |entry| outside of | ||||||
| @@ -231,12 +226,11 @@ typedef struct _cef_navigation_entry_visitor_t { | |||||||
|   // the total number of entries. |   // the total number of entries. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *visit)(struct _cef_navigation_entry_visitor_t* self, |   int (CEF_CALLBACK *visit)(struct _cef_navigation_entry_visitor_t* self, | ||||||
|                            struct _cef_navigation_entry_t* entry, |       struct _cef_navigation_entry_t* entry, int current, int index, | ||||||
|                            int current, |  | ||||||
|                            int index, |  | ||||||
|       int total); |       int total); | ||||||
| } cef_navigation_entry_visitor_t; | } cef_navigation_entry_visitor_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Callback structure for cef_browser_host_t::PrintToPDF. The functions of this | // Callback structure for cef_browser_host_t::PrintToPDF. The functions of this | ||||||
| // structure will be called on the browser process UI thread. | // structure will be called on the browser process UI thread. | ||||||
| @@ -245,7 +239,7 @@ typedef struct _cef_pdf_print_callback_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Method that will be executed when the PDF printing has completed. |path| is |   // Method that will be executed when the PDF printing has completed. |path| is | ||||||
| @@ -253,11 +247,11 @@ typedef struct _cef_pdf_print_callback_t { | |||||||
|   // successfully or false (0) otherwise. |   // successfully or false (0) otherwise. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_pdf_print_finished)( |   void (CEF_CALLBACK *on_pdf_print_finished)( | ||||||
|       struct _cef_pdf_print_callback_t* self, |       struct _cef_pdf_print_callback_t* self, const cef_string_t* path, | ||||||
|       const cef_string_t* path, |  | ||||||
|       int ok); |       int ok); | ||||||
| } cef_pdf_print_callback_t; | } cef_pdf_print_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Callback structure for cef_browser_host_t::DownloadImage. The functions of | // Callback structure for cef_browser_host_t::DownloadImage. The functions of | ||||||
| // this structure will be called on the browser process UI thread. | // this structure will be called on the browser process UI thread. | ||||||
| @@ -266,7 +260,7 @@ typedef struct _cef_download_image_callback_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Method that will be executed when the image download has completed. |   // Method that will be executed when the image download has completed. | ||||||
| @@ -276,11 +270,11 @@ typedef struct _cef_download_image_callback_t { | |||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_download_image_finished)( |   void (CEF_CALLBACK *on_download_image_finished)( | ||||||
|       struct _cef_download_image_callback_t* self, |       struct _cef_download_image_callback_t* self, | ||||||
|       const cef_string_t* image_url, |       const cef_string_t* image_url, int http_status_code, | ||||||
|       int http_status_code, |  | ||||||
|       struct _cef_image_t* image); |       struct _cef_image_t* image); | ||||||
| } cef_download_image_callback_t; | } cef_download_image_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used to represent the browser process aspects of a browser window. | // Structure used to represent the browser process aspects of a browser window. | ||||||
| // The functions of this structure can only be called in the browser process. | // The functions of this structure can only be called in the browser process. | ||||||
| @@ -291,7 +285,7 @@ typedef struct _cef_browser_host_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the hosted browser object. |   // Returns the hosted browser object. | ||||||
| @@ -391,12 +385,9 @@ typedef struct _cef_browser_host_t { | |||||||
|   // dismissed or immediately if another dialog is already pending. The dialog |   // dismissed or immediately if another dialog is already pending. The dialog | ||||||
|   // will be initiated asynchronously on the UI thread. |   // will be initiated asynchronously on the UI thread. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* run_file_dialog)( |   void (CEF_CALLBACK *run_file_dialog)(struct _cef_browser_host_t* self, | ||||||
|       struct _cef_browser_host_t* self, |       cef_file_dialog_mode_t mode, const cef_string_t* title, | ||||||
|       cef_file_dialog_mode_t mode, |       const cef_string_t* default_file_path, cef_string_list_t accept_filters, | ||||||
|       const cef_string_t* title, |  | ||||||
|       const cef_string_t* default_file_path, |  | ||||||
|       cef_string_list_t accept_filters, |  | ||||||
|       int selected_accept_filter, |       int selected_accept_filter, | ||||||
|       struct _cef_run_file_dialog_callback_t* callback); |       struct _cef_run_file_dialog_callback_t* callback); | ||||||
|  |  | ||||||
| @@ -418,13 +409,9 @@ typedef struct _cef_browser_host_t { | |||||||
|   // unlimited. If |bypass_cache| is true (1) then |image_url| is requested from |   // unlimited. If |bypass_cache| is true (1) then |image_url| is requested from | ||||||
|   // the server even if it is present in the browser cache. |   // the server even if it is present in the browser cache. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* download_image)( |   void (CEF_CALLBACK *download_image)(struct _cef_browser_host_t* self, | ||||||
|       struct _cef_browser_host_t* self, |       const cef_string_t* image_url, int is_favicon, uint32 max_image_size, | ||||||
|       const cef_string_t* image_url, |       int bypass_cache, struct _cef_download_image_callback_t* callback); | ||||||
|       int is_favicon, |  | ||||||
|       uint32 max_image_size, |  | ||||||
|       int bypass_cache, |  | ||||||
|       struct _cef_download_image_callback_t* callback); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Print the current browser contents. |   // Print the current browser contents. | ||||||
| @@ -437,28 +424,21 @@ typedef struct _cef_browser_host_t { | |||||||
|   // |path| when done. For PDF printing to work on Linux you must implement the |   // |path| when done. For PDF printing to work on Linux you must implement the | ||||||
|   // cef_print_handler_t::GetPdfPaperSize function. |   // cef_print_handler_t::GetPdfPaperSize function. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* print_to_pdf)( |   void (CEF_CALLBACK *print_to_pdf)(struct _cef_browser_host_t* self, | ||||||
|       struct _cef_browser_host_t* self, |  | ||||||
|       const cef_string_t* path, |       const cef_string_t* path, | ||||||
|       const struct _cef_pdf_print_settings_t* settings, |       const struct _cef_pdf_print_settings_t* settings, | ||||||
|       struct _cef_pdf_print_callback_t* callback); |       struct _cef_pdf_print_callback_t* callback); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Search for |searchText|. |identifier| must be a unique ID and these IDs |   // Search for |searchText|. |identifier| can be used to have multiple searches | ||||||
|   // must strictly increase so that newer requests always have greater IDs than |   // running simultaniously. |forward| indicates whether to search forward or | ||||||
|   // older requests. If |identifier| is zero or less than the previous ID value |   // backward within the page. |matchCase| indicates whether the search should | ||||||
|   // then it will be automatically assigned a new valid ID. |forward| indicates |   // be case-sensitive. |findNext| indicates whether this is the first request | ||||||
|   // whether to search forward or backward within the page. |matchCase| |   // or a follow-up. The cef_find_handler_t instance, if any, returned via | ||||||
|   // indicates whether the search should be case-sensitive. |findNext| indicates |   // cef_client_t::GetFindHandler will be called to report find results. | ||||||
|   // whether this is the first request or a follow-up. The cef_find_handler_t |  | ||||||
|   // instance, if any, returned via cef_client_t::GetFindHandler will be called |  | ||||||
|   // to report find results. |  | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* find)(struct _cef_browser_host_t* self, |   void (CEF_CALLBACK *find)(struct _cef_browser_host_t* self, int identifier, | ||||||
|                            int identifier, |       const cef_string_t* searchText, int forward, int matchCase, | ||||||
|                            const cef_string_t* searchText, |  | ||||||
|                            int forward, |  | ||||||
|                            int matchCase, |  | ||||||
|       int findNext); |       int findNext); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -476,8 +456,7 @@ typedef struct _cef_browser_host_t { | |||||||
|   // inspected. The |windowInfo| parameter will be ignored if this browser is |   // inspected. The |windowInfo| parameter will be ignored if this browser is | ||||||
|   // wrapped in a cef_browser_view_t. |   // wrapped in a cef_browser_view_t. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* show_dev_tools)( |   void (CEF_CALLBACK *show_dev_tools)(struct _cef_browser_host_t* self, | ||||||
|       struct _cef_browser_host_t* self, |  | ||||||
|       const struct _cef_window_info_t* windowInfo, |       const struct _cef_window_info_t* windowInfo, | ||||||
|       struct _cef_client_t* client, |       struct _cef_client_t* client, | ||||||
|       const struct _cef_browser_settings_t* settings, |       const struct _cef_browser_settings_t* settings, | ||||||
| @@ -500,17 +479,14 @@ typedef struct _cef_browser_host_t { | |||||||
|   // navigation entry will be sent, otherwise all navigation entries will be |   // navigation entry will be sent, otherwise all navigation entries will be | ||||||
|   // sent. |   // sent. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* get_navigation_entries)( |   void (CEF_CALLBACK *get_navigation_entries)(struct _cef_browser_host_t* self, | ||||||
|       struct _cef_browser_host_t* self, |       struct _cef_navigation_entry_visitor_t* visitor, int current_only); | ||||||
|       struct _cef_navigation_entry_visitor_t* visitor, |  | ||||||
|       int current_only); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Set whether mouse cursor change is disabled. |   // Set whether mouse cursor change is disabled. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *set_mouse_cursor_change_disabled)( |   void (CEF_CALLBACK *set_mouse_cursor_change_disabled)( | ||||||
|       struct _cef_browser_host_t* self, |       struct _cef_browser_host_t* self, int disabled); | ||||||
|       int disabled); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if mouse cursor change is disabled. |   // Returns true (1) if mouse cursor change is disabled. | ||||||
| @@ -581,21 +557,16 @@ typedef struct _cef_browser_host_t { | |||||||
|   // Send a mouse click event to the browser. The |x| and |y| coordinates are |   // Send a mouse click event to the browser. The |x| and |y| coordinates are | ||||||
|   // relative to the upper-left corner of the view. |   // relative to the upper-left corner of the view. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* send_mouse_click_event)( |   void (CEF_CALLBACK *send_mouse_click_event)(struct _cef_browser_host_t* self, | ||||||
|       struct _cef_browser_host_t* self, |       const struct _cef_mouse_event_t* event, cef_mouse_button_type_t type, | ||||||
|       const struct _cef_mouse_event_t* event, |       int mouseUp, int clickCount); | ||||||
|       cef_mouse_button_type_t type, |  | ||||||
|       int mouseUp, |  | ||||||
|       int clickCount); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Send a mouse move event to the browser. The |x| and |y| coordinates are |   // Send a mouse move event to the browser. The |x| and |y| coordinates are | ||||||
|   // relative to the upper-left corner of the view. |   // relative to the upper-left corner of the view. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* send_mouse_move_event)( |   void (CEF_CALLBACK *send_mouse_move_event)(struct _cef_browser_host_t* self, | ||||||
|       struct _cef_browser_host_t* self, |       const struct _cef_mouse_event_t* event, int mouseLeave); | ||||||
|       const struct _cef_mouse_event_t* event, |  | ||||||
|       int mouseLeave); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Send a mouse wheel event to the browser. The |x| and |y| coordinates are |   // Send a mouse wheel event to the browser. The |x| and |y| coordinates are | ||||||
| @@ -604,11 +575,8 @@ typedef struct _cef_browser_host_t { | |||||||
|   // In order to scroll inside select popups with window rendering disabled |   // In order to scroll inside select popups with window rendering disabled | ||||||
|   // cef_render_handler_t::GetScreenPoint should be implemented properly. |   // cef_render_handler_t::GetScreenPoint should be implemented properly. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* send_mouse_wheel_event)( |   void (CEF_CALLBACK *send_mouse_wheel_event)(struct _cef_browser_host_t* self, | ||||||
|       struct _cef_browser_host_t* self, |       const struct _cef_mouse_event_t* event, int deltaX, int deltaY); | ||||||
|       const struct _cef_mouse_event_t* event, |  | ||||||
|       int deltaX, |  | ||||||
|       int deltaY); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Send a focus event to the browser. |   // Send a focus event to the browser. | ||||||
| @@ -619,7 +587,8 @@ typedef struct _cef_browser_host_t { | |||||||
|   /// |   /// | ||||||
|   // Send a capture lost event to the browser. |   // Send a capture lost event to the browser. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* send_capture_lost_event)(struct _cef_browser_host_t* self); |   void (CEF_CALLBACK *send_capture_lost_event)( | ||||||
|  |       struct _cef_browser_host_t* self); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Notify the browser that the window hosting it is about to be moved or |   // Notify the browser that the window hosting it is about to be moved or | ||||||
| @@ -646,8 +615,7 @@ typedef struct _cef_browser_host_t { | |||||||
|   // set at browser creation via cef_browser_tSettings.windowless_frame_rate. |   // set at browser creation via cef_browser_tSettings.windowless_frame_rate. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *set_windowless_frame_rate)( |   void (CEF_CALLBACK *set_windowless_frame_rate)( | ||||||
|       struct _cef_browser_host_t* self, |       struct _cef_browser_host_t* self, int frame_rate); | ||||||
|       int frame_rate); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Begins a new composition or updates the existing composition. Blink has a |   // Begins a new composition or updates the existing composition. Blink has a | ||||||
| @@ -672,10 +640,8 @@ typedef struct _cef_browser_host_t { | |||||||
|   // |   // | ||||||
|   // This function is only used when window rendering is disabled. |   // This function is only used when window rendering is disabled. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* ime_set_composition)( |   void (CEF_CALLBACK *ime_set_composition)(struct _cef_browser_host_t* self, | ||||||
|       struct _cef_browser_host_t* self, |       const cef_string_t* text, size_t underlinesCount, | ||||||
|       const cef_string_t* text, |  | ||||||
|       size_t underlinesCount, |  | ||||||
|       cef_composition_underline_t const* underlines, |       cef_composition_underline_t const* underlines, | ||||||
|       const cef_range_t* replacement_range, |       const cef_range_t* replacement_range, | ||||||
|       const cef_range_t* selection_range); |       const cef_range_t* selection_range); | ||||||
| @@ -690,8 +656,7 @@ typedef struct _cef_browser_host_t { | |||||||
|   // used when window rendering is disabled. |   // used when window rendering is disabled. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *ime_commit_text)(struct _cef_browser_host_t* self, |   void (CEF_CALLBACK *ime_commit_text)(struct _cef_browser_host_t* self, | ||||||
|                                       const cef_string_t* text, |       const cef_string_t* text, const cef_range_t* replacement_range, | ||||||
|                                       const cef_range_t* replacement_range, |  | ||||||
|       int relative_cursor_pos); |       int relative_cursor_pos); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -701,8 +666,7 @@ typedef struct _cef_browser_host_t { | |||||||
|   // function is only used when window rendering is disabled. |   // function is only used when window rendering is disabled. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *ime_finish_composing_text)( |   void (CEF_CALLBACK *ime_finish_composing_text)( | ||||||
|       struct _cef_browser_host_t* self, |       struct _cef_browser_host_t* self, int keep_selection); | ||||||
|       int keep_selection); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Cancels the existing composition and discards the composition node contents |   // Cancels the existing composition and discards the composition node contents | ||||||
| @@ -720,8 +684,7 @@ typedef struct _cef_browser_host_t { | |||||||
|   // cef_render_handler_t::StartDragging). This function is only used when |   // cef_render_handler_t::StartDragging). This function is only used when | ||||||
|   // window rendering is disabled. |   // window rendering is disabled. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* drag_target_drag_enter)( |   void (CEF_CALLBACK *drag_target_drag_enter)(struct _cef_browser_host_t* self, | ||||||
|       struct _cef_browser_host_t* self, |  | ||||||
|       struct _cef_drag_data_t* drag_data, |       struct _cef_drag_data_t* drag_data, | ||||||
|       const struct _cef_mouse_event_t* event, |       const struct _cef_mouse_event_t* event, | ||||||
|       cef_drag_operations_mask_t allowed_ops); |       cef_drag_operations_mask_t allowed_ops); | ||||||
| @@ -732,8 +695,7 @@ typedef struct _cef_browser_host_t { | |||||||
|   // DragTargetDragLeave/DragTargetDrop). This function is only used when window |   // DragTargetDragLeave/DragTargetDrop). This function is only used when window | ||||||
|   // rendering is disabled. |   // rendering is disabled. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* drag_target_drag_over)( |   void (CEF_CALLBACK *drag_target_drag_over)(struct _cef_browser_host_t* self, | ||||||
|       struct _cef_browser_host_t* self, |  | ||||||
|       const struct _cef_mouse_event_t* event, |       const struct _cef_mouse_event_t* event, | ||||||
|       cef_drag_operations_mask_t allowed_ops); |       cef_drag_operations_mask_t allowed_ops); | ||||||
|  |  | ||||||
| @@ -764,9 +726,7 @@ typedef struct _cef_browser_host_t { | |||||||
|   // disabled. |   // disabled. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *drag_source_ended_at)(struct _cef_browser_host_t* self, |   void (CEF_CALLBACK *drag_source_ended_at)(struct _cef_browser_host_t* self, | ||||||
|                                            int x, |       int x, int y, cef_drag_operations_mask_t op); | ||||||
|                                            int y, |  | ||||||
|                                            cef_drag_operations_mask_t op); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Call this function when the drag operation started by a |   // Call this function when the drag operation started by a | ||||||
| @@ -785,60 +745,9 @@ typedef struct _cef_browser_host_t { | |||||||
|   /// |   /// | ||||||
|   struct _cef_navigation_entry_t* (CEF_CALLBACK *get_visible_navigation_entry)( |   struct _cef_navigation_entry_t* (CEF_CALLBACK *get_visible_navigation_entry)( | ||||||
|       struct _cef_browser_host_t* self); |       struct _cef_browser_host_t* self); | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Set accessibility state for all frames. |accessibility_state| may be |  | ||||||
|   // default, enabled or disabled. If |accessibility_state| is STATE_DEFAULT |  | ||||||
|   // then accessibility will be disabled by default and the state may be further |  | ||||||
|   // controlled with the "force-renderer-accessibility" and "disable-renderer- |  | ||||||
|   // accessibility" command-line switches. If |accessibility_state| is |  | ||||||
|   // STATE_ENABLED then accessibility will be enabled. If |accessibility_state| |  | ||||||
|   // is STATE_DISABLED then accessibility will be completely disabled. |  | ||||||
|   // |  | ||||||
|   // For windowed browsers accessibility will be enabled in Complete mode (which |  | ||||||
|   // corresponds to kAccessibilityModeComplete in Chromium). In this mode all |  | ||||||
|   // platform accessibility objects will be created and managed by Chromium's |  | ||||||
|   // internal implementation. The client needs only to detect the screen reader |  | ||||||
|   // and call this function appropriately. For example, on macOS the client can |  | ||||||
|   // handle the @"AXEnhancedUserStructure" accessibility attribute to detect |  | ||||||
|   // VoiceOver state changes and on Windows the client can handle WM_GETOBJECT |  | ||||||
|   // with OBJID_CLIENT to detect accessibility readers. |  | ||||||
|   // |  | ||||||
|   // For windowless browsers accessibility will be enabled in TreeOnly mode |  | ||||||
|   // (which corresponds to kAccessibilityModeWebContentsOnly in Chromium). In |  | ||||||
|   // this mode renderer accessibility is enabled, the full tree is computed, and |  | ||||||
|   // events are passed to CefAccessibiltyHandler, but platform accessibility |  | ||||||
|   // objects are not created. The client may implement platform accessibility |  | ||||||
|   // objects using CefAccessibiltyHandler callbacks if desired. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* set_accessibility_state)(struct _cef_browser_host_t* self, |  | ||||||
|                                               cef_state_t accessibility_state); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Enable notifications of auto resize via |  | ||||||
|   // cef_display_handler_t::OnAutoResize. Notifications are disabled by default. |  | ||||||
|   // |min_size| and |max_size| define the range of allowed sizes. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* set_auto_resize_enabled)(struct _cef_browser_host_t* self, |  | ||||||
|                                               int enabled, |  | ||||||
|                                               const cef_size_t* min_size, |  | ||||||
|                                               const cef_size_t* max_size); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns the extension hosted in this browser or NULL if no extension is |  | ||||||
|   // hosted. See cef_request_tContext::LoadExtension for details. |  | ||||||
|   /// |  | ||||||
|   struct _cef_extension_t*(CEF_CALLBACK* get_extension)( |  | ||||||
|       struct _cef_browser_host_t* self); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns true (1) if this browser is hosting an extension background script. |  | ||||||
|   // Background hosts do not have a window and are not displayable. See |  | ||||||
|   // cef_request_tContext::LoadExtension for details. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* is_background_host)(struct _cef_browser_host_t* self); |  | ||||||
| } cef_browser_host_t; | } cef_browser_host_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Create a new browser window using the window parameters specified by | // Create a new browser window using the window parameters specified by | ||||||
| // |windowInfo|. All values will be copied internally and the actual window will | // |windowInfo|. All values will be copied internally and the actual window will | ||||||
| @@ -847,10 +756,8 @@ typedef struct _cef_browser_host_t { | |||||||
| // thread and will not block. | // thread and will not block. | ||||||
| /// | /// | ||||||
| CEF_EXPORT int cef_browser_host_create_browser( | CEF_EXPORT int cef_browser_host_create_browser( | ||||||
|     const cef_window_info_t* windowInfo, |     const cef_window_info_t* windowInfo, struct _cef_client_t* client, | ||||||
|     struct _cef_client_t* client, |     const cef_string_t* url, const struct _cef_browser_settings_t* settings, | ||||||
|     const cef_string_t* url, |  | ||||||
|     const struct _cef_browser_settings_t* settings, |  | ||||||
|     struct _cef_request_context_t* request_context); |     struct _cef_request_context_t* request_context); | ||||||
|  |  | ||||||
| /// | /// | ||||||
| @@ -859,12 +766,11 @@ CEF_EXPORT int cef_browser_host_create_browser( | |||||||
| // used. This function can only be called on the browser process UI thread. | // used. This function can only be called on the browser process UI thread. | ||||||
| /// | /// | ||||||
| CEF_EXPORT cef_browser_t* cef_browser_host_create_browser_sync( | CEF_EXPORT cef_browser_t* cef_browser_host_create_browser_sync( | ||||||
|     const cef_window_info_t* windowInfo, |     const cef_window_info_t* windowInfo, struct _cef_client_t* client, | ||||||
|     struct _cef_client_t* client, |     const cef_string_t* url, const struct _cef_browser_settings_t* settings, | ||||||
|     const cef_string_t* url, |  | ||||||
|     const struct _cef_browser_settings_t* settings, |  | ||||||
|     struct _cef_request_context_t* request_context); |     struct _cef_request_context_t* request_context); | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=437eae6454931ccf2687f60f8050fcf216966e09$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_BROWSER_PROCESS_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_BROWSER_PROCESS_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_BROWSER_PROCESS_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_BROWSER_PROCESS_HANDLER_CAPI_H_ | ||||||
| @@ -49,6 +47,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used to implement browser process callbacks. The functions of this | // Structure used to implement browser process callbacks. The functions of this | ||||||
| // structure will be called on the browser process main thread unless otherwise | // structure will be called on the browser process main thread unless otherwise | ||||||
| @@ -58,7 +57,7 @@ typedef struct _cef_browser_process_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called on the browser process UI thread immediately after the CEF context |   // Called on the browser process UI thread immediately after the CEF context | ||||||
| @@ -110,10 +109,10 @@ typedef struct _cef_browser_process_handler_t { | |||||||
|   // cancelled. |   // cancelled. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_schedule_message_pump_work)( |   void (CEF_CALLBACK *on_schedule_message_pump_work)( | ||||||
|       struct _cef_browser_process_handler_t* self, |       struct _cef_browser_process_handler_t* self, int64 delay_ms); | ||||||
|       int64 delay_ms); |  | ||||||
| } cef_browser_process_handler_t; | } cef_browser_process_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=41c1f253d23f062f96debd7184f3b5e5dac03a89$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_CALLBACK_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_CALLBACK_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_CALLBACK_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_CALLBACK_CAPI_H_ | ||||||
| @@ -46,6 +44,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Generic callback structure used for asynchronous continuation. | // Generic callback structure used for asynchronous continuation. | ||||||
| /// | /// | ||||||
| @@ -53,7 +52,7 @@ typedef struct _cef_callback_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Continue processing. |   // Continue processing. | ||||||
| @@ -66,6 +65,7 @@ typedef struct _cef_callback_t { | |||||||
|   void (CEF_CALLBACK *cancel)(struct _cef_callback_t* self); |   void (CEF_CALLBACK *cancel)(struct _cef_callback_t* self); | ||||||
| } cef_callback_t; | } cef_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Generic callback structure used for asynchronous completion. | // Generic callback structure used for asynchronous completion. | ||||||
| /// | /// | ||||||
| @@ -73,7 +73,7 @@ typedef struct _cef_completion_callback_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Method that will be called once the task is complete. |   // Method that will be called once the task is complete. | ||||||
| @@ -81,6 +81,7 @@ typedef struct _cef_completion_callback_t { | |||||||
|   void (CEF_CALLBACK *on_complete)(struct _cef_completion_callback_t* self); |   void (CEF_CALLBACK *on_complete)(struct _cef_completion_callback_t* self); | ||||||
| } cef_completion_callback_t; | } cef_completion_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=1dbb0adf7ac5fd42b5a79d271834781664a7fd47$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_CLIENT_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_CLIENT_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_CLIENT_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_CLIENT_CAPI_H_ | ||||||
| @@ -48,6 +46,7 @@ | |||||||
| #include "include/capi/cef_drag_handler_capi.h" | #include "include/capi/cef_drag_handler_capi.h" | ||||||
| #include "include/capi/cef_find_handler_capi.h" | #include "include/capi/cef_find_handler_capi.h" | ||||||
| #include "include/capi/cef_focus_handler_capi.h" | #include "include/capi/cef_focus_handler_capi.h" | ||||||
|  | #include "include/capi/cef_geolocation_handler_capi.h" | ||||||
| #include "include/capi/cef_jsdialog_handler_capi.h" | #include "include/capi/cef_jsdialog_handler_capi.h" | ||||||
| #include "include/capi/cef_keyboard_handler_capi.h" | #include "include/capi/cef_keyboard_handler_capi.h" | ||||||
| #include "include/capi/cef_life_span_handler_capi.h" | #include "include/capi/cef_life_span_handler_capi.h" | ||||||
| @@ -60,6 +59,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Implement this structure to provide handler implementations. | // Implement this structure to provide handler implementations. | ||||||
| /// | /// | ||||||
| @@ -67,7 +67,7 @@ typedef struct _cef_client_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Return the handler for context menus. If no handler is provided the default |   // Return the handler for context menus. If no handler is provided the default | ||||||
| @@ -114,6 +114,13 @@ typedef struct _cef_client_t { | |||||||
|   struct _cef_focus_handler_t* (CEF_CALLBACK *get_focus_handler)( |   struct _cef_focus_handler_t* (CEF_CALLBACK *get_focus_handler)( | ||||||
|       struct _cef_client_t* self); |       struct _cef_client_t* self); | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Return the handler for geolocation permissions requests. If no handler is | ||||||
|  |   // provided geolocation access will be denied by default. | ||||||
|  |   /// | ||||||
|  |   struct _cef_geolocation_handler_t* (CEF_CALLBACK *get_geolocation_handler)( | ||||||
|  |       struct _cef_client_t* self); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Return the handler for JavaScript dialogs. If no handler is provided the |   // Return the handler for JavaScript dialogs. If no handler is provided the | ||||||
|   // default implementation will be used. |   // default implementation will be used. | ||||||
| @@ -156,13 +163,12 @@ typedef struct _cef_client_t { | |||||||
|   // (1) if the message was handled or false (0) otherwise. Do not keep a |   // (1) if the message was handled or false (0) otherwise. Do not keep a | ||||||
|   // reference to or attempt to access the message outside of this callback. |   // reference to or attempt to access the message outside of this callback. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* on_process_message_received)( |   int (CEF_CALLBACK *on_process_message_received)(struct _cef_client_t* self, | ||||||
|       struct _cef_client_t* self, |       struct _cef_browser_t* browser, cef_process_id_t source_process, | ||||||
|       struct _cef_browser_t* browser, |  | ||||||
|       cef_process_id_t source_process, |  | ||||||
|       struct _cef_process_message_t* message); |       struct _cef_process_message_t* message); | ||||||
| } cef_client_t; | } cef_client_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=4e9afcf5b6d90535ea4b98c3493e242244373f9e$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_COMMAND_LINE_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_COMMAND_LINE_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_COMMAND_LINE_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_COMMAND_LINE_CAPI_H_ | ||||||
| @@ -46,6 +44,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used to create and/or parse command line arguments. Arguments with | // Structure used to create and/or parse command line arguments. Arguments with | ||||||
| // '--', '-' and, on Windows, '/' prefixes are considered switches. Switches | // '--', '-' and, on Windows, '/' prefixes are considered switches. Switches | ||||||
| @@ -60,7 +59,7 @@ typedef struct _cef_command_line_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if this object is valid. Do not call any other functions |   // Returns true (1) if this object is valid. Do not call any other functions | ||||||
| @@ -86,8 +85,7 @@ typedef struct _cef_command_line_t { | |||||||
|   // supported on non-Windows platforms. |   // supported on non-Windows platforms. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *init_from_argv)(struct _cef_command_line_t* self, |   void (CEF_CALLBACK *init_from_argv)(struct _cef_command_line_t* self, | ||||||
|                                      int argc, |       int argc, const char* const* argv); | ||||||
|                                      const char* const* argv); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Initialize the command line with the string returned by calling |   // Initialize the command line with the string returned by calling | ||||||
| @@ -147,8 +145,7 @@ typedef struct _cef_command_line_t { | |||||||
|   /// |   /// | ||||||
|   // The resulting string must be freed by calling cef_string_userfree_free(). |   // The resulting string must be freed by calling cef_string_userfree_free(). | ||||||
|   cef_string_userfree_t (CEF_CALLBACK *get_switch_value)( |   cef_string_userfree_t (CEF_CALLBACK *get_switch_value)( | ||||||
|       struct _cef_command_line_t* self, |       struct _cef_command_line_t* self, const cef_string_t* name); | ||||||
|       const cef_string_t* name); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the map of switch names and values. If a switch has no value an |   // Returns the map of switch names and values. If a switch has no value an | ||||||
| @@ -167,8 +164,8 @@ typedef struct _cef_command_line_t { | |||||||
|   /// |   /// | ||||||
|   // Add a switch with the specified value to the end of the command line. |   // Add a switch with the specified value to the end of the command line. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* append_switch_with_value)(struct _cef_command_line_t* self, |   void (CEF_CALLBACK *append_switch_with_value)( | ||||||
|                                                const cef_string_t* name, |       struct _cef_command_line_t* self, const cef_string_t* name, | ||||||
|       const cef_string_t* value); |       const cef_string_t* value); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -196,6 +193,7 @@ typedef struct _cef_command_line_t { | |||||||
|       const cef_string_t* wrapper); |       const cef_string_t* wrapper); | ||||||
| } cef_command_line_t; | } cef_command_line_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Create a new cef_command_line_t instance. | // Create a new cef_command_line_t instance. | ||||||
| /// | /// | ||||||
| @@ -207,6 +205,7 @@ CEF_EXPORT cef_command_line_t* cef_command_line_create(); | |||||||
| /// | /// | ||||||
| CEF_EXPORT cef_command_line_t* cef_command_line_get_global(); | CEF_EXPORT cef_command_line_t* cef_command_line_get_global(); | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=fdd4de9c81a7b01a94aee020b2c314e519cd8e55$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_CONTEXT_MENU_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_CONTEXT_MENU_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_CONTEXT_MENU_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_CONTEXT_MENU_HANDLER_CAPI_H_ | ||||||
| @@ -58,15 +56,14 @@ typedef struct _cef_run_context_menu_callback_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Complete context menu display by selecting the specified |command_id| and |   // Complete context menu display by selecting the specified |command_id| and | ||||||
|   // |event_flags|. |   // |event_flags|. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *cont)(struct _cef_run_context_menu_callback_t* self, |   void (CEF_CALLBACK *cont)(struct _cef_run_context_menu_callback_t* self, | ||||||
|                            int command_id, |       int command_id, cef_event_flags_t event_flags); | ||||||
|                            cef_event_flags_t event_flags); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Cancel context menu display. |   // Cancel context menu display. | ||||||
| @@ -74,6 +71,7 @@ typedef struct _cef_run_context_menu_callback_t { | |||||||
|   void (CEF_CALLBACK *cancel)(struct _cef_run_context_menu_callback_t* self); |   void (CEF_CALLBACK *cancel)(struct _cef_run_context_menu_callback_t* self); | ||||||
| } cef_run_context_menu_callback_t; | } cef_run_context_menu_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Implement this structure to handle context menu events. The functions of this | // Implement this structure to handle context menu events. The functions of this | ||||||
| // structure will be called on the UI thread. | // structure will be called on the UI thread. | ||||||
| @@ -82,7 +80,7 @@ typedef struct _cef_context_menu_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called before a context menu is displayed. |params| provides information |   // Called before a context menu is displayed. |params| provides information | ||||||
| @@ -92,10 +90,8 @@ typedef struct _cef_context_menu_handler_t { | |||||||
|   // |model| outside of this callback. |   // |model| outside of this callback. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_before_context_menu)( |   void (CEF_CALLBACK *on_before_context_menu)( | ||||||
|       struct _cef_context_menu_handler_t* self, |       struct _cef_context_menu_handler_t* self, struct _cef_browser_t* browser, | ||||||
|       struct _cef_browser_t* browser, |       struct _cef_frame_t* frame, struct _cef_context_menu_params_t* params, | ||||||
|       struct _cef_frame_t* frame, |  | ||||||
|       struct _cef_context_menu_params_t* params, |  | ||||||
|       struct _cef_menu_model_t* model); |       struct _cef_menu_model_t* model); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -106,10 +102,8 @@ typedef struct _cef_context_menu_handler_t { | |||||||
|   // selected command ID. For default display return false (0). Do not keep |   // selected command ID. For default display return false (0). Do not keep | ||||||
|   // references to |params| or |model| outside of this callback. |   // references to |params| or |model| outside of this callback. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* run_context_menu)( |   int (CEF_CALLBACK *run_context_menu)(struct _cef_context_menu_handler_t* self, | ||||||
|       struct _cef_context_menu_handler_t* self, |       struct _cef_browser_t* browser, struct _cef_frame_t* frame, | ||||||
|       struct _cef_browser_t* browser, |  | ||||||
|       struct _cef_frame_t* frame, |  | ||||||
|       struct _cef_context_menu_params_t* params, |       struct _cef_context_menu_params_t* params, | ||||||
|       struct _cef_menu_model_t* model, |       struct _cef_menu_model_t* model, | ||||||
|       struct _cef_run_context_menu_callback_t* callback); |       struct _cef_run_context_menu_callback_t* callback); | ||||||
| @@ -124,23 +118,20 @@ typedef struct _cef_context_menu_handler_t { | |||||||
|   // this callback. |   // this callback. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *on_context_menu_command)( |   int (CEF_CALLBACK *on_context_menu_command)( | ||||||
|       struct _cef_context_menu_handler_t* self, |       struct _cef_context_menu_handler_t* self, struct _cef_browser_t* browser, | ||||||
|       struct _cef_browser_t* browser, |       struct _cef_frame_t* frame, struct _cef_context_menu_params_t* params, | ||||||
|       struct _cef_frame_t* frame, |       int command_id, cef_event_flags_t event_flags); | ||||||
|       struct _cef_context_menu_params_t* params, |  | ||||||
|       int command_id, |  | ||||||
|       cef_event_flags_t event_flags); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when the context menu is dismissed irregardless of whether the menu |   // Called when the context menu is dismissed irregardless of whether the menu | ||||||
|   // was NULL or a command was selected. |   // was NULL or a command was selected. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_context_menu_dismissed)( |   void (CEF_CALLBACK *on_context_menu_dismissed)( | ||||||
|       struct _cef_context_menu_handler_t* self, |       struct _cef_context_menu_handler_t* self, struct _cef_browser_t* browser, | ||||||
|       struct _cef_browser_t* browser, |  | ||||||
|       struct _cef_frame_t* frame); |       struct _cef_frame_t* frame); | ||||||
| } cef_context_menu_handler_t; | } cef_context_menu_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Provides information about the context menu state. The ethods of this | // Provides information about the context menu state. The ethods of this | ||||||
| // structure can only be accessed on browser process the UI thread. | // structure can only be accessed on browser process the UI thread. | ||||||
| @@ -149,7 +140,7 @@ typedef struct _cef_context_menu_params_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the X coordinate of the mouse where the context menu was invoked. |   // Returns the X coordinate of the mouse where the context menu was invoked. | ||||||
| @@ -266,8 +257,7 @@ typedef struct _cef_context_menu_params_t { | |||||||
|   // is one. |   // is one. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *get_dictionary_suggestions)( |   int (CEF_CALLBACK *get_dictionary_suggestions)( | ||||||
|       struct _cef_context_menu_params_t* self, |       struct _cef_context_menu_params_t* self, cef_string_list_t suggestions); | ||||||
|       cef_string_list_t suggestions); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if the context menu was invoked on an editable node. |   // Returns true (1) if the context menu was invoked on an editable node. | ||||||
| @@ -301,6 +291,7 @@ typedef struct _cef_context_menu_params_t { | |||||||
|   int (CEF_CALLBACK *is_pepper_menu)(struct _cef_context_menu_params_t* self); |   int (CEF_CALLBACK *is_pepper_menu)(struct _cef_context_menu_params_t* self); | ||||||
| } cef_context_menu_params_t; | } cef_context_menu_params_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=00e6d1aa80d5998d89cc272dcb199cde0add12fa$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_COOKIE_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_COOKIE_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_COOKIE_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_COOKIE_CAPI_H_ | ||||||
| @@ -59,7 +57,7 @@ typedef struct _cef_cookie_manager_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Set the schemes supported by this manager. The default schemes ("http", |   // Set the schemes supported by this manager. The default schemes ("http", | ||||||
| @@ -67,10 +65,8 @@ typedef struct _cef_cookie_manager_t { | |||||||
|   // NULL it will be executed asnychronously on the IO thread after the change |   // NULL it will be executed asnychronously on the IO thread after the change | ||||||
|   // has been applied. Must be called before any cookies are accessed. |   // has been applied. Must be called before any cookies are accessed. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* set_supported_schemes)( |   void (CEF_CALLBACK *set_supported_schemes)(struct _cef_cookie_manager_t* self, | ||||||
|       struct _cef_cookie_manager_t* self, |       cef_string_list_t schemes, struct _cef_completion_callback_t* callback); | ||||||
|       cef_string_list_t schemes, |  | ||||||
|       struct _cef_completion_callback_t* callback); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Visit all cookies on the IO thread. The returned cookies are ordered by |   // Visit all cookies on the IO thread. The returned cookies are ordered by | ||||||
| @@ -88,8 +84,7 @@ typedef struct _cef_cookie_manager_t { | |||||||
|   // Returns false (0) if cookies cannot be accessed. |   // Returns false (0) if cookies cannot be accessed. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *visit_url_cookies)(struct _cef_cookie_manager_t* self, |   int (CEF_CALLBACK *visit_url_cookies)(struct _cef_cookie_manager_t* self, | ||||||
|                                        const cef_string_t* url, |       const cef_string_t* url, int includeHttpOnly, | ||||||
|                                        int includeHttpOnly, |  | ||||||
|       struct _cef_cookie_visitor_t* visitor); |       struct _cef_cookie_visitor_t* visitor); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -102,8 +97,7 @@ typedef struct _cef_cookie_manager_t { | |||||||
|   // false (0) if an invalid URL is specified or if cookies cannot be accessed. |   // false (0) if an invalid URL is specified or if cookies cannot be accessed. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *set_cookie)(struct _cef_cookie_manager_t* self, |   int (CEF_CALLBACK *set_cookie)(struct _cef_cookie_manager_t* self, | ||||||
|                                 const cef_string_t* url, |       const cef_string_t* url, const struct _cef_cookie_t* cookie, | ||||||
|                                 const struct _cef_cookie_t* cookie, |  | ||||||
|       struct _cef_set_cookie_callback_t* callback); |       struct _cef_set_cookie_callback_t* callback); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -117,10 +111,8 @@ typedef struct _cef_cookie_manager_t { | |||||||
|   // or if cookies cannot be accessed. Cookies can alternately be deleted using |   // or if cookies cannot be accessed. Cookies can alternately be deleted using | ||||||
|   // the Visit*Cookies() functions. |   // the Visit*Cookies() functions. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* delete_cookies)( |   int (CEF_CALLBACK *delete_cookies)(struct _cef_cookie_manager_t* self, | ||||||
|       struct _cef_cookie_manager_t* self, |       const cef_string_t* url, const cef_string_t* cookie_name, | ||||||
|       const cef_string_t* url, |  | ||||||
|       const cef_string_t* cookie_name, |  | ||||||
|       struct _cef_delete_cookies_callback_t* callback); |       struct _cef_delete_cookies_callback_t* callback); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -133,10 +125,8 @@ typedef struct _cef_cookie_manager_t { | |||||||
|   // asnychronously on the IO thread after the manager's storage has been |   // asnychronously on the IO thread after the manager's storage has been | ||||||
|   // initialized. Returns false (0) if cookies cannot be accessed. |   // initialized. Returns false (0) if cookies cannot be accessed. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* set_storage_path)( |   int (CEF_CALLBACK *set_storage_path)(struct _cef_cookie_manager_t* self, | ||||||
|       struct _cef_cookie_manager_t* self, |       const cef_string_t* path, int persist_session_cookies, | ||||||
|       const cef_string_t* path, |  | ||||||
|       int persist_session_cookies, |  | ||||||
|       struct _cef_completion_callback_t* callback); |       struct _cef_completion_callback_t* callback); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -148,6 +138,7 @@ typedef struct _cef_cookie_manager_t { | |||||||
|       struct _cef_completion_callback_t* callback); |       struct _cef_completion_callback_t* callback); | ||||||
| } cef_cookie_manager_t; | } cef_cookie_manager_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Returns the global cookie manager. By default data will be stored at | // Returns the global cookie manager. By default data will be stored at | ||||||
| // CefSettings.cache_path if specified or in memory otherwise. If |callback| is | // CefSettings.cache_path if specified or in memory otherwise. If |callback| is | ||||||
| @@ -159,16 +150,6 @@ typedef struct _cef_cookie_manager_t { | |||||||
| CEF_EXPORT cef_cookie_manager_t* cef_cookie_manager_get_global_manager( | CEF_EXPORT cef_cookie_manager_t* cef_cookie_manager_get_global_manager( | ||||||
|     struct _cef_completion_callback_t* callback); |     struct _cef_completion_callback_t* callback); | ||||||
|  |  | ||||||
| /// |  | ||||||
| // Returns a cookie manager that neither stores nor retrieves cookies. All usage |  | ||||||
| // of cookies will be blocked including cookies accessed via the network |  | ||||||
| // (request/response headers), via JavaScript (document.cookie), and via |  | ||||||
| // cef_cookie_manager_t functions. No cookies will be displayed in DevTools. If |  | ||||||
| // you wish to only block cookies sent via the network use the |  | ||||||
| // cef_request_tHandler CanGetCookies and CanSetCookie functions instead. |  | ||||||
| /// |  | ||||||
| CEF_EXPORT cef_cookie_manager_t* cef_cookie_manager_get_blocking_manager(); |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Creates a new cookie manager. If |path| is NULL data will be stored in memory | // Creates a new cookie manager. If |path| is NULL data will be stored in memory | ||||||
| // only. Otherwise, data will be stored at the specified |path|. To persist | // only. Otherwise, data will be stored at the specified |path|. To persist | ||||||
| @@ -179,10 +160,10 @@ CEF_EXPORT cef_cookie_manager_t* cef_cookie_manager_get_blocking_manager(); | |||||||
| // manager's storage has been initialized. | // manager's storage has been initialized. | ||||||
| /// | /// | ||||||
| CEF_EXPORT cef_cookie_manager_t* cef_cookie_manager_create_manager( | CEF_EXPORT cef_cookie_manager_t* cef_cookie_manager_create_manager( | ||||||
|     const cef_string_t* path, |     const cef_string_t* path, int persist_session_cookies, | ||||||
|     int persist_session_cookies, |  | ||||||
|     struct _cef_completion_callback_t* callback); |     struct _cef_completion_callback_t* callback); | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure to implement for visiting cookie values. The functions of this | // Structure to implement for visiting cookie values. The functions of this | ||||||
| // structure will always be called on the IO thread. | // structure will always be called on the IO thread. | ||||||
| @@ -191,7 +172,7 @@ typedef struct _cef_cookie_visitor_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Method that will be called once for each cookie. |count| is the 0-based |   // Method that will be called once for each cookie. |count| is the 0-based | ||||||
| @@ -201,12 +182,11 @@ typedef struct _cef_cookie_visitor_t { | |||||||
|   // called if no cookies are found. |   // called if no cookies are found. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *visit)(struct _cef_cookie_visitor_t* self, |   int (CEF_CALLBACK *visit)(struct _cef_cookie_visitor_t* self, | ||||||
|                            const struct _cef_cookie_t* cookie, |       const struct _cef_cookie_t* cookie, int count, int total, | ||||||
|                            int count, |  | ||||||
|                            int total, |  | ||||||
|       int* deleteCookie); |       int* deleteCookie); | ||||||
| } cef_cookie_visitor_t; | } cef_cookie_visitor_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure to implement to be notified of asynchronous completion via | // Structure to implement to be notified of asynchronous completion via | ||||||
| // cef_cookie_manager_t::set_cookie(). | // cef_cookie_manager_t::set_cookie(). | ||||||
| @@ -215,7 +195,7 @@ typedef struct _cef_set_cookie_callback_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Method that will be called upon completion. |success| will be true (1) if |   // Method that will be called upon completion. |success| will be true (1) if | ||||||
| @@ -225,6 +205,7 @@ typedef struct _cef_set_cookie_callback_t { | |||||||
|       int success); |       int success); | ||||||
| } cef_set_cookie_callback_t; | } cef_set_cookie_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure to implement to be notified of asynchronous completion via | // Structure to implement to be notified of asynchronous completion via | ||||||
| // cef_cookie_manager_t::delete_cookies(). | // cef_cookie_manager_t::delete_cookies(). | ||||||
| @@ -233,7 +214,7 @@ typedef struct _cef_delete_cookies_callback_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Method that will be called upon completion. |num_deleted| will be the |   // Method that will be called upon completion. |num_deleted| will be the | ||||||
| @@ -243,6 +224,7 @@ typedef struct _cef_delete_cookies_callback_t { | |||||||
|       int num_deleted); |       int num_deleted); | ||||||
| } cef_delete_cookies_callback_t; | } cef_delete_cookies_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=e4da4fab11e33d34d70714be22e6f72579586ffe$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_CRASH_UTIL_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_CRASH_UTIL_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_CRASH_UTIL_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_CRASH_UTIL_CAPI_H_ | ||||||
| @@ -46,6 +44,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Crash reporting is configured using an INI-style config file named | // Crash reporting is configured using an INI-style config file named | ||||||
| // "crash_reporter.cfg". On Windows and Linux this file must be placed next to | // "crash_reporter.cfg". On Windows and Linux this file must be placed next to | ||||||
| @@ -62,9 +61,6 @@ extern "C" { | |||||||
| //           information; default to "CEF"> | //           information; default to "CEF"> | ||||||
| //  ExternalHandler=<Windows only; Name of the external handler exe to use | //  ExternalHandler=<Windows only; Name of the external handler exe to use | ||||||
| //                   instead of re-launching the main exe; default to empty> | //                   instead of re-launching the main exe; default to empty> | ||||||
| //  BrowserCrashForwardingEnabled=<macOS only; True if browser process crashes |  | ||||||
| //                                 should be forwarded to the system crash |  | ||||||
| //                                 reporter; default to false> |  | ||||||
| //  ServerURL=<crash server URL; default to empty> | //  ServerURL=<crash server URL; default to empty> | ||||||
| //  RateLimitEnabled=<True if uploads should be rate limited; default to true> | //  RateLimitEnabled=<True if uploads should be rate limited; default to true> | ||||||
| //  MaxUploadsPerDay=<Max uploads per 24 hours, used if rate limit is enabled; | //  MaxUploadsPerDay=<Max uploads per 24 hours, used if rate limit is enabled; | ||||||
| @@ -96,12 +92,6 @@ extern "C" { | |||||||
| // directory. On Linux the CefSettings.browser_subprocess_path value will be | // directory. On Linux the CefSettings.browser_subprocess_path value will be | ||||||
| // used. On macOS the existing subprocess app bundle will be used. | // used. On macOS the existing subprocess app bundle will be used. | ||||||
| // | // | ||||||
| // If "BrowserCrashForwardingEnabled" is set to true (1) on macOS then browser |  | ||||||
| // process crashes will be forwarded to the system crash reporter. This results |  | ||||||
| // in the crash UI dialog being displayed to the user and crash reports being |  | ||||||
| // logged under "~/Library/Logs/DiagnosticReports". Forwarding of crash reports |  | ||||||
| // from non-browser processes and Debug builds is always disabled. |  | ||||||
| // |  | ||||||
| // If "ServerURL" is set then crashes will be uploaded as a multi-part POST | // If "ServerURL" is set then crashes will be uploaded as a multi-part POST | ||||||
| // request to the specified URL. Otherwise, reports will only be stored locally | // request to the specified URL. Otherwise, reports will only be stored locally | ||||||
| // on disk. | // on disk. | ||||||
| @@ -129,12 +119,14 @@ extern "C" { | |||||||
| // | // | ||||||
| // CrashKeys section: | // CrashKeys section: | ||||||
| // | // | ||||||
| // A maximum of 26 crash keys of each size can be specified for use by the | // Any number of crash keys can be specified for use by the application. Crash | ||||||
| // application. Crash key values will be truncated based on the specified size | // key values will be truncated based on the specified size (small = 63 bytes, | ||||||
| // (small = 64 bytes, medium = 256 bytes, large = 1024 bytes). The value of | // medium = 252 bytes, large = 1008 bytes). The value of crash keys can be set | ||||||
| // crash keys can be set from any thread or process using the | // from any thread or process using the CefSetCrashKeyValue function. These | ||||||
| // CefSetCrashKeyValue function. These key/value pairs will be sent to the crash | // key/value pairs will be sent to the crash server along with the crash dump | ||||||
| // server along with the crash dump file. | // file. Medium and large values will be chunked for submission. For example, if | ||||||
|  | // your key is named "mykey" then the value will be broken into ordered chunks | ||||||
|  | // and submitted using keys named "mykey-1", "mykey-2", etc. | ||||||
| /// | /// | ||||||
| CEF_EXPORT int cef_crash_reporting_enabled(); | CEF_EXPORT int cef_crash_reporting_enabled(); | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=ddf4110dadc49faf08ac2744d851511c41ca403f$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_DIALOG_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_DIALOG_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_DIALOG_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_DIALOG_HANDLER_CAPI_H_ | ||||||
| @@ -47,6 +45,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Callback structure for asynchronous continuation of file dialog requests. | // Callback structure for asynchronous continuation of file dialog requests. | ||||||
| /// | /// | ||||||
| @@ -54,7 +53,7 @@ typedef struct _cef_file_dialog_callback_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Continue the file selection. |selected_accept_filter| should be the 0-based |   // Continue the file selection. |selected_accept_filter| should be the 0-based | ||||||
| @@ -64,8 +63,7 @@ typedef struct _cef_file_dialog_callback_t { | |||||||
|   // value is treated the same as calling cancel(). |   // value is treated the same as calling cancel(). | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *cont)(struct _cef_file_dialog_callback_t* self, |   void (CEF_CALLBACK *cont)(struct _cef_file_dialog_callback_t* self, | ||||||
|                            int selected_accept_filter, |       int selected_accept_filter, cef_string_list_t file_paths); | ||||||
|                            cef_string_list_t file_paths); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Cancel the file selection. |   // Cancel the file selection. | ||||||
| @@ -73,6 +71,7 @@ typedef struct _cef_file_dialog_callback_t { | |||||||
|   void (CEF_CALLBACK *cancel)(struct _cef_file_dialog_callback_t* self); |   void (CEF_CALLBACK *cancel)(struct _cef_file_dialog_callback_t* self); | ||||||
| } cef_file_dialog_callback_t; | } cef_file_dialog_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Implement this structure to handle dialog events. The functions of this | // Implement this structure to handle dialog events. The functions of this | ||||||
| // structure will be called on the browser process UI thread. | // structure will be called on the browser process UI thread. | ||||||
| @@ -81,7 +80,7 @@ typedef struct _cef_dialog_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called to run a file chooser dialog. |mode| represents the type of dialog |   // Called to run a file chooser dialog. |mode| represents the type of dialog | ||||||
| @@ -98,17 +97,14 @@ typedef struct _cef_dialog_handler_t { | |||||||
|   // return true (1) and execute |callback| either inline or at a later time. To |   // return true (1) and execute |callback| either inline or at a later time. To | ||||||
|   // display the default dialog return false (0). |   // display the default dialog return false (0). | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* on_file_dialog)( |   int (CEF_CALLBACK *on_file_dialog)(struct _cef_dialog_handler_t* self, | ||||||
|       struct _cef_dialog_handler_t* self, |       struct _cef_browser_t* browser, cef_file_dialog_mode_t mode, | ||||||
|       struct _cef_browser_t* browser, |       const cef_string_t* title, const cef_string_t* default_file_path, | ||||||
|       cef_file_dialog_mode_t mode, |       cef_string_list_t accept_filters, int selected_accept_filter, | ||||||
|       const cef_string_t* title, |  | ||||||
|       const cef_string_t* default_file_path, |  | ||||||
|       cef_string_list_t accept_filters, |  | ||||||
|       int selected_accept_filter, |  | ||||||
|       struct _cef_file_dialog_callback_t* callback); |       struct _cef_file_dialog_callback_t* callback); | ||||||
| } cef_dialog_handler_t; | } cef_dialog_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=c7641e41aca6bf30b9c36092861f061d2b16ff82$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_DISPLAY_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_DISPLAY_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_DISPLAY_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_DISPLAY_HANDLER_CAPI_H_ | ||||||
| @@ -48,6 +46,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Implement this structure to handle events related to browser display state. | // Implement this structure to handle events related to browser display state. | ||||||
| // The functions of this structure will be called on the UI thread. | // The functions of this structure will be called on the UI thread. | ||||||
| @@ -56,29 +55,26 @@ typedef struct _cef_display_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when a frame's address has changed. |   // Called when a frame's address has changed. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_address_change)(struct _cef_display_handler_t* self, |   void (CEF_CALLBACK *on_address_change)(struct _cef_display_handler_t* self, | ||||||
|                                         struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, struct _cef_frame_t* frame, | ||||||
|                                         struct _cef_frame_t* frame, |  | ||||||
|       const cef_string_t* url); |       const cef_string_t* url); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when the page title changes. |   // Called when the page title changes. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_title_change)(struct _cef_display_handler_t* self, |   void (CEF_CALLBACK *on_title_change)(struct _cef_display_handler_t* self, | ||||||
|                                       struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, const cef_string_t* title); | ||||||
|                                       const cef_string_t* title); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when the page icon changes. |   // Called when the page icon changes. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_favicon_urlchange)(struct _cef_display_handler_t* self, |   void (CEF_CALLBACK *on_favicon_urlchange)(struct _cef_display_handler_t* self, | ||||||
|                                            struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, cef_string_list_t icon_urls); | ||||||
|                                            cef_string_list_t icon_urls); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when web content in the page has toggled fullscreen mode. If |   // Called when web content in the page has toggled fullscreen mode. If | ||||||
| @@ -88,8 +84,7 @@ typedef struct _cef_display_handler_t { | |||||||
|   // responsible for resizing the browser if desired. |   // responsible for resizing the browser if desired. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_fullscreen_mode_change)( |   void (CEF_CALLBACK *on_fullscreen_mode_change)( | ||||||
|       struct _cef_display_handler_t* self, |       struct _cef_display_handler_t* self, struct _cef_browser_t* browser, | ||||||
|       struct _cef_browser_t* browser, |  | ||||||
|       int fullscreen); |       int fullscreen); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -101,48 +96,25 @@ typedef struct _cef_display_handler_t { | |||||||
|   // for drawing tooltips and the return value is ignored. |   // for drawing tooltips and the return value is ignored. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *on_tooltip)(struct _cef_display_handler_t* self, |   int (CEF_CALLBACK *on_tooltip)(struct _cef_display_handler_t* self, | ||||||
|                                 struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, cef_string_t* text); | ||||||
|                                 cef_string_t* text); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when the browser receives a status message. |value| contains the |   // Called when the browser receives a status message. |value| contains the | ||||||
|   // text that will be displayed in the status message. |   // text that will be displayed in the status message. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_status_message)(struct _cef_display_handler_t* self, |   void (CEF_CALLBACK *on_status_message)(struct _cef_display_handler_t* self, | ||||||
|                                         struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, const cef_string_t* value); | ||||||
|                                         const cef_string_t* value); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called to display a console message. Return true (1) to stop the message |   // Called to display a console message. Return true (1) to stop the message | ||||||
|   // from being output to the console. |   // from being output to the console. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *on_console_message)(struct _cef_display_handler_t* self, |   int (CEF_CALLBACK *on_console_message)(struct _cef_display_handler_t* self, | ||||||
|                                         struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, const cef_string_t* message, | ||||||
|                                         cef_log_severity_t level, |       const cef_string_t* source, int line); | ||||||
|                                         const cef_string_t* message, |  | ||||||
|                                         const cef_string_t* source, |  | ||||||
|                                         int line); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called when auto-resize is enabled via |  | ||||||
|   // cef_browser_host_t::SetAutoResizeEnabled and the contents have auto- |  | ||||||
|   // resized. |new_size| will be the desired size in view coordinates. Return |  | ||||||
|   // true (1) if the resize was handled or false (0) for default handling. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* on_auto_resize)(struct _cef_display_handler_t* self, |  | ||||||
|                                     struct _cef_browser_t* browser, |  | ||||||
|                                     const cef_size_t* new_size); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called when the overall page loading progress has changed. |progress| |  | ||||||
|   // ranges from 0.0 to 1.0. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* on_loading_progress_change)( |  | ||||||
|       struct _cef_display_handler_t* self, |  | ||||||
|       struct _cef_browser_t* browser, |  | ||||||
|       double progress); |  | ||||||
| } cef_display_handler_t; | } cef_display_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=b9bef5257ecbd1933356fcc02687bf725bff9277$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_DOM_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_DOM_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_DOM_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_DOM_CAPI_H_ | ||||||
| @@ -57,7 +55,7 @@ typedef struct _cef_domvisitor_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Method executed for visiting the DOM. The document object passed to this |   // Method executed for visiting the DOM. The document object passed to this | ||||||
| @@ -70,6 +68,7 @@ typedef struct _cef_domvisitor_t { | |||||||
|       struct _cef_domdocument_t* document); |       struct _cef_domdocument_t* document); | ||||||
| } cef_domvisitor_t; | } cef_domvisitor_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used to represent a DOM document. The functions of this structure | // Structure used to represent a DOM document. The functions of this structure | ||||||
| // should only be called on the render process main thread thread. | // should only be called on the render process main thread thread. | ||||||
| @@ -78,7 +77,7 @@ typedef struct _cef_domdocument_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the document type. |   // Returns the document type. | ||||||
| @@ -115,8 +114,7 @@ typedef struct _cef_domdocument_t { | |||||||
|   // Returns the document element with the specified ID value. |   // Returns the document element with the specified ID value. | ||||||
|   /// |   /// | ||||||
|   struct _cef_domnode_t* (CEF_CALLBACK *get_element_by_id)( |   struct _cef_domnode_t* (CEF_CALLBACK *get_element_by_id)( | ||||||
|       struct _cef_domdocument_t* self, |       struct _cef_domdocument_t* self, const cef_string_t* id); | ||||||
|       const cef_string_t* id); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the node that currently has keyboard focus. |   // Returns the node that currently has keyboard focus. | ||||||
| @@ -167,10 +165,10 @@ typedef struct _cef_domdocument_t { | |||||||
|   /// |   /// | ||||||
|   // The resulting string must be freed by calling cef_string_userfree_free(). |   // The resulting string must be freed by calling cef_string_userfree_free(). | ||||||
|   cef_string_userfree_t (CEF_CALLBACK *get_complete_url)( |   cef_string_userfree_t (CEF_CALLBACK *get_complete_url)( | ||||||
|       struct _cef_domdocument_t* self, |       struct _cef_domdocument_t* self, const cef_string_t* partialURL); | ||||||
|       const cef_string_t* partialURL); |  | ||||||
| } cef_domdocument_t; | } cef_domdocument_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used to represent a DOM node. The functions of this structure | // Structure used to represent a DOM node. The functions of this structure | ||||||
| // should only be called on the render process main thread. | // should only be called on the render process main thread. | ||||||
| @@ -179,7 +177,7 @@ typedef struct _cef_domnode_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the type for this node. |   // Returns the type for this node. | ||||||
| @@ -254,7 +252,8 @@ typedef struct _cef_domnode_t { | |||||||
|   /// |   /// | ||||||
|   // Returns the parent node. |   // Returns the parent node. | ||||||
|   /// |   /// | ||||||
|   struct _cef_domnode_t*(CEF_CALLBACK* get_parent)(struct _cef_domnode_t* self); |   struct _cef_domnode_t* (CEF_CALLBACK *get_parent)( | ||||||
|  |       struct _cef_domnode_t* self); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the previous sibling node. |   // Returns the previous sibling node. | ||||||
| @@ -285,6 +284,7 @@ typedef struct _cef_domnode_t { | |||||||
|   struct _cef_domnode_t* (CEF_CALLBACK *get_last_child)( |   struct _cef_domnode_t* (CEF_CALLBACK *get_last_child)( | ||||||
|       struct _cef_domnode_t* self); |       struct _cef_domnode_t* self); | ||||||
|  |  | ||||||
|  |  | ||||||
|   // The following functions are valid only for element nodes. |   // The following functions are valid only for element nodes. | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -310,8 +310,7 @@ typedef struct _cef_domnode_t { | |||||||
|   /// |   /// | ||||||
|   // The resulting string must be freed by calling cef_string_userfree_free(). |   // The resulting string must be freed by calling cef_string_userfree_free(). | ||||||
|   cef_string_userfree_t (CEF_CALLBACK *get_element_attribute)( |   cef_string_userfree_t (CEF_CALLBACK *get_element_attribute)( | ||||||
|       struct _cef_domnode_t* self, |       struct _cef_domnode_t* self, const cef_string_t* attrName); | ||||||
|       const cef_string_t* attrName); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns a map of all element attributes. |   // Returns a map of all element attributes. | ||||||
| @@ -324,8 +323,7 @@ typedef struct _cef_domnode_t { | |||||||
|   // on success. |   // on success. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *set_element_attribute)(struct _cef_domnode_t* self, |   int (CEF_CALLBACK *set_element_attribute)(struct _cef_domnode_t* self, | ||||||
|                                            const cef_string_t* attrName, |       const cef_string_t* attrName, const cef_string_t* value); | ||||||
|                                            const cef_string_t* value); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the inner text of the element. |   // Returns the inner text of the element. | ||||||
| @@ -340,6 +338,7 @@ typedef struct _cef_domnode_t { | |||||||
|   cef_rect_t (CEF_CALLBACK *get_element_bounds)(struct _cef_domnode_t* self); |   cef_rect_t (CEF_CALLBACK *get_element_bounds)(struct _cef_domnode_t* self); | ||||||
| } cef_domnode_t; | } cef_domnode_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=d9cedd8c411dd064eacde55a95d6e05303dea365$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_DOWNLOAD_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_DOWNLOAD_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_DOWNLOAD_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_DOWNLOAD_HANDLER_CAPI_H_ | ||||||
| @@ -48,6 +46,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Callback structure used to asynchronously continue a download. | // Callback structure used to asynchronously continue a download. | ||||||
| /// | /// | ||||||
| @@ -55,7 +54,7 @@ typedef struct _cef_before_download_callback_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Call to continue the download. Set |download_path| to the full file path |   // Call to continue the download. Set |download_path| to the full file path | ||||||
| @@ -64,10 +63,10 @@ typedef struct _cef_before_download_callback_t { | |||||||
|   // (1) if you do wish to show the default "Save As" dialog. |   // (1) if you do wish to show the default "Save As" dialog. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *cont)(struct _cef_before_download_callback_t* self, |   void (CEF_CALLBACK *cont)(struct _cef_before_download_callback_t* self, | ||||||
|                            const cef_string_t* download_path, |       const cef_string_t* download_path, int show_dialog); | ||||||
|                            int show_dialog); |  | ||||||
| } cef_before_download_callback_t; | } cef_before_download_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Callback structure used to asynchronously cancel a download. | // Callback structure used to asynchronously cancel a download. | ||||||
| /// | /// | ||||||
| @@ -75,7 +74,7 @@ typedef struct _cef_download_item_callback_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Call to cancel the download. |   // Call to cancel the download. | ||||||
| @@ -93,6 +92,7 @@ typedef struct _cef_download_item_callback_t { | |||||||
|   void (CEF_CALLBACK *resume)(struct _cef_download_item_callback_t* self); |   void (CEF_CALLBACK *resume)(struct _cef_download_item_callback_t* self); | ||||||
| } cef_download_item_callback_t; | } cef_download_item_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used to handle file downloads. The functions of this structure will | // Structure used to handle file downloads. The functions of this structure will | ||||||
| // called on the browser process UI thread. | // called on the browser process UI thread. | ||||||
| @@ -101,7 +101,7 @@ typedef struct _cef_download_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called before a download begins. |suggested_name| is the suggested name for |   // Called before a download begins. |suggested_name| is the suggested name for | ||||||
| @@ -110,8 +110,7 @@ typedef struct _cef_download_handler_t { | |||||||
|   // download if desired. Do not keep a reference to |download_item| outside of |   // download if desired. Do not keep a reference to |download_item| outside of | ||||||
|   // this function. |   // this function. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* on_before_download)( |   void (CEF_CALLBACK *on_before_download)(struct _cef_download_handler_t* self, | ||||||
|       struct _cef_download_handler_t* self, |  | ||||||
|       struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, | ||||||
|       struct _cef_download_item_t* download_item, |       struct _cef_download_item_t* download_item, | ||||||
|       const cef_string_t* suggested_name, |       const cef_string_t* suggested_name, | ||||||
| @@ -124,13 +123,13 @@ typedef struct _cef_download_handler_t { | |||||||
|   // download if desired. Do not keep a reference to |download_item| outside of |   // download if desired. Do not keep a reference to |download_item| outside of | ||||||
|   // this function. |   // this function. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* on_download_updated)( |   void (CEF_CALLBACK *on_download_updated)(struct _cef_download_handler_t* self, | ||||||
|       struct _cef_download_handler_t* self, |  | ||||||
|       struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, | ||||||
|       struct _cef_download_item_t* download_item, |       struct _cef_download_item_t* download_item, | ||||||
|       struct _cef_download_item_callback_t* callback); |       struct _cef_download_item_callback_t* callback); | ||||||
| } cef_download_handler_t; | } cef_download_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=c17ff4fd6d85b1db10dce2e1a5dbea5a4b17e4da$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_DOWNLOAD_ITEM_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_DOWNLOAD_ITEM_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_DOWNLOAD_ITEM_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_DOWNLOAD_ITEM_CAPI_H_ | ||||||
| @@ -46,6 +44,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used to represent a download item. | // Structure used to represent a download item. | ||||||
| /// | /// | ||||||
| @@ -53,7 +52,7 @@ typedef struct _cef_download_item_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if this object is valid. Do not call any other functions |   // Returns true (1) if this object is valid. Do not call any other functions | ||||||
| @@ -155,6 +154,7 @@ typedef struct _cef_download_item_t { | |||||||
|       struct _cef_download_item_t* self); |       struct _cef_download_item_t* self); | ||||||
| } cef_download_item_t; | } cef_download_item_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,21 +33,19 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=b72ebf98f79f28a18366c037e65e98326d4a350a$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_DRAG_DATA_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_DRAG_DATA_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_DRAG_DATA_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_DRAG_DATA_CAPI_H_ | ||||||
| #pragma once | #pragma once | ||||||
|  |  | ||||||
| #include "include/capi/cef_base_capi.h" | #include "include/capi/cef_base_capi.h" | ||||||
| #include "include/capi/cef_image_capi.h" |  | ||||||
| #include "include/capi/cef_stream_capi.h" | #include "include/capi/cef_stream_capi.h" | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used to represent drag data. The functions of this structure may be | // Structure used to represent drag data. The functions of this structure may be | ||||||
| // called on any thread. | // called on any thread. | ||||||
| @@ -56,7 +54,7 @@ typedef struct _cef_drag_data_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns a copy of the current object. |   // Returns a copy of the current object. | ||||||
| @@ -196,31 +194,16 @@ typedef struct _cef_drag_data_t { | |||||||
|   // Add a file that is being dragged into the webview. |   // Add a file that is being dragged into the webview. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *add_file)(struct _cef_drag_data_t* self, |   void (CEF_CALLBACK *add_file)(struct _cef_drag_data_t* self, | ||||||
|                                const cef_string_t* path, |       const cef_string_t* path, const cef_string_t* display_name); | ||||||
|                                const cef_string_t* display_name); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Get the image representation of drag data. May return NULL if no image |  | ||||||
|   // representation is available. |  | ||||||
|   /// |  | ||||||
|   struct _cef_image_t*(CEF_CALLBACK* get_image)(struct _cef_drag_data_t* self); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Get the image hotspot (drag start location relative to image dimensions). |  | ||||||
|   /// |  | ||||||
|   cef_point_t(CEF_CALLBACK* get_image_hotspot)(struct _cef_drag_data_t* self); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns true (1) if an image representation of drag data is available. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* has_image)(struct _cef_drag_data_t* self); |  | ||||||
| } cef_drag_data_t; | } cef_drag_data_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Create a new cef_drag_data_t object. | // Create a new cef_drag_data_t object. | ||||||
| /// | /// | ||||||
| CEF_EXPORT cef_drag_data_t* cef_drag_data_create(); | CEF_EXPORT cef_drag_data_t* cef_drag_data_create(); | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=88d9a33295e7fb7238bcb18b25d12906ba4cb791$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_DRAG_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_DRAG_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_DRAG_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_DRAG_HANDLER_CAPI_H_ | ||||||
| @@ -48,6 +46,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Implement this structure to handle events related to dragging. The functions | // Implement this structure to handle events related to dragging. The functions | ||||||
| // of this structure will be called on the UI thread. | // of this structure will be called on the UI thread. | ||||||
| @@ -56,7 +55,7 @@ typedef struct _cef_drag_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when an external drag event enters the browser window. |dragData| |   // Called when an external drag event enters the browser window. |dragData| | ||||||
| @@ -65,8 +64,7 @@ typedef struct _cef_drag_handler_t { | |||||||
|   // to cancel the drag event. |   // to cancel the drag event. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *on_drag_enter)(struct _cef_drag_handler_t* self, |   int (CEF_CALLBACK *on_drag_enter)(struct _cef_drag_handler_t* self, | ||||||
|                                    struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, struct _cef_drag_data_t* dragData, | ||||||
|                                    struct _cef_drag_data_t* dragData, |  | ||||||
|       cef_drag_operations_mask_t mask); |       cef_drag_operations_mask_t mask); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -77,12 +75,11 @@ typedef struct _cef_drag_handler_t { | |||||||
|   // this function will be called with an NULL vector. |   // this function will be called with an NULL vector. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_draggable_regions_changed)( |   void (CEF_CALLBACK *on_draggable_regions_changed)( | ||||||
|       struct _cef_drag_handler_t* self, |       struct _cef_drag_handler_t* self, struct _cef_browser_t* browser, | ||||||
|       struct _cef_browser_t* browser, |       size_t regionsCount, cef_draggable_region_t const* regions); | ||||||
|       size_t regionsCount, |  | ||||||
|       cef_draggable_region_t const* regions); |  | ||||||
| } cef_drag_handler_t; | } cef_drag_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,130 +0,0 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. |  | ||||||
| // |  | ||||||
| // Redistribution and use in source and binary forms, with or without |  | ||||||
| // modification, are permitted provided that the following conditions are |  | ||||||
| // met: |  | ||||||
| // |  | ||||||
| //    * Redistributions of source code must retain the above copyright |  | ||||||
| // notice, this list of conditions and the following disclaimer. |  | ||||||
| //    * Redistributions in binary form must reproduce the above |  | ||||||
| // copyright notice, this list of conditions and the following disclaimer |  | ||||||
| // in the documentation and/or other materials provided with the |  | ||||||
| // distribution. |  | ||||||
| //    * Neither the name of Google Inc. nor the name Chromium Embedded |  | ||||||
| // Framework nor the names of its contributors may be used to endorse |  | ||||||
| // or promote products derived from this software without specific prior |  | ||||||
| // written permission. |  | ||||||
| // |  | ||||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |  | ||||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |  | ||||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |  | ||||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |  | ||||||
| // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |  | ||||||
| // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |  | ||||||
| // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |  | ||||||
| // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |  | ||||||
| // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |  | ||||||
| // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |  | ||||||
| // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  | ||||||
| // |  | ||||||
| // --------------------------------------------------------------------------- |  | ||||||
| // |  | ||||||
| // This file was generated by the CEF translator tool and should not edited |  | ||||||
| // by hand. See the translator.README.txt file in the tools directory for |  | ||||||
| // more information. |  | ||||||
| // |  | ||||||
| // $hash=b681f766235613cce8a09617e7ffb76fee5545a2$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_EXTENSION_CAPI_H_ |  | ||||||
| #define CEF_INCLUDE_CAPI_CEF_EXTENSION_CAPI_H_ |  | ||||||
| #pragma once |  | ||||||
|  |  | ||||||
| #include "include/capi/cef_base_capi.h" |  | ||||||
| #include "include/capi/cef_values_capi.h" |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus |  | ||||||
| extern "C" { |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| struct _cef_extension_handler_t; |  | ||||||
| struct _cef_request_context_t; |  | ||||||
|  |  | ||||||
| /// |  | ||||||
| // Object representing an extension. Methods may be called on any thread unless |  | ||||||
| // otherwise indicated. |  | ||||||
| /// |  | ||||||
| typedef struct _cef_extension_t { |  | ||||||
|   /// |  | ||||||
|   // Base structure. |  | ||||||
|   /// |  | ||||||
|   cef_base_ref_counted_t base; |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns the unique extension identifier. This is calculated based on the |  | ||||||
|   // extension public key, if available, or on the extension path. See |  | ||||||
|   // https://developer.chrome.com/extensions/manifest/key for details. |  | ||||||
|   /// |  | ||||||
|   // The resulting string must be freed by calling cef_string_userfree_free(). |  | ||||||
|   cef_string_userfree_t(CEF_CALLBACK* get_identifier)( |  | ||||||
|       struct _cef_extension_t* self); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns the absolute path to the extension directory on disk. This value |  | ||||||
|   // will be prefixed with PK_DIR_RESOURCES if a relative path was passed to |  | ||||||
|   // cef_request_tContext::LoadExtension. |  | ||||||
|   /// |  | ||||||
|   // The resulting string must be freed by calling cef_string_userfree_free(). |  | ||||||
|   cef_string_userfree_t(CEF_CALLBACK* get_path)(struct _cef_extension_t* self); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns the extension manifest contents as a cef_dictionary_value_t object. |  | ||||||
|   // See https://developer.chrome.com/extensions/manifest for details. |  | ||||||
|   /// |  | ||||||
|   struct _cef_dictionary_value_t*(CEF_CALLBACK* get_manifest)( |  | ||||||
|       struct _cef_extension_t* self); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns true (1) if this object is the same extension as |that| object. |  | ||||||
|   // Extensions are considered the same if identifier, path and loader context |  | ||||||
|   // match. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* is_same)(struct _cef_extension_t* self, |  | ||||||
|                              struct _cef_extension_t* that); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns the handler for this extension. Will return NULL for internal |  | ||||||
|   // extensions or if no handler was passed to |  | ||||||
|   // cef_request_tContext::LoadExtension. |  | ||||||
|   /// |  | ||||||
|   struct _cef_extension_handler_t*(CEF_CALLBACK* get_handler)( |  | ||||||
|       struct _cef_extension_t* self); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns the request context that loaded this extension. Will return NULL |  | ||||||
|   // for internal extensions or if the extension has been unloaded. See the |  | ||||||
|   // cef_request_tContext::LoadExtension documentation for more information |  | ||||||
|   // about loader contexts. Must be called on the browser process UI thread. |  | ||||||
|   /// |  | ||||||
|   struct _cef_request_context_t*(CEF_CALLBACK* get_loader_context)( |  | ||||||
|       struct _cef_extension_t* self); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns true (1) if this extension is currently loaded. Must be called on |  | ||||||
|   // the browser process UI thread. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* is_loaded)(struct _cef_extension_t* self); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Unload this extension if it is not an internal extension and is currently |  | ||||||
|   // loaded. Will result in a call to |  | ||||||
|   // cef_extension_tHandler::OnExtensionUnloaded on success. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* unload)(struct _cef_extension_t* self); |  | ||||||
| } cef_extension_t; |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus |  | ||||||
| } |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #endif  // CEF_INCLUDE_CAPI_CEF_EXTENSION_CAPI_H_ |  | ||||||
| @@ -1,210 +0,0 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. |  | ||||||
| // |  | ||||||
| // Redistribution and use in source and binary forms, with or without |  | ||||||
| // modification, are permitted provided that the following conditions are |  | ||||||
| // met: |  | ||||||
| // |  | ||||||
| //    * Redistributions of source code must retain the above copyright |  | ||||||
| // notice, this list of conditions and the following disclaimer. |  | ||||||
| //    * Redistributions in binary form must reproduce the above |  | ||||||
| // copyright notice, this list of conditions and the following disclaimer |  | ||||||
| // in the documentation and/or other materials provided with the |  | ||||||
| // distribution. |  | ||||||
| //    * Neither the name of Google Inc. nor the name Chromium Embedded |  | ||||||
| // Framework nor the names of its contributors may be used to endorse |  | ||||||
| // or promote products derived from this software without specific prior |  | ||||||
| // written permission. |  | ||||||
| // |  | ||||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |  | ||||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |  | ||||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |  | ||||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |  | ||||||
| // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |  | ||||||
| // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |  | ||||||
| // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |  | ||||||
| // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |  | ||||||
| // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |  | ||||||
| // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |  | ||||||
| // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  | ||||||
| // |  | ||||||
| // --------------------------------------------------------------------------- |  | ||||||
| // |  | ||||||
| // This file was generated by the CEF translator tool and should not edited |  | ||||||
| // by hand. See the translator.README.txt file in the tools directory for |  | ||||||
| // more information. |  | ||||||
| // |  | ||||||
| // $hash=9ce34129b7058aaba2e2f77cd63e3edb23e70bb7$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_EXTENSION_HANDLER_CAPI_H_ |  | ||||||
| #define CEF_INCLUDE_CAPI_CEF_EXTENSION_HANDLER_CAPI_H_ |  | ||||||
| #pragma once |  | ||||||
|  |  | ||||||
| #include "include/capi/cef_base_capi.h" |  | ||||||
| #include "include/capi/cef_browser_capi.h" |  | ||||||
| #include "include/capi/cef_extension_capi.h" |  | ||||||
| #include "include/capi/cef_stream_capi.h" |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus |  | ||||||
| extern "C" { |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| struct _cef_client_t; |  | ||||||
|  |  | ||||||
| /// |  | ||||||
| // Callback structure used for asynchronous continuation of |  | ||||||
| // cef_extension_tHandler::GetExtensionResource. |  | ||||||
| /// |  | ||||||
| typedef struct _cef_get_extension_resource_callback_t { |  | ||||||
|   /// |  | ||||||
|   // Base structure. |  | ||||||
|   /// |  | ||||||
|   cef_base_ref_counted_t base; |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Continue the request. Read the resource contents from |stream|. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* cont)(struct _cef_get_extension_resource_callback_t* self, |  | ||||||
|                            struct _cef_stream_reader_t* stream); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Cancel the request. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* cancel)( |  | ||||||
|       struct _cef_get_extension_resource_callback_t* self); |  | ||||||
| } cef_get_extension_resource_callback_t; |  | ||||||
|  |  | ||||||
| /// |  | ||||||
| // Implement this structure to handle events related to browser extensions. The |  | ||||||
| // functions of this structure will be called on the UI thread. See |  | ||||||
| // cef_request_tContext::LoadExtension for information about extension loading. |  | ||||||
| /// |  | ||||||
| typedef struct _cef_extension_handler_t { |  | ||||||
|   /// |  | ||||||
|   // Base structure. |  | ||||||
|   /// |  | ||||||
|   cef_base_ref_counted_t base; |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called if the cef_request_tContext::LoadExtension request fails. |result| |  | ||||||
|   // will be the error code. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* on_extension_load_failed)( |  | ||||||
|       struct _cef_extension_handler_t* self, |  | ||||||
|       cef_errorcode_t result); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called if the cef_request_tContext::LoadExtension request succeeds. |  | ||||||
|   // |extension| is the loaded extension. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* on_extension_loaded)(struct _cef_extension_handler_t* self, |  | ||||||
|                                           struct _cef_extension_t* extension); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called after the cef_extension_t::Unload request has completed. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* on_extension_unloaded)( |  | ||||||
|       struct _cef_extension_handler_t* self, |  | ||||||
|       struct _cef_extension_t* extension); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called when an extension needs a browser to host a background script |  | ||||||
|   // specified via the "background" manifest key. The browser will have no |  | ||||||
|   // visible window and cannot be displayed. |extension| is the extension that |  | ||||||
|   // is loading the background script. |url| is an internally generated |  | ||||||
|   // reference to an HTML page that will be used to load the background script |  | ||||||
|   // via a <script> src attribute. To allow creation of the browser optionally |  | ||||||
|   // modify |client| and |settings| and return false (0). To cancel creation of |  | ||||||
|   // the browser (and consequently cancel load of the background script) return |  | ||||||
|   // true (1). Successful creation will be indicated by a call to |  | ||||||
|   // cef_life_span_handler_t::OnAfterCreated, and |  | ||||||
|   // cef_browser_host_t::IsBackgroundHost will return true (1) for the resulting |  | ||||||
|   // browser. See https://developer.chrome.com/extensions/event_pages for more |  | ||||||
|   // information about extension background script usage. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* on_before_background_browser)( |  | ||||||
|       struct _cef_extension_handler_t* self, |  | ||||||
|       struct _cef_extension_t* extension, |  | ||||||
|       const cef_string_t* url, |  | ||||||
|       struct _cef_client_t** client, |  | ||||||
|       struct _cef_browser_settings_t* settings); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called when an extension API (e.g. chrome.tabs.create) requests creation of |  | ||||||
|   // a new browser. |extension| and |browser| are the source of the API call. |  | ||||||
|   // |active_browser| may optionally be specified via the windowId property or |  | ||||||
|   // returned via the get_active_browser() callback and provides the default |  | ||||||
|   // |client| and |settings| values for the new browser. |index| is the position |  | ||||||
|   // value optionally specified via the index property. |url| is the URL that |  | ||||||
|   // will be loaded in the browser. |active| is true (1) if the new browser |  | ||||||
|   // should be active when opened.  To allow creation of the browser optionally |  | ||||||
|   // modify |windowInfo|, |client| and |settings| and return false (0). To |  | ||||||
|   // cancel creation of the browser return true (1). Successful creation will be |  | ||||||
|   // indicated by a call to cef_life_span_handler_t::OnAfterCreated. Any |  | ||||||
|   // modifications to |windowInfo| will be ignored if |active_browser| is |  | ||||||
|   // wrapped in a cef_browser_view_t. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* on_before_browser)( |  | ||||||
|       struct _cef_extension_handler_t* self, |  | ||||||
|       struct _cef_extension_t* extension, |  | ||||||
|       struct _cef_browser_t* browser, |  | ||||||
|       struct _cef_browser_t* active_browser, |  | ||||||
|       int index, |  | ||||||
|       const cef_string_t* url, |  | ||||||
|       int active, |  | ||||||
|       struct _cef_window_info_t* windowInfo, |  | ||||||
|       struct _cef_client_t** client, |  | ||||||
|       struct _cef_browser_settings_t* settings); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called when no tabId is specified to an extension API call that accepts a |  | ||||||
|   // tabId parameter (e.g. chrome.tabs.*). |extension| and |browser| are the |  | ||||||
|   // source of the API call. Return the browser that will be acted on by the API |  | ||||||
|   // call or return NULL to act on |browser|. The returned browser must share |  | ||||||
|   // the same cef_request_tContext as |browser|. Incognito browsers should not |  | ||||||
|   // be considered unless the source extension has incognito access enabled, in |  | ||||||
|   // which case |include_incognito| will be true (1). |  | ||||||
|   /// |  | ||||||
|   struct _cef_browser_t*(CEF_CALLBACK* get_active_browser)( |  | ||||||
|       struct _cef_extension_handler_t* self, |  | ||||||
|       struct _cef_extension_t* extension, |  | ||||||
|       struct _cef_browser_t* browser, |  | ||||||
|       int include_incognito); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called when the tabId associated with |target_browser| is specified to an |  | ||||||
|   // extension API call that accepts a tabId parameter (e.g. chrome.tabs.*). |  | ||||||
|   // |extension| and |browser| are the source of the API call. Return true (1) |  | ||||||
|   // to allow access of false (0) to deny access. Access to incognito browsers |  | ||||||
|   // should not be allowed unless the source extension has incognito access |  | ||||||
|   // enabled, in which case |include_incognito| will be true (1). |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* can_access_browser)(struct _cef_extension_handler_t* self, |  | ||||||
|                                         struct _cef_extension_t* extension, |  | ||||||
|                                         struct _cef_browser_t* browser, |  | ||||||
|                                         int include_incognito, |  | ||||||
|                                         struct _cef_browser_t* target_browser); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called to retrieve an extension resource that would normally be loaded from |  | ||||||
|   // disk (e.g. if a file parameter is specified to chrome.tabs.executeScript). |  | ||||||
|   // |extension| and |browser| are the source of the resource request. |file| is |  | ||||||
|   // the requested relative file path. To handle the resource request return |  | ||||||
|   // true (1) and execute |callback| either synchronously or asynchronously. For |  | ||||||
|   // the default behavior which reads the resource from the extension directory |  | ||||||
|   // on disk return false (0). Localization substitutions will not be applied to |  | ||||||
|   // resources handled via this function. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* get_extension_resource)( |  | ||||||
|       struct _cef_extension_handler_t* self, |  | ||||||
|       struct _cef_extension_t* extension, |  | ||||||
|       struct _cef_browser_t* browser, |  | ||||||
|       const cef_string_t* file, |  | ||||||
|       struct _cef_get_extension_resource_callback_t* callback); |  | ||||||
| } cef_extension_handler_t; |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus |  | ||||||
| } |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #endif  // CEF_INCLUDE_CAPI_CEF_EXTENSION_HANDLER_CAPI_H_ |  | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=51f4b75a01dbf07fda0eb4bdbbe7a7f3d3b13bdb$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_FILE_UTIL_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_FILE_UTIL_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_FILE_UTIL_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_FILE_UTIL_CAPI_H_ | ||||||
| @@ -46,6 +44,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Creates a directory and all parent directories if they don't already exist. | // Creates a directory and all parent directories if they don't already exist. | ||||||
| // Returns true (1) on successful creation or if the directory already exists. | // Returns true (1) on successful creation or if the directory already exists. | ||||||
| @@ -83,8 +82,7 @@ CEF_EXPORT int cef_create_new_temp_directory(const cef_string_t* prefix, | |||||||
| // or IO threads is not allowed. | // or IO threads is not allowed. | ||||||
| /// | /// | ||||||
| CEF_EXPORT int cef_create_temp_directory_in_directory( | CEF_EXPORT int cef_create_temp_directory_in_directory( | ||||||
|     const cef_string_t* base_dir, |     const cef_string_t* base_dir, const cef_string_t* prefix, | ||||||
|     const cef_string_t* prefix, |  | ||||||
|     cef_string_t* new_dir); |     cef_string_t* new_dir); | ||||||
|  |  | ||||||
| /// | /// | ||||||
| @@ -111,18 +109,7 @@ CEF_EXPORT int cef_delete_file(const cef_string_t* path, int recursive); | |||||||
| // or IO threads is not allowed. | // or IO threads is not allowed. | ||||||
| /// | /// | ||||||
| CEF_EXPORT int cef_zip_directory(const cef_string_t* src_dir, | CEF_EXPORT int cef_zip_directory(const cef_string_t* src_dir, | ||||||
|                                  const cef_string_t* dest_file, |     const cef_string_t* dest_file, int include_hidden_files); | ||||||
|                                  int include_hidden_files); |  | ||||||
|  |  | ||||||
| /// |  | ||||||
| // Loads the existing "Certificate Revocation Lists" file that is managed by |  | ||||||
| // Google Chrome. This file can generally be found in Chrome's User Data |  | ||||||
| // directory (e.g. "C:\Users\[User]\AppData\Local\Google\Chrome\User Data\" on |  | ||||||
| // Windows) and is updated periodically by Chrome's component updater service. |  | ||||||
| // Must be called in the browser process after the context has been initialized. |  | ||||||
| // See https://dev.chromium.org/Home/chromium-security/crlsets for background. |  | ||||||
| /// |  | ||||||
| CEF_EXPORT void cef_load_crlsets_file(const cef_string_t* path); |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=200ff1e9b7fac8d0eda63bbbaec68225570bc099$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_FIND_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_FIND_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_FIND_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_FIND_HANDLER_CAPI_H_ | ||||||
| @@ -47,6 +45,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Implement this structure to handle events related to find results. The | // Implement this structure to handle events related to find results. The | ||||||
| // functions of this structure will be called on the UI thread. | // functions of this structure will be called on the UI thread. | ||||||
| @@ -55,7 +54,7 @@ typedef struct _cef_find_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called to report find results returned by cef_browser_host_t::find(). |   // Called to report find results returned by cef_browser_host_t::find(). | ||||||
| @@ -66,14 +65,12 @@ typedef struct _cef_find_handler_t { | |||||||
|   // this is the last find notification. |   // this is the last find notification. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_find_result)(struct _cef_find_handler_t* self, |   void (CEF_CALLBACK *on_find_result)(struct _cef_find_handler_t* self, | ||||||
|                                      struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, int identifier, int count, | ||||||
|                                      int identifier, |       const cef_rect_t* selectionRect, int activeMatchOrdinal, | ||||||
|                                      int count, |  | ||||||
|                                      const cef_rect_t* selectionRect, |  | ||||||
|                                      int activeMatchOrdinal, |  | ||||||
|       int finalUpdate); |       int finalUpdate); | ||||||
| } cef_find_handler_t; | } cef_find_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=365c6d4385b860543225e086dc973609fbfdedc8$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_FOCUS_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_FOCUS_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_FOCUS_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_FOCUS_HANDLER_CAPI_H_ | ||||||
| @@ -49,6 +47,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Implement this structure to handle events related to focus. The functions of | // Implement this structure to handle events related to focus. The functions of | ||||||
| // this structure will be called on the UI thread. | // this structure will be called on the UI thread. | ||||||
| @@ -57,7 +56,7 @@ typedef struct _cef_focus_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when the browser component is about to loose focus. For instance, if |   // Called when the browser component is about to loose focus. For instance, if | ||||||
| @@ -66,8 +65,7 @@ typedef struct _cef_focus_handler_t { | |||||||
|   // false (0) if the browser is giving focus to the previous component. |   // false (0) if the browser is giving focus to the previous component. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_take_focus)(struct _cef_focus_handler_t* self, |   void (CEF_CALLBACK *on_take_focus)(struct _cef_focus_handler_t* self, | ||||||
|                                     struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, int next); | ||||||
|                                     int next); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when the browser component is requesting focus. |source| indicates |   // Called when the browser component is requesting focus. |source| indicates | ||||||
| @@ -75,8 +73,7 @@ typedef struct _cef_focus_handler_t { | |||||||
|   // focus to be set or true (1) to cancel setting the focus. |   // focus to be set or true (1) to cancel setting the focus. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *on_set_focus)(struct _cef_focus_handler_t* self, |   int (CEF_CALLBACK *on_set_focus)(struct _cef_focus_handler_t* self, | ||||||
|                                   struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, cef_focus_source_t source); | ||||||
|                                   cef_focus_source_t source); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when the browser component has received focus. |   // Called when the browser component has received focus. | ||||||
| @@ -85,6 +82,7 @@ typedef struct _cef_focus_handler_t { | |||||||
|       struct _cef_browser_t* browser); |       struct _cef_browser_t* browser); | ||||||
| } cef_focus_handler_t; | } cef_focus_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=9495bafa6c18cf4a250f4933c39fb2c4597e4212$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_FRAME_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_FRAME_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_FRAME_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_FRAME_CAPI_H_ | ||||||
| @@ -63,7 +61,7 @@ typedef struct _cef_frame_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // True if this object is currently attached to a valid frame. |   // True if this object is currently attached to a valid frame. | ||||||
| @@ -144,8 +142,7 @@ typedef struct _cef_frame_t { | |||||||
|   // link clicks and web security restrictions may not behave as expected. |   // link clicks and web security restrictions may not behave as expected. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *load_string)(struct _cef_frame_t* self, |   void (CEF_CALLBACK *load_string)(struct _cef_frame_t* self, | ||||||
|                                   const cef_string_t* string_val, |       const cef_string_t* string_val, const cef_string_t* url); | ||||||
|                                   const cef_string_t* url); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Execute a string of JavaScript code in this frame. The |script_url| |   // Execute a string of JavaScript code in this frame. The |script_url| | ||||||
| @@ -155,8 +152,7 @@ typedef struct _cef_frame_t { | |||||||
|   // reporting. |   // reporting. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *execute_java_script)(struct _cef_frame_t* self, |   void (CEF_CALLBACK *execute_java_script)(struct _cef_frame_t* self, | ||||||
|                                           const cef_string_t* code, |       const cef_string_t* code, const cef_string_t* script_url, | ||||||
|                                           const cef_string_t* script_url, |  | ||||||
|       int start_line); |       int start_line); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -217,6 +213,7 @@ typedef struct _cef_frame_t { | |||||||
|       struct _cef_domvisitor_t* visitor); |       struct _cef_domvisitor_t* visitor); | ||||||
| } cef_frame_t; | } cef_frame_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved.
 | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved.
 | ||||||
| //
 | //
 | ||||||
| // Redistribution and use in source and binary forms, with or without
 | // Redistribution and use in source and binary forms, with or without
 | ||||||
| // modification, are permitted provided that the following conditions are
 | // modification, are permitted provided that the following conditions are
 | ||||||
| @@ -33,34 +33,47 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for
 | // by hand. See the translator.README.txt file in the tools directory for
 | ||||||
| // more information.
 | // more information.
 | ||||||
| //
 | //
 | ||||||
| // $hash=17ac101c343ef5bee85e2fb2046fc87c4ab5b033$
 |  | ||||||
| //
 |  | ||||||
| 
 | 
 | ||||||
| #ifndef CEF_INCLUDE_CAPI_TEST_CEF_TEST_HELPERS_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_GEOLOCATION_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_TEST_CEF_TEST_HELPERS_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_GEOLOCATION_CAPI_H_ | ||||||
| #pragma once | #pragma once | ||||||
| 
 | 
 | ||||||
| #if !defined(BUILDING_CEF_SHARED) && !defined(WRAPPING_CEF_SHARED) && \ |  | ||||||
|     !defined(UNIT_TEST) |  | ||||||
| #error This file can be included for unit tests only |  | ||||||
| #endif |  | ||||||
| 
 |  | ||||||
| #include "include/capi/cef_base_capi.h" | #include "include/capi/cef_base_capi.h" | ||||||
| 
 | 
 | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| ///
 | ///
 | ||||||
| // Execute JavaScript with a user gesture to trigger functionality like
 | // Implement this structure to receive geolocation updates. The functions of
 | ||||||
| // onbeforeunload handlers that will otherwise be blocked.
 | // this structure will be called on the browser process UI thread.
 | ||||||
| ///
 | ///
 | ||||||
| CEF_EXPORT void cef_execute_java_script_with_user_gesture_for_tests( | typedef struct _cef_get_geolocation_callback_t { | ||||||
|     struct _cef_frame_t* frame, |   ///
 | ||||||
|     const cef_string_t* javascript); |   // Base structure.
 | ||||||
|  |   ///
 | ||||||
|  |   cef_base_t base; | ||||||
|  | 
 | ||||||
|  |   ///
 | ||||||
|  |   // Called with the 'best available' location information or, if the location
 | ||||||
|  |   // update failed, with error information.
 | ||||||
|  |   ///
 | ||||||
|  |   void (CEF_CALLBACK *on_location_update)( | ||||||
|  |       struct _cef_get_geolocation_callback_t* self, | ||||||
|  |       const struct _cef_geoposition_t* position); | ||||||
|  | } cef_get_geolocation_callback_t; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | ///
 | ||||||
|  | // Request a one-time geolocation update. This function bypasses any user
 | ||||||
|  | // permission checks so should only be used by code that is allowed to access
 | ||||||
|  | // location information.
 | ||||||
|  | ///
 | ||||||
|  | CEF_EXPORT int cef_get_geolocation(cef_get_geolocation_callback_t* callback); | ||||||
| 
 | 
 | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| #endif  // CEF_INCLUDE_CAPI_TEST_CEF_TEST_HELPERS_CAPI_H_
 | #endif  // CEF_INCLUDE_CAPI_CEF_GEOLOCATION_CAPI_H_
 | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved.
 | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved.
 | ||||||
| //
 | //
 | ||||||
| // Redistribution and use in source and binary forms, with or without
 | // Redistribution and use in source and binary forms, with or without
 | ||||||
| // modification, are permitted provided that the following conditions are
 | // modification, are permitted provided that the following conditions are
 | ||||||
| @@ -33,49 +33,73 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for
 | // by hand. See the translator.README.txt file in the tools directory for
 | ||||||
| // more information.
 | // more information.
 | ||||||
| //
 | //
 | ||||||
| // $hash=3e20b926af7550a1dc4000bfdf261332222a64b8$
 |  | ||||||
| //
 |  | ||||||
| 
 | 
 | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_ACCESSIBILITY_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_GEOLOCATION_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_ACCESSIBILITY_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_GEOLOCATION_HANDLER_CAPI_H_ | ||||||
| #pragma once | #pragma once | ||||||
| 
 | 
 | ||||||
| #include "include/capi/cef_values_capi.h" | #include "include/capi/cef_base_capi.h" | ||||||
|  | #include "include/capi/cef_browser_capi.h" | ||||||
| 
 | 
 | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
|  | 
 | ||||||
| ///
 | ///
 | ||||||
| // Implement this structure to receive accessibility notification when
 | // Callback structure used for asynchronous continuation of geolocation
 | ||||||
| // accessibility events have been registered. The functions of this structure
 | // permission requests.
 | ||||||
| // will be called on the UI thread.
 |  | ||||||
| ///
 | ///
 | ||||||
| typedef struct _cef_accessibility_handler_t { | typedef struct _cef_geolocation_callback_t { | ||||||
|   ///
 |   ///
 | ||||||
|   // Base structure.
 |   // Base structure.
 | ||||||
|   ///
 |   ///
 | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
| 
 | 
 | ||||||
|   ///
 |   ///
 | ||||||
|   // Called after renderer process sends accessibility tree changes to the
 |   // Call to allow or deny geolocation access.
 | ||||||
|   // browser process.
 |  | ||||||
|   ///
 |   ///
 | ||||||
|   void(CEF_CALLBACK* on_accessibility_tree_change)( |   void (CEF_CALLBACK *cont)(struct _cef_geolocation_callback_t* self, | ||||||
|       struct _cef_accessibility_handler_t* self, |       int allow); | ||||||
|       struct _cef_value_t* value); | } cef_geolocation_callback_t; | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| ///
 | ///
 | ||||||
|   // Called after renderer process sends accessibility location changes to the
 | // Implement this structure to handle events related to geolocation permission
 | ||||||
|   // browser process.
 | // requests. The functions of this structure will be called on the browser
 | ||||||
|  | // process UI thread.
 | ||||||
| ///
 | ///
 | ||||||
|   void(CEF_CALLBACK* on_accessibility_location_change)( | typedef struct _cef_geolocation_handler_t { | ||||||
|       struct _cef_accessibility_handler_t* self, |   ///
 | ||||||
|       struct _cef_value_t* value); |   // Base structure.
 | ||||||
| } cef_accessibility_handler_t; |   ///
 | ||||||
|  |   cef_base_t base; | ||||||
|  | 
 | ||||||
|  |   ///
 | ||||||
|  |   // Called when a page requests permission to access geolocation information.
 | ||||||
|  |   // |requesting_url| is the URL requesting permission and |request_id| is the
 | ||||||
|  |   // unique ID for the permission request. Return true (1) and call
 | ||||||
|  |   // cef_geolocation_callback_t::cont() either in this function or at a later
 | ||||||
|  |   // time to continue or cancel the request. Return false (0) to cancel the
 | ||||||
|  |   // request immediately.
 | ||||||
|  |   ///
 | ||||||
|  |   int (CEF_CALLBACK *on_request_geolocation_permission)( | ||||||
|  |       struct _cef_geolocation_handler_t* self, struct _cef_browser_t* browser, | ||||||
|  |       const cef_string_t* requesting_url, int request_id, | ||||||
|  |       struct _cef_geolocation_callback_t* callback); | ||||||
|  | 
 | ||||||
|  |   ///
 | ||||||
|  |   // Called when a geolocation access request is canceled. |request_id| is the
 | ||||||
|  |   // unique ID for the permission request.
 | ||||||
|  |   ///
 | ||||||
|  |   void (CEF_CALLBACK *on_cancel_geolocation_permission)( | ||||||
|  |       struct _cef_geolocation_handler_t* self, struct _cef_browser_t* browser, | ||||||
|  |       int request_id); | ||||||
|  | } cef_geolocation_handler_t; | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
| 
 | 
 | ||||||
| #endif  // CEF_INCLUDE_CAPI_CEF_ACCESSIBILITY_HANDLER_CAPI_H_
 | #endif  // CEF_INCLUDE_CAPI_CEF_GEOLOCATION_HANDLER_CAPI_H_
 | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=7e5e6dfee8fe6c6bc17b8d58d3e5ddfa8537e2c5$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_IMAGE_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_IMAGE_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_IMAGE_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_IMAGE_CAPI_H_ | ||||||
| @@ -47,6 +45,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Container for a single image represented at different scale factors. All | // Container for a single image represented at different scale factors. All | ||||||
| // image representations should be the same size in density independent pixel | // image representations should be the same size in density independent pixel | ||||||
| @@ -59,7 +58,7 @@ typedef struct _cef_image_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if this Image is NULL. |   // Returns true (1) if this Image is NULL. | ||||||
| @@ -80,13 +79,9 @@ typedef struct _cef_image_t { | |||||||
|   // pixel data and should be |pixel_width| x |pixel_height| x 4 bytes in size. |   // pixel data and should be |pixel_width| x |pixel_height| x 4 bytes in size. | ||||||
|   // |color_type| and |alpha_type| values specify the pixel format. |   // |color_type| and |alpha_type| values specify the pixel format. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* add_bitmap)(struct _cef_image_t* self, |   int (CEF_CALLBACK *add_bitmap)(struct _cef_image_t* self, float scale_factor, | ||||||
|                                 float scale_factor, |       int pixel_width, int pixel_height, cef_color_type_t color_type, | ||||||
|                                 int pixel_width, |       cef_alpha_type_t alpha_type, const void* pixel_data, | ||||||
|                                 int pixel_height, |  | ||||||
|                                 cef_color_type_t color_type, |  | ||||||
|                                 cef_alpha_type_t alpha_type, |  | ||||||
|                                 const void* pixel_data, |  | ||||||
|       size_t pixel_data_size); |       size_t pixel_data_size); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -94,20 +89,16 @@ typedef struct _cef_image_t { | |||||||
|   // data of size |png_data_size|. Any alpha transparency in the PNG data will |   // data of size |png_data_size|. Any alpha transparency in the PNG data will | ||||||
|   // be maintained. |   // be maintained. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* add_png)(struct _cef_image_t* self, |   int (CEF_CALLBACK *add_png)(struct _cef_image_t* self, float scale_factor, | ||||||
|                              float scale_factor, |       const void* png_data, size_t png_data_size); | ||||||
|                              const void* png_data, |  | ||||||
|                              size_t png_data_size); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Create a JPEG image representation for |scale_factor|. |jpeg_data| is the |   // Create a JPEG image representation for |scale_factor|. |jpeg_data| is the | ||||||
|   // image data of size |jpeg_data_size|. The JPEG format does not support |   // image data of size |jpeg_data_size|. The JPEG format does not support | ||||||
|   // transparency so the alpha byte will be set to 0xFF for all pixels. |   // transparency so the alpha byte will be set to 0xFF for all pixels. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* add_jpeg)(struct _cef_image_t* self, |   int (CEF_CALLBACK *add_jpeg)(struct _cef_image_t* self, float scale_factor, | ||||||
|                               float scale_factor, |       const void* jpeg_data, size_t jpeg_data_size); | ||||||
|                               const void* jpeg_data, |  | ||||||
|                               size_t jpeg_data_size); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the image width in density independent pixel (DIP) units. |   // Returns the image width in density independent pixel (DIP) units. | ||||||
| @@ -139,9 +130,7 @@ typedef struct _cef_image_t { | |||||||
|   // size in pixel coordinates. Returns true (1) on success. |   // size in pixel coordinates. Returns true (1) on success. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *get_representation_info)(struct _cef_image_t* self, |   int (CEF_CALLBACK *get_representation_info)(struct _cef_image_t* self, | ||||||
|                                              float scale_factor, |       float scale_factor, float* actual_scale_factor, int* pixel_width, | ||||||
|                                              float* actual_scale_factor, |  | ||||||
|                                              int* pixel_width, |  | ||||||
|       int* pixel_height); |       int* pixel_height); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -153,12 +142,9 @@ typedef struct _cef_image_t { | |||||||
|   // on failure. |   // on failure. | ||||||
|   /// |   /// | ||||||
|   struct _cef_binary_value_t* (CEF_CALLBACK *get_as_bitmap)( |   struct _cef_binary_value_t* (CEF_CALLBACK *get_as_bitmap)( | ||||||
|       struct _cef_image_t* self, |       struct _cef_image_t* self, float scale_factor, | ||||||
|       float scale_factor, |       cef_color_type_t color_type, cef_alpha_type_t alpha_type, | ||||||
|       cef_color_type_t color_type, |       int* pixel_width, int* pixel_height); | ||||||
|       cef_alpha_type_t alpha_type, |  | ||||||
|       int* pixel_width, |  | ||||||
|       int* pixel_height); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the PNG representation that most closely matches |scale_factor|. If |   // Returns the PNG representation that most closely matches |scale_factor|. If | ||||||
| @@ -169,11 +155,8 @@ typedef struct _cef_image_t { | |||||||
|   // failure. |   // failure. | ||||||
|   /// |   /// | ||||||
|   struct _cef_binary_value_t* (CEF_CALLBACK *get_as_png)( |   struct _cef_binary_value_t* (CEF_CALLBACK *get_as_png)( | ||||||
|       struct _cef_image_t* self, |       struct _cef_image_t* self, float scale_factor, int with_transparency, | ||||||
|       float scale_factor, |       int* pixel_width, int* pixel_height); | ||||||
|       int with_transparency, |  | ||||||
|       int* pixel_width, |  | ||||||
|       int* pixel_height); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the JPEG representation that most closely matches |scale_factor|. |   // Returns the JPEG representation that most closely matches |scale_factor|. | ||||||
| @@ -185,19 +168,18 @@ typedef struct _cef_image_t { | |||||||
|   // failure. |   // failure. | ||||||
|   /// |   /// | ||||||
|   struct _cef_binary_value_t* (CEF_CALLBACK *get_as_jpeg)( |   struct _cef_binary_value_t* (CEF_CALLBACK *get_as_jpeg)( | ||||||
|       struct _cef_image_t* self, |       struct _cef_image_t* self, float scale_factor, int quality, | ||||||
|       float scale_factor, |       int* pixel_width, int* pixel_height); | ||||||
|       int quality, |  | ||||||
|       int* pixel_width, |  | ||||||
|       int* pixel_height); |  | ||||||
| } cef_image_t; | } cef_image_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Create a new cef_image_t. It will initially be NULL. Use the Add*() functions | // Create a new cef_image_t. It will initially be NULL. Use the Add*() functions | ||||||
| // to add representations at different scale factors. | // to add representations at different scale factors. | ||||||
| /// | /// | ||||||
| CEF_EXPORT cef_image_t* cef_image_create(); | CEF_EXPORT cef_image_t* cef_image_create(); | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=f4cd52053981d473b0a5be80d04bd8239d831d46$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_JSDIALOG_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_JSDIALOG_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_JSDIALOG_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_JSDIALOG_HANDLER_CAPI_H_ | ||||||
| @@ -47,6 +45,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Callback structure used for asynchronous continuation of JavaScript dialog | // Callback structure used for asynchronous continuation of JavaScript dialog | ||||||
| // requests. | // requests. | ||||||
| @@ -55,17 +54,17 @@ typedef struct _cef_jsdialog_callback_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Continue the JS dialog request. Set |success| to true (1) if the OK button |   // Continue the JS dialog request. Set |success| to true (1) if the OK button | ||||||
|   // was pressed. The |user_input| value should be specified for prompt dialogs. |   // was pressed. The |user_input| value should be specified for prompt dialogs. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* cont)(struct _cef_jsdialog_callback_t* self, |   void (CEF_CALLBACK *cont)(struct _cef_jsdialog_callback_t* self, int success, | ||||||
|                            int success, |  | ||||||
|       const cef_string_t* user_input); |       const cef_string_t* user_input); | ||||||
| } cef_jsdialog_callback_t; | } cef_jsdialog_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Implement this structure to handle events related to JavaScript dialogs. The | // Implement this structure to handle events related to JavaScript dialogs. The | ||||||
| // functions of this structure will be called on the UI thread. | // functions of this structure will be called on the UI thread. | ||||||
| @@ -74,7 +73,7 @@ typedef struct _cef_jsdialog_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called to run a JavaScript dialog. If |origin_url| is non-NULL it can be |   // Called to run a JavaScript dialog. If |origin_url| is non-NULL it can be | ||||||
| @@ -94,13 +93,10 @@ typedef struct _cef_jsdialog_handler_t { | |||||||
|   // dismissed. |   // dismissed. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *on_jsdialog)(struct _cef_jsdialog_handler_t* self, |   int (CEF_CALLBACK *on_jsdialog)(struct _cef_jsdialog_handler_t* self, | ||||||
|                                  struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, const cef_string_t* origin_url, | ||||||
|                                  const cef_string_t* origin_url, |       cef_jsdialog_type_t dialog_type, const cef_string_t* message_text, | ||||||
|                                  cef_jsdialog_type_t dialog_type, |  | ||||||
|                                  const cef_string_t* message_text, |  | ||||||
|       const cef_string_t* default_prompt_text, |       const cef_string_t* default_prompt_text, | ||||||
|                                  struct _cef_jsdialog_callback_t* callback, |       struct _cef_jsdialog_callback_t* callback, int* suppress_message); | ||||||
|                                  int* suppress_message); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called to run a dialog asking the user if they want to leave a page. Return |   // Called to run a dialog asking the user if they want to leave a page. Return | ||||||
| @@ -111,10 +107,8 @@ typedef struct _cef_jsdialog_handler_t { | |||||||
|   // dialog is dismissed. |   // dialog is dismissed. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *on_before_unload_dialog)( |   int (CEF_CALLBACK *on_before_unload_dialog)( | ||||||
|       struct _cef_jsdialog_handler_t* self, |       struct _cef_jsdialog_handler_t* self, struct _cef_browser_t* browser, | ||||||
|       struct _cef_browser_t* browser, |       const cef_string_t* message_text, int is_reload, | ||||||
|       const cef_string_t* message_text, |  | ||||||
|       int is_reload, |  | ||||||
|       struct _cef_jsdialog_callback_t* callback); |       struct _cef_jsdialog_callback_t* callback); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -123,8 +117,7 @@ typedef struct _cef_jsdialog_handler_t { | |||||||
|   // dialogs are currently pending. |   // dialogs are currently pending. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_reset_dialog_state)( |   void (CEF_CALLBACK *on_reset_dialog_state)( | ||||||
|       struct _cef_jsdialog_handler_t* self, |       struct _cef_jsdialog_handler_t* self, struct _cef_browser_t* browser); | ||||||
|       struct _cef_browser_t* browser); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when the default implementation dialog is closed. |   // Called when the default implementation dialog is closed. | ||||||
| @@ -133,6 +126,7 @@ typedef struct _cef_jsdialog_handler_t { | |||||||
|       struct _cef_browser_t* browser); |       struct _cef_browser_t* browser); | ||||||
| } cef_jsdialog_handler_t; | } cef_jsdialog_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=7efb9ec2ee02bb511c1d0363b8c4d235a6170cad$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_KEYBOARD_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_KEYBOARD_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_KEYBOARD_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_KEYBOARD_HANDLER_CAPI_H_ | ||||||
| @@ -47,6 +45,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Implement this structure to handle events related to keyboard input. The | // Implement this structure to handle events related to keyboard input. The | ||||||
| // functions of this structure will be called on the UI thread. | // functions of this structure will be called on the UI thread. | ||||||
| @@ -55,7 +54,7 @@ typedef struct _cef_keyboard_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called before a keyboard event is sent to the renderer. |event| contains |   // Called before a keyboard event is sent to the renderer. |event| contains | ||||||
| @@ -65,10 +64,8 @@ typedef struct _cef_keyboard_handler_t { | |||||||
|   // shortcut set |is_keyboard_shortcut| to true (1) and return false (0). |   // shortcut set |is_keyboard_shortcut| to true (1) and return false (0). | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *on_pre_key_event)(struct _cef_keyboard_handler_t* self, |   int (CEF_CALLBACK *on_pre_key_event)(struct _cef_keyboard_handler_t* self, | ||||||
|                                       struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, const struct _cef_key_event_t* event, | ||||||
|                                       const struct _cef_key_event_t* event, |       cef_event_handle_t os_event, int* is_keyboard_shortcut); | ||||||
|                                       cef_event_handle_t os_event, |  | ||||||
|                                       int* is_keyboard_shortcut); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called after the renderer and JavaScript in the page has had a chance to |   // Called after the renderer and JavaScript in the page has had a chance to | ||||||
| @@ -77,11 +74,11 @@ typedef struct _cef_keyboard_handler_t { | |||||||
|   // if the keyboard event was handled or false (0) otherwise. |   // if the keyboard event was handled or false (0) otherwise. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *on_key_event)(struct _cef_keyboard_handler_t* self, |   int (CEF_CALLBACK *on_key_event)(struct _cef_keyboard_handler_t* self, | ||||||
|                                   struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, const struct _cef_key_event_t* event, | ||||||
|                                   const struct _cef_key_event_t* event, |  | ||||||
|       cef_event_handle_t os_event); |       cef_event_handle_t os_event); | ||||||
| } cef_keyboard_handler_t; | } cef_keyboard_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=eca8f0216a3430fad8ff3714a0ef65ed27e02f0e$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_LIFE_SPAN_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_LIFE_SPAN_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_LIFE_SPAN_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_LIFE_SPAN_HANDLER_CAPI_H_ | ||||||
| @@ -58,10 +56,10 @@ typedef struct _cef_life_span_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called on the UI thread before a new popup browser is created. The |   // Called on the IO thread before a new popup browser is created. The | ||||||
|   // |browser| and |frame| values represent the source of the popup request. The |   // |browser| and |frame| values represent the source of the popup request. The | ||||||
|   // |target_url| and |target_frame_name| values indicate where the popup |   // |target_url| and |target_frame_name| values indicate where the popup | ||||||
|   // browser should navigate and may be NULL if not specified with the request. |   // browser should navigate and may be NULL if not specified with the request. | ||||||
| @@ -78,23 +76,15 @@ typedef struct _cef_life_span_handler_t { | |||||||
|   // is set to false (0) the new browser will not be scriptable and may not be |   // is set to false (0) the new browser will not be scriptable and may not be | ||||||
|   // hosted in the same renderer process as the source browser. Any |   // hosted in the same renderer process as the source browser. Any | ||||||
|   // modifications to |windowInfo| will be ignored if the parent browser is |   // modifications to |windowInfo| will be ignored if the parent browser is | ||||||
|   // wrapped in a cef_browser_view_t. Popup browser creation will be canceled if |   // wrapped in a cef_browser_view_t. | ||||||
|   // the parent browser is destroyed before the popup browser creation completes |  | ||||||
|   // (indicated by a call to OnAfterCreated for the popup browser). |  | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* on_before_popup)( |   int (CEF_CALLBACK *on_before_popup)(struct _cef_life_span_handler_t* self, | ||||||
|       struct _cef_life_span_handler_t* self, |       struct _cef_browser_t* browser, struct _cef_frame_t* frame, | ||||||
|       struct _cef_browser_t* browser, |       const cef_string_t* target_url, const cef_string_t* target_frame_name, | ||||||
|       struct _cef_frame_t* frame, |       cef_window_open_disposition_t target_disposition, int user_gesture, | ||||||
|       const cef_string_t* target_url, |  | ||||||
|       const cef_string_t* target_frame_name, |  | ||||||
|       cef_window_open_disposition_t target_disposition, |  | ||||||
|       int user_gesture, |  | ||||||
|       const struct _cef_popup_features_t* popupFeatures, |       const struct _cef_popup_features_t* popupFeatures, | ||||||
|       struct _cef_window_info_t* windowInfo, |       struct _cef_window_info_t* windowInfo, struct _cef_client_t** client, | ||||||
|       struct _cef_client_t** client, |       struct _cef_browser_settings_t* settings, int* no_javascript_access); | ||||||
|       struct _cef_browser_settings_t* settings, |  | ||||||
|       int* no_javascript_access); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called after a new browser is created. This callback will be the first |   // Called after a new browser is created. This callback will be the first | ||||||
| @@ -206,6 +196,7 @@ typedef struct _cef_life_span_handler_t { | |||||||
|       struct _cef_browser_t* browser); |       struct _cef_browser_t* browser); | ||||||
| } cef_life_span_handler_t; | } cef_life_span_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=94b07e1d76b57fbd125f0cc8d78298ff119f1822$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_LOAD_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_LOAD_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_LOAD_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_LOAD_HANDLER_CAPI_H_ | ||||||
| @@ -48,6 +46,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Implement this structure to handle events related to browser load status. The | // Implement this structure to handle events related to browser load status. The | ||||||
| // functions of this structure will be called on the browser process UI thread | // functions of this structure will be called on the browser process UI thread | ||||||
| @@ -57,7 +56,7 @@ typedef struct _cef_load_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when the loading state has changed. This callback will be executed |   // Called when the loading state has changed. This callback will be executed | ||||||
| @@ -67,26 +66,22 @@ typedef struct _cef_load_handler_t { | |||||||
|   // calls to OnLoadError and/or OnLoadEnd. |   // calls to OnLoadError and/or OnLoadEnd. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_loading_state_change)(struct _cef_load_handler_t* self, |   void (CEF_CALLBACK *on_loading_state_change)(struct _cef_load_handler_t* self, | ||||||
|                                               struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, int isLoading, int canGoBack, | ||||||
|                                               int isLoading, |  | ||||||
|                                               int canGoBack, |  | ||||||
|       int canGoForward); |       int canGoForward); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called after a navigation has been committed and before the browser begins |   // Called when the browser begins loading a frame. The |frame| value will | ||||||
|   // loading contents in the frame. The |frame| value will never be NULL -- call |   // never be NULL -- call the is_main() function to check if this frame is the | ||||||
|   // the is_main() function to check if this frame is the main frame. |   // main frame. |transition_type| provides information about the source of the | ||||||
|   // |transition_type| provides information about the source of the navigation |   // navigation and an accurate value is only available in the browser process. | ||||||
|   // and an accurate value is only available in the browser process. Multiple |   // Multiple frames may be loading at the same time. Sub-frames may start or | ||||||
|   // frames may be loading at the same time. Sub-frames may start or continue |   // continue loading after the main frame load has ended. This function will | ||||||
|   // loading after the main frame load has ended. This function will not be |   // always be called for all frames irrespective of whether the request | ||||||
|   // called for same page navigations (fragments, history state, etc.) or for |   // completes successfully. For notification of overall browser load status use | ||||||
|   // navigations that fail or are canceled before commit. For notification of |   // OnLoadingStateChange instead. | ||||||
|   // overall browser load status use OnLoadingStateChange instead. |  | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_load_start)(struct _cef_load_handler_t* self, |   void (CEF_CALLBACK *on_load_start)(struct _cef_load_handler_t* self, | ||||||
|                                     struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, struct _cef_frame_t* frame, | ||||||
|                                     struct _cef_frame_t* frame, |  | ||||||
|       cef_transition_type_t transition_type); |       cef_transition_type_t transition_type); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -94,31 +89,27 @@ typedef struct _cef_load_handler_t { | |||||||
|   // never be NULL -- call the is_main() function to check if this frame is the |   // never be NULL -- call the is_main() function to check if this frame is the | ||||||
|   // main frame. Multiple frames may be loading at the same time. Sub-frames may |   // main frame. Multiple frames may be loading at the same time. Sub-frames may | ||||||
|   // start or continue loading after the main frame load has ended. This |   // start or continue loading after the main frame load has ended. This | ||||||
|   // function will not be called for same page navigations (fragments, history |   // function will always be called for all frames irrespective of whether the | ||||||
|   // state, etc.) or for navigations that fail or are canceled before commit. |   // request completes successfully. For notification of overall browser load | ||||||
|   // For notification of overall browser load status use OnLoadingStateChange |   // status use OnLoadingStateChange instead. | ||||||
|   // instead. |  | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_load_end)(struct _cef_load_handler_t* self, |   void (CEF_CALLBACK *on_load_end)(struct _cef_load_handler_t* self, | ||||||
|                                   struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, struct _cef_frame_t* frame, | ||||||
|                                   struct _cef_frame_t* frame, |  | ||||||
|       int httpStatusCode); |       int httpStatusCode); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when a navigation fails or is canceled. This function may be called |   // Called when the resource load for a navigation fails or is canceled. | ||||||
|   // by itself if before commit or in combination with OnLoadStart/OnLoadEnd if |   // |errorCode| is the error code number, |errorText| is the error text and | ||||||
|   // after commit. |errorCode| is the error code number, |errorText| is the |   // |failedUrl| is the URL that failed to load. See net\base\net_error_list.h | ||||||
|   // error text and |failedUrl| is the URL that failed to load. See |   // for complete descriptions of the error codes. | ||||||
|   // net\base\net_error_list.h for complete descriptions of the error codes. |  | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_load_error)(struct _cef_load_handler_t* self, |   void (CEF_CALLBACK *on_load_error)(struct _cef_load_handler_t* self, | ||||||
|                                     struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, struct _cef_frame_t* frame, | ||||||
|                                     struct _cef_frame_t* frame, |       cef_errorcode_t errorCode, const cef_string_t* errorText, | ||||||
|                                     cef_errorcode_t errorCode, |  | ||||||
|                                     const cef_string_t* errorText, |  | ||||||
|       const cef_string_t* failedUrl); |       const cef_string_t* failedUrl); | ||||||
| } cef_load_handler_t; | } cef_load_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=c86c5964cd093de8913b092db47d9e820a169ae8$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_MENU_MODEL_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_MENU_MODEL_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_MENU_MODEL_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_MENU_MODEL_CAPI_H_ | ||||||
| @@ -47,6 +45,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Supports creation and modification of menus. See cef_menu_id_t for the | // Supports creation and modification of menus. See cef_menu_id_t for the | ||||||
| // command ids that have default implementations. All user-defined command ids | // command ids that have default implementations. All user-defined command ids | ||||||
| @@ -57,12 +56,7 @@ typedef struct _cef_menu_model_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns true (1) if this menu is a submenu. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* is_sub_menu)(struct _cef_menu_model_t* self); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Clears the menu. Returns true (1) on success. |   // Clears the menu. Returns true (1) on success. | ||||||
| @@ -82,32 +76,27 @@ typedef struct _cef_menu_model_t { | |||||||
|   /// |   /// | ||||||
|   // Add an item to the menu. Returns true (1) on success. |   // Add an item to the menu. Returns true (1) on success. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* add_item)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *add_item)(struct _cef_menu_model_t* self, int command_id, | ||||||
|                               int command_id, |  | ||||||
|       const cef_string_t* label); |       const cef_string_t* label); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Add a check item to the menu. Returns true (1) on success. |   // Add a check item to the menu. Returns true (1) on success. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *add_check_item)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *add_check_item)(struct _cef_menu_model_t* self, | ||||||
|                                     int command_id, |       int command_id, const cef_string_t* label); | ||||||
|                                     const cef_string_t* label); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Add a radio item to the menu. Only a single item with the specified |   // Add a radio item to the menu. Only a single item with the specified | ||||||
|   // |group_id| can be checked at a time. Returns true (1) on success. |   // |group_id| can be checked at a time. Returns true (1) on success. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *add_radio_item)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *add_radio_item)(struct _cef_menu_model_t* self, | ||||||
|                                     int command_id, |       int command_id, const cef_string_t* label, int group_id); | ||||||
|                                     const cef_string_t* label, |  | ||||||
|                                     int group_id); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Add a sub-menu to the menu. The new sub-menu is returned. |   // Add a sub-menu to the menu. The new sub-menu is returned. | ||||||
|   /// |   /// | ||||||
|   struct _cef_menu_model_t* (CEF_CALLBACK *add_sub_menu)( |   struct _cef_menu_model_t* (CEF_CALLBACK *add_sub_menu)( | ||||||
|       struct _cef_menu_model_t* self, |       struct _cef_menu_model_t* self, int command_id, | ||||||
|       int command_id, |  | ||||||
|       const cef_string_t* label); |       const cef_string_t* label); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -121,19 +110,15 @@ typedef struct _cef_menu_model_t { | |||||||
|   // Insert an item in the menu at the specified |index|. Returns true (1) on |   // Insert an item in the menu at the specified |index|. Returns true (1) on | ||||||
|   // success. |   // success. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* insert_item_at)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *insert_item_at)(struct _cef_menu_model_t* self, int index, | ||||||
|                                     int index, |       int command_id, const cef_string_t* label); | ||||||
|                                     int command_id, |  | ||||||
|                                     const cef_string_t* label); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Insert a check item in the menu at the specified |index|. Returns true (1) |   // Insert a check item in the menu at the specified |index|. Returns true (1) | ||||||
|   // on success. |   // on success. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *insert_check_item_at)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *insert_check_item_at)(struct _cef_menu_model_t* self, | ||||||
|                                           int index, |       int index, int command_id, const cef_string_t* label); | ||||||
|                                           int command_id, |  | ||||||
|                                           const cef_string_t* label); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Insert a radio item in the menu at the specified |index|. Only a single |   // Insert a radio item in the menu at the specified |index|. Only a single | ||||||
| @@ -141,19 +126,14 @@ typedef struct _cef_menu_model_t { | |||||||
|   // (1) on success. |   // (1) on success. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *insert_radio_item_at)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *insert_radio_item_at)(struct _cef_menu_model_t* self, | ||||||
|                                           int index, |       int index, int command_id, const cef_string_t* label, int group_id); | ||||||
|                                           int command_id, |  | ||||||
|                                           const cef_string_t* label, |  | ||||||
|                                           int group_id); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Insert a sub-menu in the menu at the specified |index|. The new sub-menu is |   // Insert a sub-menu in the menu at the specified |index|. The new sub-menu is | ||||||
|   // returned. |   // returned. | ||||||
|   /// |   /// | ||||||
|   struct _cef_menu_model_t* (CEF_CALLBACK *insert_sub_menu_at)( |   struct _cef_menu_model_t* (CEF_CALLBACK *insert_sub_menu_at)( | ||||||
|       struct _cef_menu_model_t* self, |       struct _cef_menu_model_t* self, int index, int command_id, | ||||||
|       int index, |  | ||||||
|       int command_id, |  | ||||||
|       const cef_string_t* label); |       const cef_string_t* label); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -185,36 +165,33 @@ typedef struct _cef_menu_model_t { | |||||||
|   // Sets the command id at the specified |index|. Returns true (1) on success. |   // Sets the command id at the specified |index|. Returns true (1) on success. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *set_command_id_at)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *set_command_id_at)(struct _cef_menu_model_t* self, | ||||||
|                                        int index, |       int index, int command_id); | ||||||
|                                        int command_id); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the label for the specified |command_id| or NULL if not found. |   // Returns the label for the specified |command_id| or NULL if not found. | ||||||
|   /// |   /// | ||||||
|   // The resulting string must be freed by calling cef_string_userfree_free(). |   // The resulting string must be freed by calling cef_string_userfree_free(). | ||||||
|   cef_string_userfree_t(CEF_CALLBACK* get_label)(struct _cef_menu_model_t* self, |   cef_string_userfree_t (CEF_CALLBACK *get_label)( | ||||||
|                                                  int command_id); |       struct _cef_menu_model_t* self, int command_id); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the label at the specified |index| or NULL if not found due to |   // Returns the label at the specified |index| or NULL if not found due to | ||||||
|   // invalid range or the index being a separator. |   // invalid range or the index being a separator. | ||||||
|   /// |   /// | ||||||
|   // The resulting string must be freed by calling cef_string_userfree_free(). |   // The resulting string must be freed by calling cef_string_userfree_free(). | ||||||
|   cef_string_userfree_t( |   cef_string_userfree_t (CEF_CALLBACK *get_label_at)( | ||||||
|       CEF_CALLBACK* get_label_at)(struct _cef_menu_model_t* self, int index); |       struct _cef_menu_model_t* self, int index); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Sets the label for the specified |command_id|. Returns true (1) on success. |   // Sets the label for the specified |command_id|. Returns true (1) on success. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* set_label)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *set_label)(struct _cef_menu_model_t* self, int command_id, | ||||||
|                                int command_id, |  | ||||||
|       const cef_string_t* label); |       const cef_string_t* label); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Set the label at the specified |index|. Returns true (1) on success. |   // Set the label at the specified |index|. Returns true (1) on success. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* set_label_at)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *set_label_at)(struct _cef_menu_model_t* self, int index, | ||||||
|                                   int index, |  | ||||||
|       const cef_string_t* label); |       const cef_string_t* label); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -226,8 +203,8 @@ typedef struct _cef_menu_model_t { | |||||||
|   /// |   /// | ||||||
|   // Returns the item type at the specified |index|. |   // Returns the item type at the specified |index|. | ||||||
|   /// |   /// | ||||||
|   cef_menu_item_type_t( |   cef_menu_item_type_t (CEF_CALLBACK *get_type_at)( | ||||||
|       CEF_CALLBACK* get_type_at)(struct _cef_menu_model_t* self, int index); |       struct _cef_menu_model_t* self, int index); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the group id for the specified |command_id| or -1 if invalid. |   // Returns the group id for the specified |command_id| or -1 if invalid. | ||||||
| @@ -238,40 +215,39 @@ typedef struct _cef_menu_model_t { | |||||||
|   /// |   /// | ||||||
|   // Returns the group id at the specified |index| or -1 if invalid. |   // Returns the group id at the specified |index| or -1 if invalid. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* get_group_id_at)(struct _cef_menu_model_t* self, int index); |   int (CEF_CALLBACK *get_group_id_at)(struct _cef_menu_model_t* self, | ||||||
|  |       int index); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Sets the group id for the specified |command_id|. Returns true (1) on |   // Sets the group id for the specified |command_id|. Returns true (1) on | ||||||
|   // success. |   // success. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *set_group_id)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *set_group_id)(struct _cef_menu_model_t* self, | ||||||
|                                   int command_id, |       int command_id, int group_id); | ||||||
|                                   int group_id); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Sets the group id at the specified |index|. Returns true (1) on success. |   // Sets the group id at the specified |index|. Returns true (1) on success. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* set_group_id_at)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *set_group_id_at)(struct _cef_menu_model_t* self, int index, | ||||||
|                                      int index, |  | ||||||
|       int group_id); |       int group_id); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the submenu for the specified |command_id| or NULL if invalid. |   // Returns the submenu for the specified |command_id| or NULL if invalid. | ||||||
|   /// |   /// | ||||||
|   struct _cef_menu_model_t* (CEF_CALLBACK *get_sub_menu)( |   struct _cef_menu_model_t* (CEF_CALLBACK *get_sub_menu)( | ||||||
|       struct _cef_menu_model_t* self, |       struct _cef_menu_model_t* self, int command_id); | ||||||
|       int command_id); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the submenu at the specified |index| or NULL if invalid. |   // Returns the submenu at the specified |index| or NULL if invalid. | ||||||
|   /// |   /// | ||||||
|   struct _cef_menu_model_t*( |   struct _cef_menu_model_t* (CEF_CALLBACK *get_sub_menu_at)( | ||||||
|       CEF_CALLBACK* get_sub_menu_at)(struct _cef_menu_model_t* self, int index); |       struct _cef_menu_model_t* self, int index); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if the specified |command_id| is visible. |   // Returns true (1) if the specified |command_id| is visible. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* is_visible)(struct _cef_menu_model_t* self, int command_id); |   int (CEF_CALLBACK *is_visible)(struct _cef_menu_model_t* self, | ||||||
|  |       int command_id); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if the specified |index| is visible. |   // Returns true (1) if the specified |index| is visible. | ||||||
| @@ -283,21 +259,20 @@ typedef struct _cef_menu_model_t { | |||||||
|   // success. |   // success. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *set_visible)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *set_visible)(struct _cef_menu_model_t* self, | ||||||
|                                  int command_id, |       int command_id, int visible); | ||||||
|                                  int visible); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Change the visibility at the specified |index|. Returns true (1) on |   // Change the visibility at the specified |index|. Returns true (1) on | ||||||
|   // success. |   // success. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* set_visible_at)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *set_visible_at)(struct _cef_menu_model_t* self, int index, | ||||||
|                                     int index, |  | ||||||
|       int visible); |       int visible); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if the specified |command_id| is enabled. |   // Returns true (1) if the specified |command_id| is enabled. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* is_enabled)(struct _cef_menu_model_t* self, int command_id); |   int (CEF_CALLBACK *is_enabled)(struct _cef_menu_model_t* self, | ||||||
|  |       int command_id); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if the specified |index| is enabled. |   // Returns true (1) if the specified |index| is enabled. | ||||||
| @@ -309,22 +284,21 @@ typedef struct _cef_menu_model_t { | |||||||
|   // on success. |   // on success. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *set_enabled)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *set_enabled)(struct _cef_menu_model_t* self, | ||||||
|                                  int command_id, |       int command_id, int enabled); | ||||||
|                                  int enabled); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Change the enabled status at the specified |index|. Returns true (1) on |   // Change the enabled status at the specified |index|. Returns true (1) on | ||||||
|   // success. |   // success. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* set_enabled_at)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *set_enabled_at)(struct _cef_menu_model_t* self, int index, | ||||||
|                                     int index, |  | ||||||
|       int enabled); |       int enabled); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if the specified |command_id| is checked. Only applies to |   // Returns true (1) if the specified |command_id| is checked. Only applies to | ||||||
|   // check and radio items. |   // check and radio items. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* is_checked)(struct _cef_menu_model_t* self, int command_id); |   int (CEF_CALLBACK *is_checked)(struct _cef_menu_model_t* self, | ||||||
|  |       int command_id); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if the specified |index| is checked. Only applies to check |   // Returns true (1) if the specified |index| is checked. Only applies to check | ||||||
| @@ -337,15 +311,13 @@ typedef struct _cef_menu_model_t { | |||||||
|   // Returns true (1) on success. |   // Returns true (1) on success. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *set_checked)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *set_checked)(struct _cef_menu_model_t* self, | ||||||
|                                  int command_id, |       int command_id, int checked); | ||||||
|                                  int checked); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Check the specified |index|. Only applies to check and radio items. Returns |   // Check the specified |index|. Only applies to check and radio items. Returns | ||||||
|   // true (1) on success. |   // true (1) on success. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* set_checked_at)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *set_checked_at)(struct _cef_menu_model_t* self, int index, | ||||||
|                                     int index, |  | ||||||
|       int checked); |       int checked); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -367,10 +339,7 @@ typedef struct _cef_menu_model_t { | |||||||
|   // be any virtual key or character value. Returns true (1) on success. |   // be any virtual key or character value. Returns true (1) on success. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *set_accelerator)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *set_accelerator)(struct _cef_menu_model_t* self, | ||||||
|                                      int command_id, |       int command_id, int key_code, int shift_pressed, int ctrl_pressed, | ||||||
|                                      int key_code, |  | ||||||
|                                      int shift_pressed, |  | ||||||
|                                      int ctrl_pressed, |  | ||||||
|       int alt_pressed); |       int alt_pressed); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -378,10 +347,7 @@ typedef struct _cef_menu_model_t { | |||||||
|   // any virtual key or character value. Returns true (1) on success. |   // any virtual key or character value. Returns true (1) on success. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *set_accelerator_at)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *set_accelerator_at)(struct _cef_menu_model_t* self, | ||||||
|                                         int index, |       int index, int key_code, int shift_pressed, int ctrl_pressed, | ||||||
|                                         int key_code, |  | ||||||
|                                         int shift_pressed, |  | ||||||
|                                         int ctrl_pressed, |  | ||||||
|       int alt_pressed); |       int alt_pressed); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -403,10 +369,7 @@ typedef struct _cef_menu_model_t { | |||||||
|   // true (1) on success. |   // true (1) on success. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *get_accelerator)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *get_accelerator)(struct _cef_menu_model_t* self, | ||||||
|                                      int command_id, |       int command_id, int* key_code, int* shift_pressed, int* ctrl_pressed, | ||||||
|                                      int* key_code, |  | ||||||
|                                      int* shift_pressed, |  | ||||||
|                                      int* ctrl_pressed, |  | ||||||
|       int* alt_pressed); |       int* alt_pressed); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -414,96 +377,18 @@ typedef struct _cef_menu_model_t { | |||||||
|   // (1) on success. |   // (1) on success. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *get_accelerator_at)(struct _cef_menu_model_t* self, |   int (CEF_CALLBACK *get_accelerator_at)(struct _cef_menu_model_t* self, | ||||||
|                                         int index, |       int index, int* key_code, int* shift_pressed, int* ctrl_pressed, | ||||||
|                                         int* key_code, |  | ||||||
|                                         int* shift_pressed, |  | ||||||
|                                         int* ctrl_pressed, |  | ||||||
|       int* alt_pressed); |       int* alt_pressed); | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Set the explicit color for |command_id| and |color_type| to |color|. |  | ||||||
|   // Specify a |color| value of 0 to remove the explicit color. If no explicit |  | ||||||
|   // color or default color is set for |color_type| then the system color will |  | ||||||
|   // be used. Returns true (1) on success. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* set_color)(struct _cef_menu_model_t* self, |  | ||||||
|                                int command_id, |  | ||||||
|                                cef_menu_color_type_t color_type, |  | ||||||
|                                cef_color_t color); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Set the explicit color for |command_id| and |index| to |color|. Specify a |  | ||||||
|   // |color| value of 0 to remove the explicit color. Specify an |index| value |  | ||||||
|   // of -1 to set the default color for items that do not have an explicit color |  | ||||||
|   // set. If no explicit color or default color is set for |color_type| then the |  | ||||||
|   // system color will be used. Returns true (1) on success. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* set_color_at)(struct _cef_menu_model_t* self, |  | ||||||
|                                   int index, |  | ||||||
|                                   cef_menu_color_type_t color_type, |  | ||||||
|                                   cef_color_t color); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns in |color| the color that was explicitly set for |command_id| and |  | ||||||
|   // |color_type|. If a color was not set then 0 will be returned in |color|. |  | ||||||
|   // Returns true (1) on success. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* get_color)(struct _cef_menu_model_t* self, |  | ||||||
|                                int command_id, |  | ||||||
|                                cef_menu_color_type_t color_type, |  | ||||||
|                                cef_color_t* color); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns in |color| the color that was explicitly set for |command_id| and |  | ||||||
|   // |color_type|. Specify an |index| value of -1 to return the default color in |  | ||||||
|   // |color|. If a color was not set then 0 will be returned in |color|. Returns |  | ||||||
|   // true (1) on success. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* get_color_at)(struct _cef_menu_model_t* self, |  | ||||||
|                                   int index, |  | ||||||
|                                   cef_menu_color_type_t color_type, |  | ||||||
|                                   cef_color_t* color); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Sets the font list for the specified |command_id|. If |font_list| is NULL |  | ||||||
|   // the system font will be used. Returns true (1) on success. The format is |  | ||||||
|   // "<FONT_FAMILY_LIST>,[STYLES] <SIZE>", where: - FONT_FAMILY_LIST is a comma- |  | ||||||
|   // separated list of font family names, - STYLES is an optional space- |  | ||||||
|   // separated list of style names (case-sensitive |  | ||||||
|   //   "Bold" and "Italic" are supported), and |  | ||||||
|   // - SIZE is an integer font size in pixels with the suffix "px". |  | ||||||
|   // |  | ||||||
|   // Here are examples of valid font description strings: - "Arial, Helvetica, |  | ||||||
|   // Bold Italic 14px" - "Arial, 14px" |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* set_font_list)(struct _cef_menu_model_t* self, |  | ||||||
|                                    int command_id, |  | ||||||
|                                    const cef_string_t* font_list); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Sets the font list for the specified |index|. Specify an |index| value of |  | ||||||
|   // -1 to set the default font. If |font_list| is NULL the system font will be |  | ||||||
|   // used. Returns true (1) on success. The format is |  | ||||||
|   // "<FONT_FAMILY_LIST>,[STYLES] <SIZE>", where: - FONT_FAMILY_LIST is a comma- |  | ||||||
|   // separated list of font family names, - STYLES is an optional space- |  | ||||||
|   // separated list of style names (case-sensitive |  | ||||||
|   //   "Bold" and "Italic" are supported), and |  | ||||||
|   // - SIZE is an integer font size in pixels with the suffix "px". |  | ||||||
|   // |  | ||||||
|   // Here are examples of valid font description strings: - "Arial, Helvetica, |  | ||||||
|   // Bold Italic 14px" - "Arial, 14px" |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* set_font_list_at)(struct _cef_menu_model_t* self, |  | ||||||
|                                       int index, |  | ||||||
|                                       const cef_string_t* font_list); |  | ||||||
| } cef_menu_model_t; | } cef_menu_model_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Create a new MenuModel with the specified |delegate|. | // Create a new MenuModel with the specified |delegate|. | ||||||
| /// | /// | ||||||
| CEF_EXPORT cef_menu_model_t* cef_menu_model_create( | CEF_EXPORT cef_menu_model_t* cef_menu_model_create( | ||||||
|     struct _cef_menu_model_delegate_t* delegate); |     struct _cef_menu_model_delegate_t* delegate); | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=d390abde0e3eb8ac8d80d16cbf638d297866b853$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_MENU_MODEL_DELEGATE_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_MENU_MODEL_DELEGATE_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_MENU_MODEL_DELEGATE_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_MENU_MODEL_DELEGATE_CAPI_H_ | ||||||
| @@ -57,44 +55,16 @@ typedef struct _cef_menu_model_delegate_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Perform the action associated with the specified |command_id| and optional |   // Perform the action associated with the specified |command_id| and optional | ||||||
|   // |event_flags|. |   // |event_flags|. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *execute_command)(struct _cef_menu_model_delegate_t* self, |   void (CEF_CALLBACK *execute_command)(struct _cef_menu_model_delegate_t* self, | ||||||
|                                       struct _cef_menu_model_t* menu_model, |       struct _cef_menu_model_t* menu_model, int command_id, | ||||||
|                                       int command_id, |  | ||||||
|       cef_event_flags_t event_flags); |       cef_event_flags_t event_flags); | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called when the user moves the mouse outside the menu and over the owning |  | ||||||
|   // window. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* mouse_outside_menu)( |  | ||||||
|       struct _cef_menu_model_delegate_t* self, |  | ||||||
|       struct _cef_menu_model_t* menu_model, |  | ||||||
|       const cef_point_t* screen_point); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called on unhandled open submenu keyboard commands. |is_rtl| will be true |  | ||||||
|   // (1) if the menu is displaying a right-to-left language. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* unhandled_open_submenu)( |  | ||||||
|       struct _cef_menu_model_delegate_t* self, |  | ||||||
|       struct _cef_menu_model_t* menu_model, |  | ||||||
|       int is_rtl); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called on unhandled close submenu keyboard commands. |is_rtl| will be true |  | ||||||
|   // (1) if the menu is displaying a right-to-left language. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* unhandled_close_submenu)( |  | ||||||
|       struct _cef_menu_model_delegate_t* self, |  | ||||||
|       struct _cef_menu_model_t* menu_model, |  | ||||||
|       int is_rtl); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // The menu is about to show. |   // The menu is about to show. | ||||||
|   /// |   /// | ||||||
| @@ -112,10 +82,10 @@ typedef struct _cef_menu_model_delegate_t { | |||||||
|   // modified. |   // modified. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *format_label)(struct _cef_menu_model_delegate_t* self, |   int (CEF_CALLBACK *format_label)(struct _cef_menu_model_delegate_t* self, | ||||||
|                                   struct _cef_menu_model_t* menu_model, |       struct _cef_menu_model_t* menu_model, cef_string_t* label); | ||||||
|                                   cef_string_t* label); |  | ||||||
| } cef_menu_model_delegate_t; | } cef_menu_model_delegate_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=e844a5ea18cdcee85faa937d5f2715452eb19d12$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_NAVIGATION_ENTRY_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_NAVIGATION_ENTRY_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_NAVIGATION_ENTRY_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_NAVIGATION_ENTRY_CAPI_H_ | ||||||
| @@ -47,6 +45,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used to represent an entry in navigation history. | // Structure used to represent an entry in navigation history. | ||||||
| /// | /// | ||||||
| @@ -54,7 +53,7 @@ typedef struct _cef_navigation_entry_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if this object is valid. Do not call any other functions |   // Returns true (1) if this object is valid. Do not call any other functions | ||||||
| @@ -116,7 +115,8 @@ typedef struct _cef_navigation_entry_t { | |||||||
|   // response. May be 0 if the response has not yet been received or if the |   // response. May be 0 if the response has not yet been received or if the | ||||||
|   // navigation has not yet completed. |   // navigation has not yet completed. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* get_http_status_code)(struct _cef_navigation_entry_t* self); |   int (CEF_CALLBACK *get_http_status_code)( | ||||||
|  |       struct _cef_navigation_entry_t* self); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the SSL information for this navigation entry. |   // Returns the SSL information for this navigation entry. | ||||||
| @@ -125,6 +125,7 @@ typedef struct _cef_navigation_entry_t { | |||||||
|       struct _cef_navigation_entry_t* self); |       struct _cef_navigation_entry_t* self); | ||||||
| } cef_navigation_entry_t; | } cef_navigation_entry_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=8aa93dd5092138e1cbc66c512624be41de71c1d3$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_ORIGIN_WHITELIST_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_ORIGIN_WHITELIST_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_ORIGIN_WHITELIST_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_ORIGIN_WHITELIST_CAPI_H_ | ||||||
| @@ -46,6 +44,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Add an entry to the cross-origin access whitelist. | // Add an entry to the cross-origin access whitelist. | ||||||
| // | // | ||||||
| @@ -83,20 +82,16 @@ extern "C" { | |||||||
| // |source_origin| is invalid or the whitelist cannot be accessed. | // |source_origin| is invalid or the whitelist cannot be accessed. | ||||||
| /// | /// | ||||||
| CEF_EXPORT int cef_add_cross_origin_whitelist_entry( | CEF_EXPORT int cef_add_cross_origin_whitelist_entry( | ||||||
|     const cef_string_t* source_origin, |     const cef_string_t* source_origin, const cef_string_t* target_protocol, | ||||||
|     const cef_string_t* target_protocol, |     const cef_string_t* target_domain, int allow_target_subdomains); | ||||||
|     const cef_string_t* target_domain, |  | ||||||
|     int allow_target_subdomains); |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Remove an entry from the cross-origin access whitelist. Returns false (0) if | // Remove an entry from the cross-origin access whitelist. Returns false (0) if | ||||||
| // |source_origin| is invalid or the whitelist cannot be accessed. | // |source_origin| is invalid or the whitelist cannot be accessed. | ||||||
| /// | /// | ||||||
| CEF_EXPORT int cef_remove_cross_origin_whitelist_entry( | CEF_EXPORT int cef_remove_cross_origin_whitelist_entry( | ||||||
|     const cef_string_t* source_origin, |     const cef_string_t* source_origin, const cef_string_t* target_protocol, | ||||||
|     const cef_string_t* target_protocol, |     const cef_string_t* target_domain, int allow_target_subdomains); | ||||||
|     const cef_string_t* target_domain, |  | ||||||
|     int allow_target_subdomains); |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Remove all entries from the cross-origin access whitelist. Returns false (0) | // Remove all entries from the cross-origin access whitelist. Returns false (0) | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=9f1c8c065c1604c5d09435e0869b45fd3f51aa31$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_PARSER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_PARSER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_PARSER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_PARSER_CAPI_H_ | ||||||
| @@ -46,6 +44,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Parse the specified |url| into its component parts. Returns false (0) if the | // Parse the specified |url| into its component parts. Returns false (0) if the | ||||||
| // URL is NULL or invalid. | // URL is NULL or invalid. | ||||||
| @@ -72,16 +71,16 @@ CEF_EXPORT int cef_create_url(const struct _cef_urlparts_t* parts, | |||||||
| // for URLs which will be parsed or sent to other applications. | // for URLs which will be parsed or sent to other applications. | ||||||
| /// | /// | ||||||
| // The resulting string must be freed by calling cef_string_userfree_free(). | // The resulting string must be freed by calling cef_string_userfree_free(). | ||||||
| CEF_EXPORT cef_string_userfree_t | CEF_EXPORT cef_string_userfree_t cef_format_url_for_security_display( | ||||||
| cef_format_url_for_security_display(const cef_string_t* origin_url); |     const cef_string_t* origin_url); | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Returns the mime type for the specified file extension or an NULL string if | // Returns the mime type for the specified file extension or an NULL string if | ||||||
| // unknown. | // unknown. | ||||||
| /// | /// | ||||||
| // The resulting string must be freed by calling cef_string_userfree_free(). | // The resulting string must be freed by calling cef_string_userfree_free(). | ||||||
| CEF_EXPORT cef_string_userfree_t | CEF_EXPORT cef_string_userfree_t cef_get_mime_type( | ||||||
| cef_get_mime_type(const cef_string_t* extension); |     const cef_string_t* extension); | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Get the extensions associated with the given mime type. This should be passed | // Get the extensions associated with the given mime type. This should be passed | ||||||
| @@ -127,17 +126,14 @@ CEF_EXPORT cef_string_userfree_t cef_uriencode(const cef_string_t* text, | |||||||
| // supports further customization the decoding process. | // supports further customization the decoding process. | ||||||
| /// | /// | ||||||
| // The resulting string must be freed by calling cef_string_userfree_free(). | // The resulting string must be freed by calling cef_string_userfree_free(). | ||||||
| CEF_EXPORT cef_string_userfree_t | CEF_EXPORT cef_string_userfree_t cef_uridecode(const cef_string_t* text, | ||||||
| cef_uridecode(const cef_string_t* text, |     int convert_to_utf8, cef_uri_unescape_rule_t unescape_rule); | ||||||
|               int convert_to_utf8, |  | ||||||
|               cef_uri_unescape_rule_t unescape_rule); |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Parses the specified |json_string| and returns a dictionary or list | // Parses the specified |json_string| and returns a dictionary or list | ||||||
| // representation. If JSON parsing fails this function returns NULL. | // representation. If JSON parsing fails this function returns NULL. | ||||||
| /// | /// | ||||||
| CEF_EXPORT struct _cef_value_t* cef_parse_json( | CEF_EXPORT struct _cef_value_t* cef_parse_json(const cef_string_t* json_string, | ||||||
|     const cef_string_t* json_string, |  | ||||||
|     cef_json_parser_options_t options); |     cef_json_parser_options_t options); | ||||||
|  |  | ||||||
| /// | /// | ||||||
| @@ -147,10 +143,8 @@ CEF_EXPORT struct _cef_value_t* cef_parse_json( | |||||||
| // formatted error message respectively. | // formatted error message respectively. | ||||||
| /// | /// | ||||||
| CEF_EXPORT struct _cef_value_t* cef_parse_jsonand_return_error( | CEF_EXPORT struct _cef_value_t* cef_parse_jsonand_return_error( | ||||||
|     const cef_string_t* json_string, |     const cef_string_t* json_string, cef_json_parser_options_t options, | ||||||
|     cef_json_parser_options_t options, |     cef_json_parser_error_t* error_code_out, cef_string_t* error_msg_out); | ||||||
|     cef_json_parser_error_t* error_code_out, |  | ||||||
|     cef_string_t* error_msg_out); |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Generates a JSON string from the specified root |node| which should be a | // Generates a JSON string from the specified root |node| which should be a | ||||||
| @@ -158,8 +152,8 @@ CEF_EXPORT struct _cef_value_t* cef_parse_jsonand_return_error( | |||||||
| // requires exclusive access to |node| including any underlying data. | // requires exclusive access to |node| including any underlying data. | ||||||
| /// | /// | ||||||
| // The resulting string must be freed by calling cef_string_userfree_free(). | // The resulting string must be freed by calling cef_string_userfree_free(). | ||||||
| CEF_EXPORT cef_string_userfree_t | CEF_EXPORT cef_string_userfree_t cef_write_json(struct _cef_value_t* node, | ||||||
| cef_write_json(struct _cef_value_t* node, cef_json_writer_options_t options); |     cef_json_writer_options_t options); | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=9d02d9da5fb643fd5dfe46e12e535da7d2e874c7$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_PATH_UTIL_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_PATH_UTIL_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_PATH_UTIL_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_PATH_UTIL_CAPI_H_ | ||||||
| @@ -46,6 +44,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Retrieve the path associated with the specified |key|. Returns true (1) on | // Retrieve the path associated with the specified |key|. Returns true (1) on | ||||||
| // success. Can be called on any thread in the browser process. | // success. Can be called on any thread in the browser process. | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=e063de969dd9903ca0265346818bbbaa52f5446b$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_PRINT_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_PRINT_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_PRINT_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_PRINT_HANDLER_CAPI_H_ | ||||||
| @@ -48,6 +46,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Callback structure for asynchronous continuation of print dialog requests. | // Callback structure for asynchronous continuation of print dialog requests. | ||||||
| /// | /// | ||||||
| @@ -55,7 +54,7 @@ typedef struct _cef_print_dialog_callback_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Continue printing with the specified |settings|. |   // Continue printing with the specified |settings|. | ||||||
| @@ -69,6 +68,7 @@ typedef struct _cef_print_dialog_callback_t { | |||||||
|   void (CEF_CALLBACK *cancel)(struct _cef_print_dialog_callback_t* self); |   void (CEF_CALLBACK *cancel)(struct _cef_print_dialog_callback_t* self); | ||||||
| } cef_print_dialog_callback_t; | } cef_print_dialog_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Callback structure for asynchronous continuation of print job requests. | // Callback structure for asynchronous continuation of print job requests. | ||||||
| /// | /// | ||||||
| @@ -76,7 +76,7 @@ typedef struct _cef_print_job_callback_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Indicate completion of the print job. |   // Indicate completion of the print job. | ||||||
| @@ -84,16 +84,16 @@ typedef struct _cef_print_job_callback_t { | |||||||
|   void (CEF_CALLBACK *cont)(struct _cef_print_job_callback_t* self); |   void (CEF_CALLBACK *cont)(struct _cef_print_job_callback_t* self); | ||||||
| } cef_print_job_callback_t; | } cef_print_job_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Implement this structure to handle printing on Linux. Each browser will have | // Implement this structure to handle printing on Linux. The functions of this | ||||||
| // only one print job in progress at a time. The functions of this structure | // structure will be called on the browser process UI thread. | ||||||
| // will be called on the browser process UI thread. |  | ||||||
| /// | /// | ||||||
| typedef struct _cef_print_handler_t { | typedef struct _cef_print_handler_t { | ||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when printing has started for the specified |browser|. This function |   // Called when printing has started for the specified |browser|. This function | ||||||
| @@ -110,20 +110,15 @@ typedef struct _cef_print_handler_t { | |||||||
|   // reference to |settings| outside of this callback. |   // reference to |settings| outside of this callback. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_print_settings)(struct _cef_print_handler_t* self, |   void (CEF_CALLBACK *on_print_settings)(struct _cef_print_handler_t* self, | ||||||
|                                         struct _cef_browser_t* browser, |       struct _cef_print_settings_t* settings, int get_defaults); | ||||||
|                                         struct _cef_print_settings_t* settings, |  | ||||||
|                                         int get_defaults); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Show the print dialog. Execute |callback| once the dialog is dismissed. |   // Show the print dialog. Execute |callback| once the dialog is dismissed. | ||||||
|   // Return true (1) if the dialog will be displayed or false (0) to cancel the |   // Return true (1) if the dialog will be displayed or false (0) to cancel the | ||||||
|   // printing immediately. |   // printing immediately. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* on_print_dialog)( |   int (CEF_CALLBACK *on_print_dialog)(struct _cef_print_handler_t* self, | ||||||
|       struct _cef_print_handler_t* self, |       int has_selection, struct _cef_print_dialog_callback_t* callback); | ||||||
|       struct _cef_browser_t* browser, |  | ||||||
|       int has_selection, |  | ||||||
|       struct _cef_print_dialog_callback_t* callback); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Send the print job to the printer. Execute |callback| once the job is |   // Send the print job to the printer. Execute |callback| once the job is | ||||||
| @@ -131,26 +126,23 @@ typedef struct _cef_print_handler_t { | |||||||
|   // the job immediately. |   // the job immediately. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *on_print_job)(struct _cef_print_handler_t* self, |   int (CEF_CALLBACK *on_print_job)(struct _cef_print_handler_t* self, | ||||||
|                                   struct _cef_browser_t* browser, |       const cef_string_t* document_name, const cef_string_t* pdf_file_path, | ||||||
|                                   const cef_string_t* document_name, |  | ||||||
|                                   const cef_string_t* pdf_file_path, |  | ||||||
|       struct _cef_print_job_callback_t* callback); |       struct _cef_print_job_callback_t* callback); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Reset client state related to printing. |   // Reset client state related to printing. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* on_print_reset)(struct _cef_print_handler_t* self, |   void (CEF_CALLBACK *on_print_reset)(struct _cef_print_handler_t* self); | ||||||
|                                      struct _cef_browser_t* browser); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Return the PDF paper size in device units. Used in combination with |   // Return the PDF paper size in device units. Used in combination with | ||||||
|   // cef_browser_host_t::print_to_pdf(). |   // cef_browser_host_t::print_to_pdf(). | ||||||
|   /// |   /// | ||||||
|   cef_size_t (CEF_CALLBACK *get_pdf_paper_size)( |   cef_size_t (CEF_CALLBACK *get_pdf_paper_size)( | ||||||
|       struct _cef_print_handler_t* self, |       struct _cef_print_handler_t* self, int device_units_per_inch); | ||||||
|       int device_units_per_inch); |  | ||||||
| } cef_print_handler_t; | } cef_print_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=593308c65c50c7f6bd890541426806a9bf07a00b$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_PRINT_SETTINGS_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_PRINT_SETTINGS_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_PRINT_SETTINGS_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_PRINT_SETTINGS_CAPI_H_ | ||||||
| @@ -46,6 +44,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure representing print settings. | // Structure representing print settings. | ||||||
| /// | /// | ||||||
| @@ -53,7 +52,7 @@ typedef struct _cef_print_settings_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if this object is valid. Do not call any other functions |   // Returns true (1) if this object is valid. Do not call any other functions | ||||||
| @@ -122,8 +121,7 @@ typedef struct _cef_print_settings_t { | |||||||
|   // Set the page ranges. |   // Set the page ranges. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *set_page_ranges)(struct _cef_print_settings_t* self, |   void (CEF_CALLBACK *set_page_ranges)(struct _cef_print_settings_t* self, | ||||||
|                                       size_t rangesCount, |       size_t rangesCount, cef_range_t const* ranges); | ||||||
|                                       cef_range_t const* ranges); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the number of page ranges that currently exist. |   // Returns the number of page ranges that currently exist. | ||||||
| @@ -135,8 +133,7 @@ typedef struct _cef_print_settings_t { | |||||||
|   // Retrieve the page ranges. |   // Retrieve the page ranges. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *get_page_ranges)(struct _cef_print_settings_t* self, |   void (CEF_CALLBACK *get_page_ranges)(struct _cef_print_settings_t* self, | ||||||
|                                       size_t* rangesCount, |       size_t* rangesCount, cef_range_t* ranges); | ||||||
|                                       cef_range_t* ranges); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Set whether only the selection will be printed. |   // Set whether only the selection will be printed. | ||||||
| @@ -196,11 +193,13 @@ typedef struct _cef_print_settings_t { | |||||||
|       struct _cef_print_settings_t* self); |       struct _cef_print_settings_t* self); | ||||||
| } cef_print_settings_t; | } cef_print_settings_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Create a new cef_print_settings_t object. | // Create a new cef_print_settings_t object. | ||||||
| /// | /// | ||||||
| CEF_EXPORT cef_print_settings_t* cef_print_settings_create(); | CEF_EXPORT cef_print_settings_t* cef_print_settings_create(); | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=5f8cd4eb4e6215cb0f6161b916dc51197e345204$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_PROCESS_MESSAGE_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_PROCESS_MESSAGE_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_PROCESS_MESSAGE_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_PROCESS_MESSAGE_CAPI_H_ | ||||||
| @@ -47,6 +45,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure representing a message. Can be used on any process and thread. | // Structure representing a message. Can be used on any process and thread. | ||||||
| /// | /// | ||||||
| @@ -54,7 +53,7 @@ typedef struct _cef_process_message_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if this object is valid. Do not call any other functions |   // Returns true (1) if this object is valid. Do not call any other functions | ||||||
| @@ -88,12 +87,14 @@ typedef struct _cef_process_message_t { | |||||||
|       struct _cef_process_message_t* self); |       struct _cef_process_message_t* self); | ||||||
| } cef_process_message_t; | } cef_process_message_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Create a new cef_process_message_t object with the specified name. | // Create a new cef_process_message_t object with the specified name. | ||||||
| /// | /// | ||||||
| CEF_EXPORT cef_process_message_t* cef_process_message_create( | CEF_EXPORT cef_process_message_t* cef_process_message_create( | ||||||
|     const cef_string_t* name); |     const cef_string_t* name); | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=aa003bb87d891baa8c79742dadcac6fe75f32737$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_PROCESS_UTIL_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_PROCESS_UTIL_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_PROCESS_UTIL_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_PROCESS_UTIL_CAPI_H_ | ||||||
| @@ -46,6 +44,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Launches the process specified via |command_line|. Returns true (1) upon | // Launches the process specified via |command_line|. Returns true (1) upon | ||||||
| // success. Must be called on the browser process TID_PROCESS_LAUNCHER thread. | // success. Must be called on the browser process TID_PROCESS_LAUNCHER thread. | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,14 +33,11 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=f2f3acb1df9815e4ac9bf34010ce260a2496ae5a$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_RENDER_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_RENDER_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_RENDER_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_RENDER_HANDLER_CAPI_H_ | ||||||
| #pragma once | #pragma once | ||||||
|  |  | ||||||
| #include "include/capi/cef_accessibility_handler_capi.h" |  | ||||||
| #include "include/capi/cef_base_capi.h" | #include "include/capi/cef_base_capi.h" | ||||||
| #include "include/capi/cef_browser_capi.h" | #include "include/capi/cef_browser_capi.h" | ||||||
| #include "include/capi/cef_drag_data_capi.h" | #include "include/capi/cef_drag_data_capi.h" | ||||||
| @@ -49,6 +46,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Implement this structure to handle events when window rendering is disabled. | // Implement this structure to handle events when window rendering is disabled. | ||||||
| // The functions of this structure will be called on the UI thread. | // The functions of this structure will be called on the UI thread. | ||||||
| @@ -57,40 +55,28 @@ typedef struct _cef_render_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Return the handler for accessibility notifications. If no handler is |  | ||||||
|   // provided the default implementation will be used. |  | ||||||
|   /// |  | ||||||
|   struct _cef_accessibility_handler_t*(CEF_CALLBACK* get_accessibility_handler)( |  | ||||||
|       struct _cef_render_handler_t* self); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called to retrieve the root window rectangle in screen coordinates. Return |   // Called to retrieve the root window rectangle in screen coordinates. Return | ||||||
|   // true (1) if the rectangle was provided. |   // true (1) if the rectangle was provided. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *get_root_screen_rect)(struct _cef_render_handler_t* self, |   int (CEF_CALLBACK *get_root_screen_rect)(struct _cef_render_handler_t* self, | ||||||
|                                           struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, cef_rect_t* rect); | ||||||
|                                           cef_rect_t* rect); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called to retrieve the view rectangle which is relative to screen |   // Called to retrieve the view rectangle which is relative to screen | ||||||
|   // coordinates. Return true (1) if the rectangle was provided. |   // coordinates. Return true (1) if the rectangle was provided. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *get_view_rect)(struct _cef_render_handler_t* self, |   int (CEF_CALLBACK *get_view_rect)(struct _cef_render_handler_t* self, | ||||||
|                                    struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, cef_rect_t* rect); | ||||||
|                                    cef_rect_t* rect); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called to retrieve the translation from view coordinates to actual screen |   // Called to retrieve the translation from view coordinates to actual screen | ||||||
|   // coordinates. Return true (1) if the screen coordinates were provided. |   // coordinates. Return true (1) if the screen coordinates were provided. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *get_screen_point)(struct _cef_render_handler_t* self, |   int (CEF_CALLBACK *get_screen_point)(struct _cef_render_handler_t* self, | ||||||
|                                       struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, int viewX, int viewY, int* screenX, | ||||||
|                                       int viewX, |  | ||||||
|                                       int viewY, |  | ||||||
|                                       int* screenX, |  | ||||||
|       int* screenY); |       int* screenY); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -103,24 +89,21 @@ typedef struct _cef_render_handler_t { | |||||||
|   // drawn correctly. |   // drawn correctly. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *get_screen_info)(struct _cef_render_handler_t* self, |   int (CEF_CALLBACK *get_screen_info)(struct _cef_render_handler_t* self, | ||||||
|                                      struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, struct _cef_screen_info_t* screen_info); | ||||||
|                                      struct _cef_screen_info_t* screen_info); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when the browser wants to show or hide the popup widget. The popup |   // Called when the browser wants to show or hide the popup widget. The popup | ||||||
|   // should be shown if |show| is true (1) and hidden if |show| is false (0). |   // should be shown if |show| is true (1) and hidden if |show| is false (0). | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_popup_show)(struct _cef_render_handler_t* self, |   void (CEF_CALLBACK *on_popup_show)(struct _cef_render_handler_t* self, | ||||||
|                                     struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, int show); | ||||||
|                                     int show); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when the browser wants to move or resize the popup widget. |rect| |   // Called when the browser wants to move or resize the popup widget. |rect| | ||||||
|   // contains the new location and size in view coordinates. |   // contains the new location and size in view coordinates. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_popup_size)(struct _cef_render_handler_t* self, |   void (CEF_CALLBACK *on_popup_size)(struct _cef_render_handler_t* self, | ||||||
|                                     struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, const cef_rect_t* rect); | ||||||
|                                     const cef_rect_t* rect); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when an element should be painted. Pixel values passed to this |   // Called when an element should be painted. Pixel values passed to this | ||||||
| @@ -133,22 +116,16 @@ typedef struct _cef_render_handler_t { | |||||||
|   // upper-left origin. |   // upper-left origin. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_paint)(struct _cef_render_handler_t* self, |   void (CEF_CALLBACK *on_paint)(struct _cef_render_handler_t* self, | ||||||
|                                struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, cef_paint_element_type_t type, | ||||||
|                                cef_paint_element_type_t type, |       size_t dirtyRectsCount, cef_rect_t const* dirtyRects, const void* buffer, | ||||||
|                                size_t dirtyRectsCount, |       int width, int height); | ||||||
|                                cef_rect_t const* dirtyRects, |  | ||||||
|                                const void* buffer, |  | ||||||
|                                int width, |  | ||||||
|                                int height); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when the browser's cursor has changed. If |type| is CT_CUSTOM then |   // Called when the browser's cursor has changed. If |type| is CT_CUSTOM then | ||||||
|   // |custom_cursor_info| will be populated with the custom cursor information. |   // |custom_cursor_info| will be populated with the custom cursor information. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* on_cursor_change)( |   void (CEF_CALLBACK *on_cursor_change)(struct _cef_render_handler_t* self, | ||||||
|       struct _cef_render_handler_t* self, |       struct _cef_browser_t* browser, cef_cursor_handle_t cursor, | ||||||
|       struct _cef_browser_t* browser, |  | ||||||
|       cef_cursor_handle_t cursor, |  | ||||||
|       cef_cursor_type_t type, |       cef_cursor_type_t type, | ||||||
|       const struct _cef_cursor_info_t* custom_cursor_info); |       const struct _cef_cursor_info_t* custom_cursor_info); | ||||||
|  |  | ||||||
| @@ -167,11 +144,8 @@ typedef struct _cef_render_handler_t { | |||||||
|   // operation has ended. |   // operation has ended. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *start_dragging)(struct _cef_render_handler_t* self, |   int (CEF_CALLBACK *start_dragging)(struct _cef_render_handler_t* self, | ||||||
|                                     struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, struct _cef_drag_data_t* drag_data, | ||||||
|                                     struct _cef_drag_data_t* drag_data, |       cef_drag_operations_mask_t allowed_ops, int x, int y); | ||||||
|                                     cef_drag_operations_mask_t allowed_ops, |  | ||||||
|                                     int x, |  | ||||||
|                                     int y); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when the web view wants to update the mouse cursor during a drag & |   // Called when the web view wants to update the mouse cursor during a drag & | ||||||
| @@ -179,17 +153,14 @@ typedef struct _cef_render_handler_t { | |||||||
|   // copy, link). |   // copy, link). | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *update_drag_cursor)(struct _cef_render_handler_t* self, |   void (CEF_CALLBACK *update_drag_cursor)(struct _cef_render_handler_t* self, | ||||||
|                                          struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, cef_drag_operations_mask_t operation); | ||||||
|                                          cef_drag_operations_mask_t operation); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when the scroll offset has changed. |   // Called when the scroll offset has changed. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_scroll_offset_changed)( |   void (CEF_CALLBACK *on_scroll_offset_changed)( | ||||||
|       struct _cef_render_handler_t* self, |       struct _cef_render_handler_t* self, struct _cef_browser_t* browser, | ||||||
|       struct _cef_browser_t* browser, |       double x, double y); | ||||||
|       double x, |  | ||||||
|       double y); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called when the IME composition range has changed. |selected_range| is the |   // Called when the IME composition range has changed. |selected_range| is the | ||||||
| @@ -197,24 +168,12 @@ typedef struct _cef_render_handler_t { | |||||||
|   // bounds of each character in view coordinates. |   // bounds of each character in view coordinates. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_ime_composition_range_changed)( |   void (CEF_CALLBACK *on_ime_composition_range_changed)( | ||||||
|       struct _cef_render_handler_t* self, |       struct _cef_render_handler_t* self, struct _cef_browser_t* browser, | ||||||
|       struct _cef_browser_t* browser, |       const cef_range_t* selected_range, size_t character_boundsCount, | ||||||
|       const cef_range_t* selected_range, |  | ||||||
|       size_t character_boundsCount, |  | ||||||
|       cef_rect_t const* character_bounds); |       cef_rect_t const* character_bounds); | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called when text selection has changed for the specified |browser|. |  | ||||||
|   // |selected_text| is the currently selected text and |selected_range| is the |  | ||||||
|   // character range. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* on_text_selection_changed)( |  | ||||||
|       struct _cef_render_handler_t* self, |  | ||||||
|       struct _cef_browser_t* browser, |  | ||||||
|       const cef_string_t* selected_text, |  | ||||||
|       const cef_range_t* selected_range); |  | ||||||
| } cef_render_handler_t; | } cef_render_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=fb34d81715ada28d5509cd33aa36f37829933a91$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_RENDER_PROCESS_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_RENDER_PROCESS_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_RENDER_PROCESS_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_RENDER_PROCESS_HANDLER_CAPI_H_ | ||||||
| @@ -53,6 +51,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used to implement render process callbacks. The functions of this | // Structure used to implement render process callbacks. The functions of this | ||||||
| // structure will be called on the render process main thread (TID_RENDERER) | // structure will be called on the render process main thread (TID_RENDERER) | ||||||
| @@ -62,7 +61,7 @@ typedef struct _cef_render_process_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called after the render process main thread has been created. |extra_info| |   // Called after the render process main thread has been created. |extra_info| | ||||||
| @@ -102,6 +101,17 @@ typedef struct _cef_render_process_handler_t { | |||||||
|   struct _cef_load_handler_t* (CEF_CALLBACK *get_load_handler)( |   struct _cef_load_handler_t* (CEF_CALLBACK *get_load_handler)( | ||||||
|       struct _cef_render_process_handler_t* self); |       struct _cef_render_process_handler_t* self); | ||||||
|  |  | ||||||
|  |   /// | ||||||
|  |   // Called before browser navigation. Return true (1) to cancel the navigation | ||||||
|  |   // or false (0) to allow the navigation to proceed. The |request| object | ||||||
|  |   // cannot be modified in this callback. | ||||||
|  |   /// | ||||||
|  |   int (CEF_CALLBACK *on_before_navigation)( | ||||||
|  |       struct _cef_render_process_handler_t* self, | ||||||
|  |       struct _cef_browser_t* browser, struct _cef_frame_t* frame, | ||||||
|  |       struct _cef_request_t* request, cef_navigation_type_t navigation_type, | ||||||
|  |       int is_redirect); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called immediately after the V8 context for a frame has been created. To |   // Called immediately after the V8 context for a frame has been created. To | ||||||
|   // retrieve the JavaScript 'window' object use the |   // retrieve the JavaScript 'window' object use the | ||||||
| @@ -112,8 +122,7 @@ typedef struct _cef_render_process_handler_t { | |||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_context_created)( |   void (CEF_CALLBACK *on_context_created)( | ||||||
|       struct _cef_render_process_handler_t* self, |       struct _cef_render_process_handler_t* self, | ||||||
|       struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, struct _cef_frame_t* frame, | ||||||
|       struct _cef_frame_t* frame, |  | ||||||
|       struct _cef_v8context_t* context); |       struct _cef_v8context_t* context); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -122,8 +131,7 @@ typedef struct _cef_render_process_handler_t { | |||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_context_released)( |   void (CEF_CALLBACK *on_context_released)( | ||||||
|       struct _cef_render_process_handler_t* self, |       struct _cef_render_process_handler_t* self, | ||||||
|       struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, struct _cef_frame_t* frame, | ||||||
|       struct _cef_frame_t* frame, |  | ||||||
|       struct _cef_v8context_t* context); |       struct _cef_v8context_t* context); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -133,10 +141,8 @@ typedef struct _cef_render_process_handler_t { | |||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_uncaught_exception)( |   void (CEF_CALLBACK *on_uncaught_exception)( | ||||||
|       struct _cef_render_process_handler_t* self, |       struct _cef_render_process_handler_t* self, | ||||||
|       struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, struct _cef_frame_t* frame, | ||||||
|       struct _cef_frame_t* frame, |       struct _cef_v8context_t* context, struct _cef_v8exception_t* exception, | ||||||
|       struct _cef_v8context_t* context, |  | ||||||
|       struct _cef_v8exception_t* exception, |  | ||||||
|       struct _cef_v8stack_trace_t* stackTrace); |       struct _cef_v8stack_trace_t* stackTrace); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -149,8 +155,7 @@ typedef struct _cef_render_process_handler_t { | |||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_focused_node_changed)( |   void (CEF_CALLBACK *on_focused_node_changed)( | ||||||
|       struct _cef_render_process_handler_t* self, |       struct _cef_render_process_handler_t* self, | ||||||
|       struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, struct _cef_frame_t* frame, | ||||||
|       struct _cef_frame_t* frame, |  | ||||||
|       struct _cef_domnode_t* node); |       struct _cef_domnode_t* node); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -160,11 +165,11 @@ typedef struct _cef_render_process_handler_t { | |||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *on_process_message_received)( |   int (CEF_CALLBACK *on_process_message_received)( | ||||||
|       struct _cef_render_process_handler_t* self, |       struct _cef_render_process_handler_t* self, | ||||||
|       struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, cef_process_id_t source_process, | ||||||
|       cef_process_id_t source_process, |  | ||||||
|       struct _cef_process_message_t* message); |       struct _cef_process_message_t* message); | ||||||
| } cef_render_process_handler_t; | } cef_render_process_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=d7f34d867389c53c384f366e08f958ed724f9b90$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_REQUEST_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_REQUEST_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_REQUEST_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_REQUEST_CAPI_H_ | ||||||
| @@ -57,7 +55,7 @@ typedef struct _cef_request_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if this object is read-only. |   // Returns true (1) if this object is read-only. | ||||||
| @@ -95,8 +93,7 @@ typedef struct _cef_request_t { | |||||||
|   // ref component will be removed. |   // ref component will be removed. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *set_referrer)(struct _cef_request_t* self, |   void (CEF_CALLBACK *set_referrer)(struct _cef_request_t* self, | ||||||
|                                    const cef_string_t* referrer_url, |       const cef_string_t* referrer_url, cef_referrer_policy_t policy); | ||||||
|                                    cef_referrer_policy_t policy); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Get the referrer URL. |   // Get the referrer URL. | ||||||
| @@ -139,10 +136,8 @@ typedef struct _cef_request_t { | |||||||
|   /// |   /// | ||||||
|   // Set all values at one time. |   // Set all values at one time. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* set)(struct _cef_request_t* self, |   void (CEF_CALLBACK *set)(struct _cef_request_t* self, const cef_string_t* url, | ||||||
|                           const cef_string_t* url, |       const cef_string_t* method, struct _cef_post_data_t* postData, | ||||||
|                           const cef_string_t* method, |  | ||||||
|                           struct _cef_post_data_t* postData, |  | ||||||
|       cef_string_multimap_t headerMap); |       cef_string_multimap_t headerMap); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -158,7 +153,7 @@ typedef struct _cef_request_t { | |||||||
|   void (CEF_CALLBACK *set_flags)(struct _cef_request_t* self, int flags); |   void (CEF_CALLBACK *set_flags)(struct _cef_request_t* self, int flags); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Get the URL to the first party for cookies used in combination with |   // Set the URL to the first party for cookies used in combination with | ||||||
|   // cef_urlrequest_t. |   // cef_urlrequest_t. | ||||||
|   /// |   /// | ||||||
|   // The resulting string must be freed by calling cef_string_userfree_free(). |   // The resulting string must be freed by calling cef_string_userfree_free(). | ||||||
| @@ -166,7 +161,7 @@ typedef struct _cef_request_t { | |||||||
|       struct _cef_request_t* self); |       struct _cef_request_t* self); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Set the URL to the first party for cookies used in combination with |   // Get the URL to the first party for cookies used in combination with | ||||||
|   // cef_urlrequest_t. |   // cef_urlrequest_t. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *set_first_party_for_cookies)(struct _cef_request_t* self, |   void (CEF_CALLBACK *set_first_party_for_cookies)(struct _cef_request_t* self, | ||||||
| @@ -195,11 +190,13 @@ typedef struct _cef_request_t { | |||||||
|   uint64 (CEF_CALLBACK *get_identifier)(struct _cef_request_t* self); |   uint64 (CEF_CALLBACK *get_identifier)(struct _cef_request_t* self); | ||||||
| } cef_request_t; | } cef_request_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Create a new cef_request_t object. | // Create a new cef_request_t object. | ||||||
| /// | /// | ||||||
| CEF_EXPORT cef_request_t* cef_request_create(); | CEF_EXPORT cef_request_t* cef_request_create(); | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used to represent post data for a web request. The functions of | // Structure used to represent post data for a web request. The functions of | ||||||
| // this structure may be called on any thread. | // this structure may be called on any thread. | ||||||
| @@ -208,7 +205,7 @@ typedef struct _cef_post_data_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if this object is read-only. |   // Returns true (1) if this object is read-only. | ||||||
| @@ -232,8 +229,7 @@ typedef struct _cef_post_data_t { | |||||||
|   // Retrieve the post data elements. |   // Retrieve the post data elements. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *get_elements)(struct _cef_post_data_t* self, |   void (CEF_CALLBACK *get_elements)(struct _cef_post_data_t* self, | ||||||
|                                    size_t* elementsCount, |       size_t* elementsCount, struct _cef_post_data_element_t** elements); | ||||||
|                                    struct _cef_post_data_element_t** elements); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Remove the specified post data element.  Returns true (1) if the removal |   // Remove the specified post data element.  Returns true (1) if the removal | ||||||
| @@ -254,11 +250,13 @@ typedef struct _cef_post_data_t { | |||||||
|   void (CEF_CALLBACK *remove_elements)(struct _cef_post_data_t* self); |   void (CEF_CALLBACK *remove_elements)(struct _cef_post_data_t* self); | ||||||
| } cef_post_data_t; | } cef_post_data_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Create a new cef_post_data_t object. | // Create a new cef_post_data_t object. | ||||||
| /// | /// | ||||||
| CEF_EXPORT cef_post_data_t* cef_post_data_create(); | CEF_EXPORT cef_post_data_t* cef_post_data_create(); | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used to represent a single element in the request post data. The | // Structure used to represent a single element in the request post data. The | ||||||
| // functions of this structure may be called on any thread. | // functions of this structure may be called on any thread. | ||||||
| @@ -267,7 +265,7 @@ typedef struct _cef_post_data_element_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if this object is read-only. |   // Returns true (1) if this object is read-only. | ||||||
| @@ -290,8 +288,7 @@ typedef struct _cef_post_data_element_t { | |||||||
|   // copied. |   // copied. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *set_to_bytes)(struct _cef_post_data_element_t* self, |   void (CEF_CALLBACK *set_to_bytes)(struct _cef_post_data_element_t* self, | ||||||
|                                    size_t size, |       size_t size, const void* bytes); | ||||||
|                                    const void* bytes); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Return the type of this post data element. |   // Return the type of this post data element. | ||||||
| @@ -316,15 +313,16 @@ typedef struct _cef_post_data_element_t { | |||||||
|   // actually read. |   // actually read. | ||||||
|   /// |   /// | ||||||
|   size_t (CEF_CALLBACK *get_bytes)(struct _cef_post_data_element_t* self, |   size_t (CEF_CALLBACK *get_bytes)(struct _cef_post_data_element_t* self, | ||||||
|                                   size_t size, |       size_t size, void* bytes); | ||||||
|                                   void* bytes); |  | ||||||
| } cef_post_data_element_t; | } cef_post_data_element_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Create a new cef_post_data_element_t object. | // Create a new cef_post_data_element_t object. | ||||||
| /// | /// | ||||||
| CEF_EXPORT cef_post_data_element_t* cef_post_data_element_create(); | CEF_EXPORT cef_post_data_element_t* cef_post_data_element_create(); | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=5f6d84d988bab3a600e6fbb6db0523acaeef88b3$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_REQUEST_CONTEXT_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_REQUEST_CONTEXT_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_REQUEST_CONTEXT_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_REQUEST_CONTEXT_CAPI_H_ | ||||||
| @@ -42,8 +40,6 @@ | |||||||
|  |  | ||||||
| #include "include/capi/cef_callback_capi.h" | #include "include/capi/cef_callback_capi.h" | ||||||
| #include "include/capi/cef_cookie_capi.h" | #include "include/capi/cef_cookie_capi.h" | ||||||
| #include "include/capi/cef_extension_capi.h" |  | ||||||
| #include "include/capi/cef_extension_handler_capi.h" |  | ||||||
| #include "include/capi/cef_request_context_handler_capi.h" | #include "include/capi/cef_request_context_handler_capi.h" | ||||||
| #include "include/capi/cef_values_capi.h" | #include "include/capi/cef_values_capi.h" | ||||||
|  |  | ||||||
| @@ -60,18 +56,19 @@ typedef struct _cef_resolve_callback_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called on the UI thread after the ResolveHost request has completed. |   // Called after the ResolveHost request has completed. |result| will be the | ||||||
|   // |result| will be the result code. |resolved_ips| will be the list of |   // result code. |resolved_ips| will be the list of resolved IP addresses or | ||||||
|   // resolved IP addresses or NULL if the resolution failed. |   // NULL if the resolution failed. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* on_resolve_completed)(struct _cef_resolve_callback_t* self, |   void (CEF_CALLBACK *on_resolve_completed)( | ||||||
|                                            cef_errorcode_t result, |       struct _cef_resolve_callback_t* self, cef_errorcode_t result, | ||||||
|       cef_string_list_t resolved_ips); |       cef_string_list_t resolved_ips); | ||||||
| } cef_resolve_callback_t; | } cef_resolve_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // A request context provides request handling for a set of related browser or | // A request context provides request handling for a set of related browser or | ||||||
| // URL request objects. A request context can be specified when creating a new | // URL request objects. A request context can be specified when creating a new | ||||||
| @@ -92,7 +89,7 @@ typedef struct _cef_request_context_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if this object is pointing to the same context as |that| |   // Returns true (1) if this object is pointing to the same context as |that| | ||||||
| @@ -155,8 +152,7 @@ typedef struct _cef_request_context_t { | |||||||
|   // may be called on any thread in the browser process. |   // may be called on any thread in the browser process. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *register_scheme_handler_factory)( |   int (CEF_CALLBACK *register_scheme_handler_factory)( | ||||||
|       struct _cef_request_context_t* self, |       struct _cef_request_context_t* self, const cef_string_t* scheme_name, | ||||||
|       const cef_string_t* scheme_name, |  | ||||||
|       const cef_string_t* domain_name, |       const cef_string_t* domain_name, | ||||||
|       struct _cef_scheme_handler_factory_t* factory); |       struct _cef_scheme_handler_factory_t* factory); | ||||||
|  |  | ||||||
| @@ -175,8 +171,7 @@ typedef struct _cef_request_context_t { | |||||||
|   // the plugin list cache. |   // the plugin list cache. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *purge_plugin_list_cache)( |   void (CEF_CALLBACK *purge_plugin_list_cache)( | ||||||
|       struct _cef_request_context_t* self, |       struct _cef_request_context_t* self, int reload_pages); | ||||||
|       int reload_pages); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if a preference with the specified |name| exists. This |   // Returns true (1) if a preference with the specified |name| exists. This | ||||||
| @@ -193,8 +188,7 @@ typedef struct _cef_request_context_t { | |||||||
|   // called on the browser process UI thread. |   // called on the browser process UI thread. | ||||||
|   /// |   /// | ||||||
|   struct _cef_value_t* (CEF_CALLBACK *get_preference)( |   struct _cef_value_t* (CEF_CALLBACK *get_preference)( | ||||||
|       struct _cef_request_context_t* self, |       struct _cef_request_context_t* self, const cef_string_t* name); | ||||||
|       const cef_string_t* name); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns all preferences as a dictionary. If |include_defaults| is true (1) |   // Returns all preferences as a dictionary. If |include_defaults| is true (1) | ||||||
| @@ -205,8 +199,7 @@ typedef struct _cef_request_context_t { | |||||||
|   // thread. |   // thread. | ||||||
|   /// |   /// | ||||||
|   struct _cef_dictionary_value_t* (CEF_CALLBACK *get_all_preferences)( |   struct _cef_dictionary_value_t* (CEF_CALLBACK *get_all_preferences)( | ||||||
|       struct _cef_request_context_t* self, |       struct _cef_request_context_t* self, int include_defaults); | ||||||
|       int include_defaults); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if the preference with the specified |name| can be |   // Returns true (1) if the preference with the specified |name| can be | ||||||
| @@ -225,8 +218,7 @@ typedef struct _cef_request_context_t { | |||||||
|   // problem. This function must be called on the browser process UI thread. |   // problem. This function must be called on the browser process UI thread. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *set_preference)(struct _cef_request_context_t* self, |   int (CEF_CALLBACK *set_preference)(struct _cef_request_context_t* self, | ||||||
|                                     const cef_string_t* name, |       const cef_string_t* name, struct _cef_value_t* value, | ||||||
|                                     struct _cef_value_t* value, |  | ||||||
|       cef_string_t* error); |       cef_string_t* error); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -244,7 +236,7 @@ typedef struct _cef_request_context_t { | |||||||
|   /// |   /// | ||||||
|   // Clears all active and idle connections that Chromium currently has. This is |   // Clears all active and idle connections that Chromium currently has. This is | ||||||
|   // only recommended if you have released all other CEF objects but don't yet |   // only recommended if you have released all other CEF objects but don't yet | ||||||
|   // want to call Cefshutdown(). If |callback| is non-NULL it will be executed |   // want to call cef_shutdown(). If |callback| is non-NULL it will be executed | ||||||
|   // on the UI thread after completion. |   // on the UI thread after completion. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *close_all_connections)( |   void (CEF_CALLBACK *close_all_connections)( | ||||||
| @@ -256,8 +248,7 @@ typedef struct _cef_request_context_t { | |||||||
|   // |callback| will be executed on the UI thread after completion. |   // |callback| will be executed on the UI thread after completion. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *resolve_host)(struct _cef_request_context_t* self, |   void (CEF_CALLBACK *resolve_host)(struct _cef_request_context_t* self, | ||||||
|                                    const cef_string_t* origin, |       const cef_string_t* origin, struct _cef_resolve_callback_t* callback); | ||||||
|                                    struct _cef_resolve_callback_t* callback); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Attempts to resolve |origin| to a list of associated IP addresses using |   // Attempts to resolve |origin| to a list of associated IP addresses using | ||||||
| @@ -266,100 +257,11 @@ typedef struct _cef_request_context_t { | |||||||
|   // success. This function must be called on the browser process IO thread. |   // success. This function must be called on the browser process IO thread. | ||||||
|   /// |   /// | ||||||
|   cef_errorcode_t (CEF_CALLBACK *resolve_host_cached)( |   cef_errorcode_t (CEF_CALLBACK *resolve_host_cached)( | ||||||
|       struct _cef_request_context_t* self, |       struct _cef_request_context_t* self, const cef_string_t* origin, | ||||||
|       const cef_string_t* origin, |  | ||||||
|       cef_string_list_t resolved_ips); |       cef_string_list_t resolved_ips); | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Load an extension. |  | ||||||
|   // |  | ||||||
|   // If extension resources will be read from disk using the default load |  | ||||||
|   // implementation then |root_directory| should be the absolute path to the |  | ||||||
|   // extension resources directory and |manifest| should be NULL. If extension |  | ||||||
|   // resources will be provided by the client (e.g. via cef_request_tHandler |  | ||||||
|   // and/or cef_extension_tHandler) then |root_directory| should be a path |  | ||||||
|   // component unique to the extension (if not absolute this will be internally |  | ||||||
|   // prefixed with the PK_DIR_RESOURCES path) and |manifest| should contain the |  | ||||||
|   // contents that would otherwise be read from the "manifest.json" file on |  | ||||||
|   // disk. |  | ||||||
|   // |  | ||||||
|   // The loaded extension will be accessible in all contexts sharing the same |  | ||||||
|   // storage (HasExtension returns true (1)). However, only the context on which |  | ||||||
|   // this function was called is considered the loader (DidLoadExtension returns |  | ||||||
|   // true (1)) and only the loader will receive cef_request_tContextHandler |  | ||||||
|   // callbacks for the extension. |  | ||||||
|   // |  | ||||||
|   // cef_extension_tHandler::OnExtensionLoaded will be called on load success or |  | ||||||
|   // cef_extension_tHandler::OnExtensionLoadFailed will be called on load |  | ||||||
|   // failure. |  | ||||||
|   // |  | ||||||
|   // If the extension specifies a background script via the "background" |  | ||||||
|   // manifest key then cef_extension_tHandler::OnBeforeBackgroundBrowser will be |  | ||||||
|   // called to create the background browser. See that function for additional |  | ||||||
|   // information about background scripts. |  | ||||||
|   // |  | ||||||
|   // For visible extension views the client application should evaluate the |  | ||||||
|   // manifest to determine the correct extension URL to load and then pass that |  | ||||||
|   // URL to the cef_browser_host_t::CreateBrowser* function after the extension |  | ||||||
|   // has loaded. For example, the client can look for the "browser_action" |  | ||||||
|   // manifest key as documented at |  | ||||||
|   // https://developer.chrome.com/extensions/browserAction. Extension URLs take |  | ||||||
|   // the form "chrome-extension://<extension_id>/<path>". |  | ||||||
|   // |  | ||||||
|   // Browsers that host extensions differ from normal browsers as follows: |  | ||||||
|   //  - Can access chrome.* JavaScript APIs if allowed by the manifest. Visit |  | ||||||
|   //    chrome://extensions-support for the list of extension APIs currently |  | ||||||
|   //    supported by CEF. |  | ||||||
|   //  - Main frame navigation to non-extension content is blocked. |  | ||||||
|   //  - Pinch-zooming is disabled. |  | ||||||
|   //  - CefBrowserHost::GetExtension returns the hosted extension. |  | ||||||
|   //  - CefBrowserHost::IsBackgroundHost returns true for background hosts. |  | ||||||
|   // |  | ||||||
|   // See https://developer.chrome.com/extensions for extension implementation |  | ||||||
|   // and usage documentation. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* load_extension)(struct _cef_request_context_t* self, |  | ||||||
|                                      const cef_string_t* root_directory, |  | ||||||
|                                      struct _cef_dictionary_value_t* manifest, |  | ||||||
|                                      struct _cef_extension_handler_t* handler); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns true (1) if this context was used to load the extension identified |  | ||||||
|   // by |extension_id|. Other contexts sharing the same storage will also have |  | ||||||
|   // access to the extension (see HasExtension). This function must be called on |  | ||||||
|   // the browser process UI thread. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* did_load_extension)(struct _cef_request_context_t* self, |  | ||||||
|                                         const cef_string_t* extension_id); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns true (1) if this context has access to the extension identified by |  | ||||||
|   // |extension_id|. This may not be the context that was used to load the |  | ||||||
|   // extension (see DidLoadExtension). This function must be called on the |  | ||||||
|   // browser process UI thread. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* has_extension)(struct _cef_request_context_t* self, |  | ||||||
|                                    const cef_string_t* extension_id); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Retrieve the list of all extensions that this context has access to (see |  | ||||||
|   // HasExtension). |extension_ids| will be populated with the list of extension |  | ||||||
|   // ID values. Returns true (1) on success. This function must be called on the |  | ||||||
|   // browser process UI thread. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* get_extensions)(struct _cef_request_context_t* self, |  | ||||||
|                                     cef_string_list_t extension_ids); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns the extension matching |extension_id| or NULL if no matching |  | ||||||
|   // extension is accessible in this context (see HasExtension). This function |  | ||||||
|   // must be called on the browser process UI thread. |  | ||||||
|   /// |  | ||||||
|   struct _cef_extension_t*(CEF_CALLBACK* get_extension)( |  | ||||||
|       struct _cef_request_context_t* self, |  | ||||||
|       const cef_string_t* extension_id); |  | ||||||
| } cef_request_context_t; | } cef_request_context_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Returns the global context object. | // Returns the global context object. | ||||||
| /// | /// | ||||||
| @@ -381,6 +283,7 @@ CEF_EXPORT cef_request_context_t* cef_create_context_shared( | |||||||
|     cef_request_context_t* other, |     cef_request_context_t* other, | ||||||
|     struct _cef_request_context_handler_t* handler); |     struct _cef_request_context_handler_t* handler); | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=52978f64fe2a612c05fc42a91ec53df6ff42079d$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_REQUEST_CONTEXT_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_REQUEST_CONTEXT_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_REQUEST_CONTEXT_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_REQUEST_CONTEXT_HANDLER_CAPI_H_ | ||||||
| @@ -48,7 +46,6 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
| struct _cef_request_context_t; |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Implement this structure to provide handler implementations. The handler | // Implement this structure to provide handler implementations. The handler | ||||||
| @@ -59,15 +56,7 @@ typedef struct _cef_request_context_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called on the browser process UI thread immediately after the request |  | ||||||
|   // context has been initialized. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* on_request_context_initialized)( |  | ||||||
|       struct _cef_request_context_handler_t* self, |  | ||||||
|       struct _cef_request_context_t* request_context); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called on the browser process IO thread to retrieve the cookie manager. If |   // Called on the browser process IO thread to retrieve the cookie manager. If | ||||||
| @@ -98,14 +87,13 @@ typedef struct _cef_request_context_handler_t { | |||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *on_before_plugin_load)( |   int (CEF_CALLBACK *on_before_plugin_load)( | ||||||
|       struct _cef_request_context_handler_t* self, |       struct _cef_request_context_handler_t* self, | ||||||
|       const cef_string_t* mime_type, |       const cef_string_t* mime_type, const cef_string_t* plugin_url, | ||||||
|       const cef_string_t* plugin_url, |       int is_main_frame, const cef_string_t* top_origin_url, | ||||||
|       int is_main_frame, |  | ||||||
|       const cef_string_t* top_origin_url, |  | ||||||
|       struct _cef_web_plugin_info_t* plugin_info, |       struct _cef_web_plugin_info_t* plugin_info, | ||||||
|       cef_plugin_policy_t* plugin_policy); |       cef_plugin_policy_t* plugin_policy); | ||||||
| } cef_request_context_handler_t; | } cef_request_context_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=95e44047a75693dbae0ab6b07b415d188252bfdf$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_REQUEST_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_REQUEST_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_REQUEST_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_REQUEST_HANDLER_CAPI_H_ | ||||||
| @@ -55,6 +53,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Callback structure used for asynchronous continuation of url requests. | // Callback structure used for asynchronous continuation of url requests. | ||||||
| /// | /// | ||||||
| @@ -62,7 +61,7 @@ typedef struct _cef_request_callback_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Continue the url request. If |allow| is true (1) the request will be |   // Continue the url request. If |allow| is true (1) the request will be | ||||||
| @@ -76,6 +75,7 @@ typedef struct _cef_request_callback_t { | |||||||
|   void (CEF_CALLBACK *cancel)(struct _cef_request_callback_t* self); |   void (CEF_CALLBACK *cancel)(struct _cef_request_callback_t* self); | ||||||
| } cef_request_callback_t; | } cef_request_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Callback structure used to select a client certificate for authentication. | // Callback structure used to select a client certificate for authentication. | ||||||
| /// | /// | ||||||
| @@ -83,7 +83,7 @@ typedef struct _cef_select_client_certificate_callback_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Chooses the specified certificate for client certificate authentication. |   // Chooses the specified certificate for client certificate authentication. | ||||||
| @@ -94,6 +94,7 @@ typedef struct _cef_select_client_certificate_callback_t { | |||||||
|       struct _cef_x509certificate_t* cert); |       struct _cef_x509certificate_t* cert); | ||||||
| } cef_select_client_certificate_callback_t; | } cef_select_client_certificate_callback_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Implement this structure to handle events related to browser requests. The | // Implement this structure to handle events related to browser requests. The | ||||||
| // functions of this structure will be called on the thread indicated. | // functions of this structure will be called on the thread indicated. | ||||||
| @@ -102,7 +103,7 @@ typedef struct _cef_request_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called on the UI thread before browser navigation. Return true (1) to |   // Called on the UI thread before browser navigation. Return true (1) to | ||||||
| @@ -112,16 +113,11 @@ typedef struct _cef_request_handler_t { | |||||||
|   // If the navigation is allowed cef_load_handler_t::OnLoadStart and |   // If the navigation is allowed cef_load_handler_t::OnLoadStart and | ||||||
|   // cef_load_handler_t::OnLoadEnd will be called. If the navigation is canceled |   // cef_load_handler_t::OnLoadEnd will be called. If the navigation is canceled | ||||||
|   // cef_load_handler_t::OnLoadError will be called with an |errorCode| value of |   // cef_load_handler_t::OnLoadError will be called with an |errorCode| value of | ||||||
|   // ERR_ABORTED. The |user_gesture| value will be true (1) if the browser |   // ERR_ABORTED. | ||||||
|   // navigated via explicit user gesture (e.g. clicking a link) or false (0) if |  | ||||||
|   // it navigated automatically (e.g. via the DomContentLoaded event). |  | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *on_before_browse)(struct _cef_request_handler_t* self, |   int (CEF_CALLBACK *on_before_browse)(struct _cef_request_handler_t* self, | ||||||
|                                       struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, struct _cef_frame_t* frame, | ||||||
|                                       struct _cef_frame_t* frame, |       struct _cef_request_t* request, int is_redirect); | ||||||
|                                       struct _cef_request_t* request, |  | ||||||
|                                       int user_gesture, |  | ||||||
|                                       int is_redirect); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called on the UI thread before OnBeforeBrowse in certain limited cases |   // Called on the UI thread before OnBeforeBrowse in certain limited cases | ||||||
| @@ -139,13 +135,10 @@ typedef struct _cef_request_handler_t { | |||||||
|   // true (1) to cancel the navigation or false (0) to allow the navigation to |   // true (1) to cancel the navigation or false (0) to allow the navigation to | ||||||
|   // proceed in the source browser's top-level frame. |   // proceed in the source browser's top-level frame. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* on_open_urlfrom_tab)( |   int (CEF_CALLBACK *on_open_urlfrom_tab)(struct _cef_request_handler_t* self, | ||||||
|       struct _cef_request_handler_t* self, |       struct _cef_browser_t* browser, struct _cef_frame_t* frame, | ||||||
|       struct _cef_browser_t* browser, |  | ||||||
|       struct _cef_frame_t* frame, |  | ||||||
|       const cef_string_t* target_url, |       const cef_string_t* target_url, | ||||||
|       cef_window_open_disposition_t target_disposition, |       cef_window_open_disposition_t target_disposition, int user_gesture); | ||||||
|       int user_gesture); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called on the IO thread before a resource request is loaded. The |request| |   // Called on the IO thread before a resource request is loaded. The |request| | ||||||
| @@ -156,10 +149,8 @@ typedef struct _cef_request_handler_t { | |||||||
|   // |   // | ||||||
|   /// |   /// | ||||||
|   cef_return_value_t (CEF_CALLBACK *on_before_resource_load)( |   cef_return_value_t (CEF_CALLBACK *on_before_resource_load)( | ||||||
|       struct _cef_request_handler_t* self, |       struct _cef_request_handler_t* self, struct _cef_browser_t* browser, | ||||||
|       struct _cef_browser_t* browser, |       struct _cef_frame_t* frame, struct _cef_request_t* request, | ||||||
|       struct _cef_frame_t* frame, |  | ||||||
|       struct _cef_request_t* request, |  | ||||||
|       struct _cef_request_callback_t* callback); |       struct _cef_request_callback_t* callback); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -169,10 +160,8 @@ typedef struct _cef_request_handler_t { | |||||||
|   // modified in this callback. |   // modified in this callback. | ||||||
|   /// |   /// | ||||||
|   struct _cef_resource_handler_t* (CEF_CALLBACK *get_resource_handler)( |   struct _cef_resource_handler_t* (CEF_CALLBACK *get_resource_handler)( | ||||||
|       struct _cef_request_handler_t* self, |       struct _cef_request_handler_t* self, struct _cef_browser_t* browser, | ||||||
|       struct _cef_browser_t* browser, |       struct _cef_frame_t* frame, struct _cef_request_t* request); | ||||||
|       struct _cef_frame_t* frame, |  | ||||||
|       struct _cef_request_t* request); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called on the IO thread when a resource load is redirected. The |request| |   // Called on the IO thread when a resource load is redirected. The |request| | ||||||
| @@ -183,10 +172,8 @@ typedef struct _cef_request_handler_t { | |||||||
|   // callback. |   // callback. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_resource_redirect)(struct _cef_request_handler_t* self, |   void (CEF_CALLBACK *on_resource_redirect)(struct _cef_request_handler_t* self, | ||||||
|                                            struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, struct _cef_frame_t* frame, | ||||||
|                                            struct _cef_frame_t* frame, |       struct _cef_request_t* request, struct _cef_response_t* response, | ||||||
|                                            struct _cef_request_t* request, |  | ||||||
|                                            struct _cef_response_t* response, |  | ||||||
|       cef_string_t* new_url); |       cef_string_t* new_url); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -196,10 +183,8 @@ typedef struct _cef_request_handler_t { | |||||||
|   // The |response| object cannot be modified in this callback. |   // The |response| object cannot be modified in this callback. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *on_resource_response)(struct _cef_request_handler_t* self, |   int (CEF_CALLBACK *on_resource_response)(struct _cef_request_handler_t* self, | ||||||
|                                           struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, struct _cef_frame_t* frame, | ||||||
|                                           struct _cef_frame_t* frame, |       struct _cef_request_t* request, struct _cef_response_t* response); | ||||||
|                                           struct _cef_request_t* request, |  | ||||||
|                                           struct _cef_response_t* response); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called on the IO thread to optionally filter resource response content. |   // Called on the IO thread to optionally filter resource response content. | ||||||
| @@ -207,10 +192,8 @@ typedef struct _cef_request_handler_t { | |||||||
|   // and cannot be modified in this callback. |   // and cannot be modified in this callback. | ||||||
|   /// |   /// | ||||||
|   struct _cef_response_filter_t* (CEF_CALLBACK *get_resource_response_filter)( |   struct _cef_response_filter_t* (CEF_CALLBACK *get_resource_response_filter)( | ||||||
|       struct _cef_request_handler_t* self, |       struct _cef_request_handler_t* self, struct _cef_browser_t* browser, | ||||||
|       struct _cef_browser_t* browser, |       struct _cef_frame_t* frame, struct _cef_request_t* request, | ||||||
|       struct _cef_frame_t* frame, |  | ||||||
|       struct _cef_request_t* request, |  | ||||||
|       struct _cef_response_t* response); |       struct _cef_response_t* response); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -220,12 +203,9 @@ typedef struct _cef_request_handler_t { | |||||||
|   // |received_content_length| is the number of response bytes actually read. |   // |received_content_length| is the number of response bytes actually read. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_resource_load_complete)( |   void (CEF_CALLBACK *on_resource_load_complete)( | ||||||
|       struct _cef_request_handler_t* self, |       struct _cef_request_handler_t* self, struct _cef_browser_t* browser, | ||||||
|       struct _cef_browser_t* browser, |       struct _cef_frame_t* frame, struct _cef_request_t* request, | ||||||
|       struct _cef_frame_t* frame, |       struct _cef_response_t* response, cef_urlrequest_status_t status, | ||||||
|       struct _cef_request_t* request, |  | ||||||
|       struct _cef_response_t* response, |  | ||||||
|       cef_urlrequest_status_t status, |  | ||||||
|       int64 received_content_length); |       int64 received_content_length); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -239,39 +219,10 @@ typedef struct _cef_request_handler_t { | |||||||
|   // the authentication information is available. Return false (0) to cancel the |   // the authentication information is available. Return false (0) to cancel the | ||||||
|   // request immediately. |   // request immediately. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* get_auth_credentials)( |   int (CEF_CALLBACK *get_auth_credentials)(struct _cef_request_handler_t* self, | ||||||
|       struct _cef_request_handler_t* self, |       struct _cef_browser_t* browser, struct _cef_frame_t* frame, int isProxy, | ||||||
|       struct _cef_browser_t* browser, |       const cef_string_t* host, int port, const cef_string_t* realm, | ||||||
|       struct _cef_frame_t* frame, |       const cef_string_t* scheme, struct _cef_auth_callback_t* callback); | ||||||
|       int isProxy, |  | ||||||
|       const cef_string_t* host, |  | ||||||
|       int port, |  | ||||||
|       const cef_string_t* realm, |  | ||||||
|       const cef_string_t* scheme, |  | ||||||
|       struct _cef_auth_callback_t* callback); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called on the IO thread before sending a network request with a "Cookie" |  | ||||||
|   // request header. Return true (1) to allow cookies to be included in the |  | ||||||
|   // network request or false (0) to block cookies. The |request| object should |  | ||||||
|   // not be modified in this callback. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* can_get_cookies)(struct _cef_request_handler_t* self, |  | ||||||
|                                      struct _cef_browser_t* browser, |  | ||||||
|                                      struct _cef_frame_t* frame, |  | ||||||
|                                      struct _cef_request_t* request); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called on the IO thread when receiving a network request with a "Set- |  | ||||||
|   // Cookie" response header value represented by |cookie|. Return true (1) to |  | ||||||
|   // allow the cookie to be stored or false (0) to block the cookie. The |  | ||||||
|   // |request| object should not be modified in this callback. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* can_set_cookie)(struct _cef_request_handler_t* self, |  | ||||||
|                                     struct _cef_browser_t* browser, |  | ||||||
|                                     struct _cef_frame_t* frame, |  | ||||||
|                                     struct _cef_request_t* request, |  | ||||||
|                                     const struct _cef_cookie_t* cookie); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called on the IO thread when JavaScript requests a specific storage quota |   // Called on the IO thread when JavaScript requests a specific storage quota | ||||||
| @@ -283,10 +234,8 @@ typedef struct _cef_request_handler_t { | |||||||
|   // immediately. |   // immediately. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *on_quota_request)(struct _cef_request_handler_t* self, |   int (CEF_CALLBACK *on_quota_request)(struct _cef_request_handler_t* self, | ||||||
|                                       struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, const cef_string_t* origin_url, | ||||||
|                                       const cef_string_t* origin_url, |       int64 new_size, struct _cef_request_callback_t* callback); | ||||||
|                                       int64 new_size, |  | ||||||
|                                       struct _cef_request_callback_t* callback); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called on the UI thread to handle requests for URLs with an unknown |   // Called on the UI thread to handle requests for URLs with an unknown | ||||||
| @@ -295,10 +244,9 @@ typedef struct _cef_request_handler_t { | |||||||
|   // YOU SHOULD USE THIS METHOD TO ENFORCE RESTRICTIONS BASED ON SCHEME, HOST OR |   // YOU SHOULD USE THIS METHOD TO ENFORCE RESTRICTIONS BASED ON SCHEME, HOST OR | ||||||
|   // OTHER URL ANALYSIS BEFORE ALLOWING OS EXECUTION. |   // OTHER URL ANALYSIS BEFORE ALLOWING OS EXECUTION. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* on_protocol_execution)(struct _cef_request_handler_t* self, |   void (CEF_CALLBACK *on_protocol_execution)( | ||||||
|                                             struct _cef_browser_t* browser, |       struct _cef_request_handler_t* self, struct _cef_browser_t* browser, | ||||||
|                                             const cef_string_t* url, |       const cef_string_t* url, int* allow_os_execution); | ||||||
|                                             int* allow_os_execution); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called on the UI thread to handle requests for URLs with an invalid SSL |   // Called on the UI thread to handle requests for URLs with an invalid SSL | ||||||
| @@ -308,12 +256,9 @@ typedef struct _cef_request_handler_t { | |||||||
|   // CefSettings.ignore_certificate_errors is set all invalid certificates will |   // CefSettings.ignore_certificate_errors is set all invalid certificates will | ||||||
|   // be accepted without calling this function. |   // be accepted without calling this function. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* on_certificate_error)( |   int (CEF_CALLBACK *on_certificate_error)(struct _cef_request_handler_t* self, | ||||||
|       struct _cef_request_handler_t* self, |       struct _cef_browser_t* browser, cef_errorcode_t cert_error, | ||||||
|       struct _cef_browser_t* browser, |       const cef_string_t* request_url, struct _cef_sslinfo_t* ssl_info, | ||||||
|       cef_errorcode_t cert_error, |  | ||||||
|       const cef_string_t* request_url, |  | ||||||
|       struct _cef_sslinfo_t* ssl_info, |  | ||||||
|       struct _cef_request_callback_t* callback); |       struct _cef_request_callback_t* callback); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -330,11 +275,8 @@ typedef struct _cef_request_handler_t { | |||||||
|   // the server trusts. |   // the server trusts. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *on_select_client_certificate)( |   int (CEF_CALLBACK *on_select_client_certificate)( | ||||||
|       struct _cef_request_handler_t* self, |       struct _cef_request_handler_t* self, struct _cef_browser_t* browser, | ||||||
|       struct _cef_browser_t* browser, |       int isProxy, const cef_string_t* host, int port, | ||||||
|       int isProxy, |  | ||||||
|       const cef_string_t* host, |  | ||||||
|       int port, |  | ||||||
|       size_t certificatesCount, |       size_t certificatesCount, | ||||||
|       struct _cef_x509certificate_t* const* certificates, |       struct _cef_x509certificate_t* const* certificates, | ||||||
|       struct _cef_select_client_certificate_callback_t* callback); |       struct _cef_select_client_certificate_callback_t* callback); | ||||||
| @@ -344,8 +286,7 @@ typedef struct _cef_request_handler_t { | |||||||
|   // |plugin_path| is the path of the plugin that crashed. |   // |plugin_path| is the path of the plugin that crashed. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_plugin_crashed)(struct _cef_request_handler_t* self, |   void (CEF_CALLBACK *on_plugin_crashed)(struct _cef_request_handler_t* self, | ||||||
|                                         struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, const cef_string_t* plugin_path); | ||||||
|                                         const cef_string_t* plugin_path); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called on the browser process UI thread when the render view associated |   // Called on the browser process UI thread when the render view associated | ||||||
| @@ -360,11 +301,11 @@ typedef struct _cef_request_handler_t { | |||||||
|   // unexpectedly. |status| indicates how the process terminated. |   // unexpectedly. |status| indicates how the process terminated. | ||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *on_render_process_terminated)( |   void (CEF_CALLBACK *on_render_process_terminated)( | ||||||
|       struct _cef_request_handler_t* self, |       struct _cef_request_handler_t* self, struct _cef_browser_t* browser, | ||||||
|       struct _cef_browser_t* browser, |  | ||||||
|       cef_termination_status_t status); |       cef_termination_status_t status); | ||||||
| } cef_request_handler_t; | } cef_request_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=439cc7c4ac7f2178ab0b445ab91df66b6759335f$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_RESOURCE_BUNDLE_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_RESOURCE_BUNDLE_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_RESOURCE_BUNDLE_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_RESOURCE_BUNDLE_CAPI_H_ | ||||||
| @@ -46,6 +44,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used for retrieving resources from the resource bundle (*.pak) | // Structure used for retrieving resources from the resource bundle (*.pak) | ||||||
| // files loaded by CEF during startup or via the cef_resource_bundle_tHandler | // files loaded by CEF during startup or via the cef_resource_bundle_tHandler | ||||||
| @@ -57,7 +56,7 @@ typedef struct _cef_resource_bundle_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the localized string for the specified |string_id| or an NULL |   // Returns the localized string for the specified |string_id| or an NULL | ||||||
| @@ -66,8 +65,7 @@ typedef struct _cef_resource_bundle_t { | |||||||
|   /// |   /// | ||||||
|   // The resulting string must be freed by calling cef_string_userfree_free(). |   // The resulting string must be freed by calling cef_string_userfree_free(). | ||||||
|   cef_string_userfree_t (CEF_CALLBACK *get_localized_string)( |   cef_string_userfree_t (CEF_CALLBACK *get_localized_string)( | ||||||
|       struct _cef_resource_bundle_t* self, |       struct _cef_resource_bundle_t* self, int string_id); | ||||||
|       int string_id); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Retrieves the contents of the specified scale independent |resource_id|. If |   // Retrieves the contents of the specified scale independent |resource_id|. If | ||||||
| @@ -78,9 +76,7 @@ typedef struct _cef_resource_bundle_t { | |||||||
|   // of valid resource ID values. |   // of valid resource ID values. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *get_data_resource)(struct _cef_resource_bundle_t* self, |   int (CEF_CALLBACK *get_data_resource)(struct _cef_resource_bundle_t* self, | ||||||
|                                        int resource_id, |       int resource_id, void** data, size_t* data_size); | ||||||
|                                        void** data, |  | ||||||
|                                        size_t* data_size); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Retrieves the contents of the specified |resource_id| nearest the scale |   // Retrieves the contents of the specified |resource_id| nearest the scale | ||||||
| @@ -93,18 +89,17 @@ typedef struct _cef_resource_bundle_t { | |||||||
|   // of valid resource ID values. |   // of valid resource ID values. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *get_data_resource_for_scale)( |   int (CEF_CALLBACK *get_data_resource_for_scale)( | ||||||
|       struct _cef_resource_bundle_t* self, |       struct _cef_resource_bundle_t* self, int resource_id, | ||||||
|       int resource_id, |       cef_scale_factor_t scale_factor, void** data, size_t* data_size); | ||||||
|       cef_scale_factor_t scale_factor, |  | ||||||
|       void** data, |  | ||||||
|       size_t* data_size); |  | ||||||
| } cef_resource_bundle_t; | } cef_resource_bundle_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Returns the global resource bundle instance. | // Returns the global resource bundle instance. | ||||||
| /// | /// | ||||||
| CEF_EXPORT cef_resource_bundle_t* cef_resource_bundle_get_global(); | CEF_EXPORT cef_resource_bundle_t* cef_resource_bundle_get_global(); | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=ce250b3a07931595bbf0028fb56c11b6160f836e$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_RESOURCE_BUNDLE_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_RESOURCE_BUNDLE_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_RESOURCE_BUNDLE_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_RESOURCE_BUNDLE_HANDLER_CAPI_H_ | ||||||
| @@ -46,6 +44,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used to implement a custom resource bundle structure. See | // Structure used to implement a custom resource bundle structure. See | ||||||
| // CefSettings for additional options related to resource bundle loading. The | // CefSettings for additional options related to resource bundle loading. The | ||||||
| @@ -55,7 +54,7 @@ typedef struct _cef_resource_bundle_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called to retrieve a localized translation for the specified |string_id|. |   // Called to retrieve a localized translation for the specified |string_id|. | ||||||
| @@ -64,8 +63,7 @@ typedef struct _cef_resource_bundle_handler_t { | |||||||
|   // cef_pack_strings.h for a listing of valid string ID values. |   // cef_pack_strings.h for a listing of valid string ID values. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *get_localized_string)( |   int (CEF_CALLBACK *get_localized_string)( | ||||||
|       struct _cef_resource_bundle_handler_t* self, |       struct _cef_resource_bundle_handler_t* self, int string_id, | ||||||
|       int string_id, |  | ||||||
|       cef_string_t* string); |       cef_string_t* string); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -77,9 +75,7 @@ typedef struct _cef_resource_bundle_handler_t { | |||||||
|   // resource ID values. |   // resource ID values. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *get_data_resource)( |   int (CEF_CALLBACK *get_data_resource)( | ||||||
|       struct _cef_resource_bundle_handler_t* self, |       struct _cef_resource_bundle_handler_t* self, int resource_id, void** data, | ||||||
|       int resource_id, |  | ||||||
|       void** data, |  | ||||||
|       size_t* data_size); |       size_t* data_size); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -91,13 +87,11 @@ typedef struct _cef_resource_bundle_handler_t { | |||||||
|   // cef_pack_resources.h for a listing of valid resource ID values. |   // cef_pack_resources.h for a listing of valid resource ID values. | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *get_data_resource_for_scale)( |   int (CEF_CALLBACK *get_data_resource_for_scale)( | ||||||
|       struct _cef_resource_bundle_handler_t* self, |       struct _cef_resource_bundle_handler_t* self, int resource_id, | ||||||
|       int resource_id, |       cef_scale_factor_t scale_factor, void** data, size_t* data_size); | ||||||
|       cef_scale_factor_t scale_factor, |  | ||||||
|       void** data, |  | ||||||
|       size_t* data_size); |  | ||||||
| } cef_resource_bundle_handler_t; | } cef_resource_bundle_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=64a8d248c8c6c5b17a8ce1bdf79b82e791d87a1a$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_RESOURCE_HANDLER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_RESOURCE_HANDLER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_RESOURCE_HANDLER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_RESOURCE_HANDLER_CAPI_H_ | ||||||
| @@ -51,6 +49,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used to implement a custom request handler structure. The functions | // Structure used to implement a custom request handler structure. The functions | ||||||
| // of this structure will always be called on the IO thread. | // of this structure will always be called on the IO thread. | ||||||
| @@ -59,7 +58,7 @@ typedef struct _cef_resource_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Begin processing the request. To handle the request return true (1) and |   // Begin processing the request. To handle the request return true (1) and | ||||||
| @@ -69,8 +68,7 @@ typedef struct _cef_resource_handler_t { | |||||||
|   // request return false (0). |   // request return false (0). | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *process_request)(struct _cef_resource_handler_t* self, |   int (CEF_CALLBACK *process_request)(struct _cef_resource_handler_t* self, | ||||||
|                                      struct _cef_request_t* request, |       struct _cef_request_t* request, struct _cef_callback_t* callback); | ||||||
|                                      struct _cef_callback_t* callback); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Retrieve response header information. If the response length is not known |   // Retrieve response header information. If the response length is not known | ||||||
| @@ -83,10 +81,9 @@ typedef struct _cef_resource_handler_t { | |||||||
|   // URL. If an error occured while setting up the request you can call |   // URL. If an error occured while setting up the request you can call | ||||||
|   // set_error() on |response| to indicate the error condition. |   // set_error() on |response| to indicate the error condition. | ||||||
|   /// |   /// | ||||||
|   void(CEF_CALLBACK* get_response_headers)(struct _cef_resource_handler_t* self, |   void (CEF_CALLBACK *get_response_headers)( | ||||||
|                                            struct _cef_response_t* response, |       struct _cef_resource_handler_t* self, struct _cef_response_t* response, | ||||||
|                                            int64* response_length, |       int64* response_length, cef_string_t* redirectUrl); | ||||||
|                                            cef_string_t* redirectUrl); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Read response data. If data is available immediately copy up to |   // Read response data. If data is available immediately copy up to | ||||||
| @@ -96,9 +93,7 @@ typedef struct _cef_resource_handler_t { | |||||||
|   // data is available. To indicate response completion return false (0). |   // data is available. To indicate response completion return false (0). | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *read_response)(struct _cef_resource_handler_t* self, |   int (CEF_CALLBACK *read_response)(struct _cef_resource_handler_t* self, | ||||||
|                                    void* data_out, |       void* data_out, int bytes_to_read, int* bytes_read, | ||||||
|                                    int bytes_to_read, |  | ||||||
|                                    int* bytes_read, |  | ||||||
|       struct _cef_callback_t* callback); |       struct _cef_callback_t* callback); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -122,6 +117,7 @@ typedef struct _cef_resource_handler_t { | |||||||
|   void (CEF_CALLBACK *cancel)(struct _cef_resource_handler_t* self); |   void (CEF_CALLBACK *cancel)(struct _cef_resource_handler_t* self); | ||||||
| } cef_resource_handler_t; | } cef_resource_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=fd2cbc427bccf30298e26dd6c3bcef9551433f8b$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_RESPONSE_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_RESPONSE_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_RESPONSE_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_RESPONSE_CAPI_H_ | ||||||
| @@ -46,6 +44,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used to represent a web response. The functions of this structure | // Structure used to represent a web response. The functions of this structure | ||||||
| // may be called on any thread. | // may be called on any thread. | ||||||
| @@ -54,7 +53,7 @@ typedef struct _cef_response_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if this object is read-only. |   // Returns true (1) if this object is read-only. | ||||||
| @@ -127,25 +126,15 @@ typedef struct _cef_response_t { | |||||||
|   /// |   /// | ||||||
|   void (CEF_CALLBACK *set_header_map)(struct _cef_response_t* self, |   void (CEF_CALLBACK *set_header_map)(struct _cef_response_t* self, | ||||||
|       cef_string_multimap_t headerMap); |       cef_string_multimap_t headerMap); | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Get the resolved URL after redirects or changed as a result of HSTS. |  | ||||||
|   /// |  | ||||||
|   // The resulting string must be freed by calling cef_string_userfree_free(). |  | ||||||
|   cef_string_userfree_t(CEF_CALLBACK* get_url)(struct _cef_response_t* self); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Set the resolved URL after redirects or changed as a result of HSTS. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* set_url)(struct _cef_response_t* self, |  | ||||||
|                               const cef_string_t* url); |  | ||||||
| } cef_response_t; | } cef_response_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Create a new cef_response_t object. | // Create a new cef_response_t object. | ||||||
| /// | /// | ||||||
| CEF_EXPORT cef_response_t* cef_response_create(); | CEF_EXPORT cef_response_t* cef_response_create(); | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=a0599caa7b458266ace091657d7024453d7ce37a$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_RESPONSE_FILTER_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_RESPONSE_FILTER_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_RESPONSE_FILTER_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_RESPONSE_FILTER_CAPI_H_ | ||||||
| @@ -46,6 +44,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Implement this structure to filter resource response content. The functions | // Implement this structure to filter resource response content. The functions | ||||||
| // of this structure will be called on the browser process IO thread. | // of this structure will be called on the browser process IO thread. | ||||||
| @@ -54,7 +53,7 @@ typedef struct _cef_response_filter_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Initialize the response filter. Will only be called a single time. The |   // Initialize the response filter. Will only be called a single time. The | ||||||
| @@ -63,46 +62,30 @@ typedef struct _cef_response_filter_t { | |||||||
|   int (CEF_CALLBACK *init_filter)(struct _cef_response_filter_t* self); |   int (CEF_CALLBACK *init_filter)(struct _cef_response_filter_t* self); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Called to filter a chunk of data. Expected usage is as follows: |   // Called to filter a chunk of data. |data_in| is the input buffer containing | ||||||
|   // |   // |data_in_size| bytes of pre-filter data (|data_in| will be NULL if | ||||||
|   //  A. Read input data from |data_in| and set |data_in_read| to the number of |   // |data_in_size| is zero). |data_out| is the output buffer that can accept up | ||||||
|   //     bytes that were read up to a maximum of |data_in_size|. |data_in| will |   // to |data_out_size| bytes of filtered output data. Set |data_in_read| to the | ||||||
|   //     be NULL if |data_in_size| is zero. |   // number of bytes that were read from |data_in|. Set |data_out_written| to | ||||||
|   //  B. Write filtered output data to |data_out| and set |data_out_written| to |   // the number of bytes that were written into |data_out|. If some or all of | ||||||
|   //     the number of bytes that were written up to a maximum of |   // the pre-filter data was read successfully but more data is needed in order | ||||||
|   //     |data_out_size|. If no output data was written then all data must be |   // to continue filtering (filtered output is pending) return | ||||||
|   //     read from |data_in| (user must set |data_in_read| = |data_in_size|). |   // RESPONSE_FILTER_NEED_MORE_DATA. If some or all of the pre-filter data was | ||||||
|   //  C. Return RESPONSE_FILTER_DONE if all output data was written or |   // read successfully and all available filtered output has been written return | ||||||
|   //     RESPONSE_FILTER_NEED_MORE_DATA if output data is still pending. |   // RESPONSE_FILTER_DONE. If an error occurs during filtering return | ||||||
|   // |   // RESPONSE_FILTER_ERROR. This function will be called repeatedly until there | ||||||
|   // This function will be called repeatedly until the input buffer has been |   // is no more data to filter (resource response is complete), |data_in_read| | ||||||
|   // fully read (user sets |data_in_read| = |data_in_size|) and there is no more |   // matches |data_in_size| (all available pre-filter bytes have been read), and | ||||||
|   // input data to filter (the resource response is complete). This function may |   // the function returns RESPONSE_FILTER_DONE or RESPONSE_FILTER_ERROR. Do not | ||||||
|   // then be called an additional time with an NULL input buffer if the user |   // keep a reference to the buffers passed to this function. | ||||||
|   // filled the output buffer (set |data_out_written| = |data_out_size|) and |  | ||||||
|   // returned RESPONSE_FILTER_NEED_MORE_DATA to indicate that output data is |  | ||||||
|   // still pending. |  | ||||||
|   // |  | ||||||
|   // Calls to this function will stop when one of the following conditions is |  | ||||||
|   // met: |  | ||||||
|   // |  | ||||||
|   //  A. There is no more input data to filter (the resource response is |  | ||||||
|   //     complete) and the user sets |data_out_written| = 0 or returns |  | ||||||
|   //     RESPONSE_FILTER_DONE to indicate that all data has been written, or; |  | ||||||
|   //  B. The user returns RESPONSE_FILTER_ERROR to indicate an error. |  | ||||||
|   // |  | ||||||
|   // Do not keep a reference to the buffers passed to this function. |  | ||||||
|   /// |   /// | ||||||
|   cef_response_filter_status_t (CEF_CALLBACK *filter)( |   cef_response_filter_status_t (CEF_CALLBACK *filter)( | ||||||
|       struct _cef_response_filter_t* self, |       struct _cef_response_filter_t* self, void* data_in, size_t data_in_size, | ||||||
|       void* data_in, |       size_t* data_in_read, void* data_out, size_t data_out_size, | ||||||
|       size_t data_in_size, |  | ||||||
|       size_t* data_in_read, |  | ||||||
|       void* data_out, |  | ||||||
|       size_t data_out_size, |  | ||||||
|       size_t* data_out_written); |       size_t* data_out_written); | ||||||
| } cef_response_filter_t; | } cef_response_filter_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=57a50b4c4bee68267ffcf7efebfbe711b62b0f84$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_SCHEME_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_SCHEME_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_SCHEME_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_SCHEME_CAPI_H_ | ||||||
| @@ -60,7 +58,7 @@ typedef struct _cef_scheme_registrar_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_scoped_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Register a custom scheme. This function should not be called for the built- |   // Register a custom scheme. This function should not be called for the built- | ||||||
| @@ -89,48 +87,31 @@ typedef struct _cef_scheme_registrar_t { | |||||||
|   // is. For example, "scheme:///some%20text" will remain the same. Non-standard |   // is. For example, "scheme:///some%20text" will remain the same. Non-standard | ||||||
|   // scheme URLs cannot be used as a target for form submission. |   // scheme URLs cannot be used as a target for form submission. | ||||||
|   // |   // | ||||||
|   // If |is_local| is true (1) the scheme will be treated with the same security |   // If |is_local| is true (1) the scheme will be treated as local (i.e., with | ||||||
|   // rules as those applied to "file" URLs. Normal pages cannot link to or |   // the same security rules as those applied to "file" URLs). Normal pages | ||||||
|   // access local URLs. Also, by default, local URLs can only perform |   // cannot link to or access local URLs. Also, by default, local URLs can only | ||||||
|   // XMLHttpRequest calls to the same URL (origin + path) that originated the |   // perform XMLHttpRequest calls to the same URL (origin + path) that | ||||||
|   // request. To allow XMLHttpRequest calls from a local URL to other URLs with |   // originated the request. To allow XMLHttpRequest calls from a local URL to | ||||||
|   // the same origin set the CefSettings.file_access_from_file_urls_allowed |   // other URLs with the same origin set the | ||||||
|   // value to true (1). To allow XMLHttpRequest calls from a local URL to all |   // CefSettings.file_access_from_file_urls_allowed value to true (1). To allow | ||||||
|   // origins set the CefSettings.universal_access_from_file_urls_allowed value |   // XMLHttpRequest calls from a local URL to all origins set the | ||||||
|   // to true (1). |   // CefSettings.universal_access_from_file_urls_allowed value to true (1). | ||||||
|   // |   // | ||||||
|   // If |is_display_isolated| is true (1) the scheme can only be displayed from |   // If |is_display_isolated| is true (1) the scheme will be treated as display- | ||||||
|   // other content hosted with the same scheme. For example, pages in other |   // isolated. This means that pages cannot display these URLs unless they are | ||||||
|   // origins cannot create iframes or hyperlinks to URLs with the scheme. For |   // from the same scheme. For example, pages in another origin cannot create | ||||||
|   // schemes that must be accessible from other schemes set this value to false |   // iframes or hyperlinks to URLs with this scheme. | ||||||
|   // (0), set |is_cors_enabled| to true (1), and use CORS "Access-Control-Allow- |  | ||||||
|   // Origin" headers to further restrict access. |  | ||||||
|   // |  | ||||||
|   // If |is_secure| is true (1) the scheme will be treated with the same |  | ||||||
|   // security rules as those applied to "https" URLs. For example, loading this |  | ||||||
|   // scheme from other secure schemes will not trigger mixed content warnings. |  | ||||||
|   // |  | ||||||
|   // If |is_cors_enabled| is true (1) the scheme can be sent CORS requests. This |  | ||||||
|   // value should be true (1) in most cases where |is_standard| is true (1). |  | ||||||
|   // |  | ||||||
|   // If |is_csp_bypassing| is true (1) the scheme can bypass Content-Security- |  | ||||||
|   // Policy (CSP) checks. This value should be false (0) in most cases where |  | ||||||
|   // |is_standard| is true (1). |  | ||||||
|   // |   // | ||||||
|   // This function may be called on any thread. It should only be called once |   // This function may be called on any thread. It should only be called once | ||||||
|   // per unique |scheme_name| value. If |scheme_name| is already registered or |   // per unique |scheme_name| value. If |scheme_name| is already registered or | ||||||
|   // if an error occurs this function will return false (0). |   // if an error occurs this function will return false (0). | ||||||
|   /// |   /// | ||||||
|   int (CEF_CALLBACK *add_custom_scheme)(struct _cef_scheme_registrar_t* self, |   int (CEF_CALLBACK *add_custom_scheme)(struct _cef_scheme_registrar_t* self, | ||||||
|                                        const cef_string_t* scheme_name, |       const cef_string_t* scheme_name, int is_standard, int is_local, | ||||||
|                                        int is_standard, |       int is_display_isolated); | ||||||
|                                        int is_local, |  | ||||||
|                                        int is_display_isolated, |  | ||||||
|                                        int is_secure, |  | ||||||
|                                        int is_cors_enabled, |  | ||||||
|                                        int is_csp_bypassing); |  | ||||||
| } cef_scheme_registrar_t; | } cef_scheme_registrar_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure that creates cef_resource_handler_t instances for handling scheme | // Structure that creates cef_resource_handler_t instances for handling scheme | ||||||
| // requests. The functions of this structure will always be called on the IO | // requests. The functions of this structure will always be called on the IO | ||||||
| @@ -140,7 +121,7 @@ typedef struct _cef_scheme_handler_factory_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Return a new resource handler instance to handle the request or an NULL |   // Return a new resource handler instance to handle the request or an NULL | ||||||
| @@ -152,12 +133,11 @@ typedef struct _cef_scheme_handler_factory_t { | |||||||
|   /// |   /// | ||||||
|   struct _cef_resource_handler_t* (CEF_CALLBACK *create)( |   struct _cef_resource_handler_t* (CEF_CALLBACK *create)( | ||||||
|       struct _cef_scheme_handler_factory_t* self, |       struct _cef_scheme_handler_factory_t* self, | ||||||
|       struct _cef_browser_t* browser, |       struct _cef_browser_t* browser, struct _cef_frame_t* frame, | ||||||
|       struct _cef_frame_t* frame, |       const cef_string_t* scheme_name, struct _cef_request_t* request); | ||||||
|       const cef_string_t* scheme_name, |  | ||||||
|       struct _cef_request_t* request); |  | ||||||
| } cef_scheme_handler_factory_t; | } cef_scheme_handler_factory_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Register a scheme handler factory with the global request context. An NULL | // Register a scheme handler factory with the global request context. An NULL | ||||||
| // |domain_name| value for a standard scheme will cause the factory to match all | // |domain_name| value for a standard scheme will cause the factory to match all | ||||||
| @@ -174,8 +154,7 @@ typedef struct _cef_scheme_handler_factory_t { | |||||||
| // ory(). | // ory(). | ||||||
| /// | /// | ||||||
| CEF_EXPORT int cef_register_scheme_handler_factory( | CEF_EXPORT int cef_register_scheme_handler_factory( | ||||||
|     const cef_string_t* scheme_name, |     const cef_string_t* scheme_name, const cef_string_t* domain_name, | ||||||
|     const cef_string_t* domain_name, |  | ||||||
|     cef_scheme_handler_factory_t* factory); |     cef_scheme_handler_factory_t* factory); | ||||||
|  |  | ||||||
| /// | /// | ||||||
|   | |||||||
| @@ -1,327 +0,0 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. |  | ||||||
| // |  | ||||||
| // Redistribution and use in source and binary forms, with or without |  | ||||||
| // modification, are permitted provided that the following conditions are |  | ||||||
| // met: |  | ||||||
| // |  | ||||||
| //    * Redistributions of source code must retain the above copyright |  | ||||||
| // notice, this list of conditions and the following disclaimer. |  | ||||||
| //    * Redistributions in binary form must reproduce the above |  | ||||||
| // copyright notice, this list of conditions and the following disclaimer |  | ||||||
| // in the documentation and/or other materials provided with the |  | ||||||
| // distribution. |  | ||||||
| //    * Neither the name of Google Inc. nor the name Chromium Embedded |  | ||||||
| // Framework nor the names of its contributors may be used to endorse |  | ||||||
| // or promote products derived from this software without specific prior |  | ||||||
| // written permission. |  | ||||||
| // |  | ||||||
| // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS |  | ||||||
| // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT |  | ||||||
| // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR |  | ||||||
| // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT |  | ||||||
| // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, |  | ||||||
| // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT |  | ||||||
| // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, |  | ||||||
| // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY |  | ||||||
| // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |  | ||||||
| // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |  | ||||||
| // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |  | ||||||
| // |  | ||||||
| // --------------------------------------------------------------------------- |  | ||||||
| // |  | ||||||
| // This file was generated by the CEF translator tool and should not edited |  | ||||||
| // by hand. See the translator.README.txt file in the tools directory for |  | ||||||
| // more information. |  | ||||||
| // |  | ||||||
| // $hash=0653420628236b2bc16541d65b75742aba4e4613$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_SERVER_CAPI_H_ |  | ||||||
| #define CEF_INCLUDE_CAPI_CEF_SERVER_CAPI_H_ |  | ||||||
| #pragma once |  | ||||||
|  |  | ||||||
| #include "include/capi/cef_base_capi.h" |  | ||||||
| #include "include/capi/cef_callback_capi.h" |  | ||||||
| #include "include/capi/cef_request_capi.h" |  | ||||||
| #include "include/capi/cef_task_capi.h" |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus |  | ||||||
| extern "C" { |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| struct _cef_server_handler_t; |  | ||||||
|  |  | ||||||
| /// |  | ||||||
| // Structure representing a server that supports HTTP and WebSocket requests. |  | ||||||
| // Server capacity is limited and is intended to handle only a small number of |  | ||||||
| // simultaneous connections (e.g. for communicating between applications on |  | ||||||
| // localhost). The functions of this structure are safe to call from any thread |  | ||||||
| // in the brower process unless otherwise indicated. |  | ||||||
| /// |  | ||||||
| typedef struct _cef_server_t { |  | ||||||
|   /// |  | ||||||
|   // Base structure. |  | ||||||
|   /// |  | ||||||
|   cef_base_ref_counted_t base; |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns the task runner for the dedicated server thread. |  | ||||||
|   /// |  | ||||||
|   struct _cef_task_runner_t*(CEF_CALLBACK* get_task_runner)( |  | ||||||
|       struct _cef_server_t* self); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Stop the server and shut down the dedicated server thread. See |  | ||||||
|   // cef_server_handler_t::OnServerCreated documentation for a description of |  | ||||||
|   // server lifespan. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* shutdown)(struct _cef_server_t* self); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns true (1) if the server is currently running and accepting incoming |  | ||||||
|   // connections. See cef_server_handler_t::OnServerCreated documentation for a |  | ||||||
|   // description of server lifespan. This function must be called on the |  | ||||||
|   // dedicated server thread. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* is_running)(struct _cef_server_t* self); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns the server address including the port number. |  | ||||||
|   /// |  | ||||||
|   // The resulting string must be freed by calling cef_string_userfree_free(). |  | ||||||
|   cef_string_userfree_t(CEF_CALLBACK* get_address)(struct _cef_server_t* self); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns true (1) if the server currently has a connection. This function |  | ||||||
|   // must be called on the dedicated server thread. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* has_connection)(struct _cef_server_t* self); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Returns true (1) if |connection_id| represents a valid connection. This |  | ||||||
|   // function must be called on the dedicated server thread. |  | ||||||
|   /// |  | ||||||
|   int(CEF_CALLBACK* is_valid_connection)(struct _cef_server_t* self, |  | ||||||
|                                          int connection_id); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Send an HTTP 200 "OK" response to the connection identified by |  | ||||||
|   // |connection_id|. |content_type| is the response content type (e.g. |  | ||||||
|   // "text/html"), |data| is the response content, and |data_size| is the size |  | ||||||
|   // of |data| in bytes. The contents of |data| will be copied. The connection |  | ||||||
|   // will be closed automatically after the response is sent. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* send_http200response)(struct _cef_server_t* self, |  | ||||||
|                                            int connection_id, |  | ||||||
|                                            const cef_string_t* content_type, |  | ||||||
|                                            const void* data, |  | ||||||
|                                            size_t data_size); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Send an HTTP 404 "Not Found" response to the connection identified by |  | ||||||
|   // |connection_id|. The connection will be closed automatically after the |  | ||||||
|   // response is sent. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* send_http404response)(struct _cef_server_t* self, |  | ||||||
|                                            int connection_id); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Send an HTTP 500 "Internal Server Error" response to the connection |  | ||||||
|   // identified by |connection_id|. |error_message| is the associated error |  | ||||||
|   // message. The connection will be closed automatically after the response is |  | ||||||
|   // sent. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* send_http500response)(struct _cef_server_t* self, |  | ||||||
|                                            int connection_id, |  | ||||||
|                                            const cef_string_t* error_message); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Send a custom HTTP response to the connection identified by |  | ||||||
|   // |connection_id|. |response_code| is the HTTP response code sent in the |  | ||||||
|   // status line (e.g. 200), |content_type| is the response content type sent as |  | ||||||
|   // the "Content-Type" header (e.g. "text/html"), |content_length| is the |  | ||||||
|   // expected content length, and |extra_headers| is the map of extra response |  | ||||||
|   // headers. If |content_length| is >= 0 then the "Content-Length" header will |  | ||||||
|   // be sent. If |content_length| is 0 then no content is expected and the |  | ||||||
|   // connection will be closed automatically after the response is sent. If |  | ||||||
|   // |content_length| is < 0 then no "Content-Length" header will be sent and |  | ||||||
|   // the client will continue reading until the connection is closed. Use the |  | ||||||
|   // SendRawData function to send the content, if applicable, and call |  | ||||||
|   // CloseConnection after all content has been sent. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* send_http_response)(struct _cef_server_t* self, |  | ||||||
|                                          int connection_id, |  | ||||||
|                                          int response_code, |  | ||||||
|                                          const cef_string_t* content_type, |  | ||||||
|                                          int64 content_length, |  | ||||||
|                                          cef_string_multimap_t extra_headers); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Send raw data directly to the connection identified by |connection_id|. |  | ||||||
|   // |data| is the raw data and |data_size| is the size of |data| in bytes. The |  | ||||||
|   // contents of |data| will be copied. No validation of |data| is performed |  | ||||||
|   // internally so the client should be careful to send the amount indicated by |  | ||||||
|   // the "Content-Length" header, if specified. See SendHttpResponse |  | ||||||
|   // documentation for intended usage. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* send_raw_data)(struct _cef_server_t* self, |  | ||||||
|                                     int connection_id, |  | ||||||
|                                     const void* data, |  | ||||||
|                                     size_t data_size); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Close the connection identified by |connection_id|. See SendHttpResponse |  | ||||||
|   // documentation for intended usage. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* close_connection)(struct _cef_server_t* self, |  | ||||||
|                                        int connection_id); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Send a WebSocket message to the connection identified by |connection_id|. |  | ||||||
|   // |data| is the response content and |data_size| is the size of |data| in |  | ||||||
|   // bytes. The contents of |data| will be copied. See |  | ||||||
|   // cef_server_handler_t::OnWebSocketRequest documentation for intended usage. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* send_web_socket_message)(struct _cef_server_t* self, |  | ||||||
|                                               int connection_id, |  | ||||||
|                                               const void* data, |  | ||||||
|                                               size_t data_size); |  | ||||||
| } cef_server_t; |  | ||||||
|  |  | ||||||
| /// |  | ||||||
| // Create a new server that binds to |address| and |port|. |address| must be a |  | ||||||
| // valid IPv4 or IPv6 address (e.g. 127.0.0.1 or ::1) and |port| must be a port |  | ||||||
| // number outside of the reserved range (e.g. between 1025 and 65535 on most |  | ||||||
| // platforms). |backlog| is the maximum number of pending connections. A new |  | ||||||
| // thread will be created for each CreateServer call (the "dedicated server |  | ||||||
| // thread"). It is therefore recommended to use a different cef_server_handler_t |  | ||||||
| // instance for each CreateServer call to avoid thread safety issues in the |  | ||||||
| // cef_server_handler_t implementation. The |  | ||||||
| // cef_server_handler_t::OnServerCreated function will be called on the |  | ||||||
| // dedicated server thread to report success or failure. See |  | ||||||
| // cef_server_handler_t::OnServerCreated documentation for a description of |  | ||||||
| // server lifespan. |  | ||||||
| /// |  | ||||||
| CEF_EXPORT void cef_server_create(const cef_string_t* address, |  | ||||||
|                                   uint16 port, |  | ||||||
|                                   int backlog, |  | ||||||
|                                   struct _cef_server_handler_t* handler); |  | ||||||
|  |  | ||||||
| /// |  | ||||||
| // Implement this structure to handle HTTP server requests. A new thread will be |  | ||||||
| // created for each cef_server_t::CreateServer call (the "dedicated server |  | ||||||
| // thread"), and the functions of this structure will be called on that thread. |  | ||||||
| // It is therefore recommended to use a different cef_server_handler_t instance |  | ||||||
| // for each cef_server_t::CreateServer call to avoid thread safety issues in the |  | ||||||
| // cef_server_handler_t implementation. |  | ||||||
| /// |  | ||||||
| typedef struct _cef_server_handler_t { |  | ||||||
|   /// |  | ||||||
|   // Base structure. |  | ||||||
|   /// |  | ||||||
|   cef_base_ref_counted_t base; |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called when |server| is created. If the server was started successfully |  | ||||||
|   // then cef_server_t::IsRunning will return true (1). The server will continue |  | ||||||
|   // running until cef_server_t::Shutdown is called, after which time |  | ||||||
|   // OnServerDestroyed will be called. If the server failed to start then |  | ||||||
|   // OnServerDestroyed will be called immediately after this function returns. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* on_server_created)(struct _cef_server_handler_t* self, |  | ||||||
|                                         struct _cef_server_t* server); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called when |server| is destroyed. The server thread will be stopped after |  | ||||||
|   // this function returns. The client should release any references to |server| |  | ||||||
|   // when this function is called. See OnServerCreated documentation for a |  | ||||||
|   // description of server lifespan. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* on_server_destroyed)(struct _cef_server_handler_t* self, |  | ||||||
|                                           struct _cef_server_t* server); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called when a client connects to |server|. |connection_id| uniquely |  | ||||||
|   // identifies the connection. Each call to this function will have a matching |  | ||||||
|   // call to OnClientDisconnected. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* on_client_connected)(struct _cef_server_handler_t* self, |  | ||||||
|                                           struct _cef_server_t* server, |  | ||||||
|                                           int connection_id); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called when a client disconnects from |server|. |connection_id| uniquely |  | ||||||
|   // identifies the connection. The client should release any data associated |  | ||||||
|   // with |connection_id| when this function is called and |connection_id| |  | ||||||
|   // should no longer be passed to cef_server_t functions. Disconnects can |  | ||||||
|   // originate from either the client or the server. For example, the server |  | ||||||
|   // will disconnect automatically after a cef_server_t::SendHttpXXXResponse |  | ||||||
|   // function is called. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* on_client_disconnected)(struct _cef_server_handler_t* self, |  | ||||||
|                                              struct _cef_server_t* server, |  | ||||||
|                                              int connection_id); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called when |server| receives an HTTP request. |connection_id| uniquely |  | ||||||
|   // identifies the connection, |client_address| is the requesting IPv4 or IPv6 |  | ||||||
|   // client address including port number, and |request| contains the request |  | ||||||
|   // contents (URL, function, headers and optional POST data). Call cef_server_t |  | ||||||
|   // functions either synchronously or asynchronusly to send a response. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* on_http_request)(struct _cef_server_handler_t* self, |  | ||||||
|                                       struct _cef_server_t* server, |  | ||||||
|                                       int connection_id, |  | ||||||
|                                       const cef_string_t* client_address, |  | ||||||
|                                       struct _cef_request_t* request); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called when |server| receives a WebSocket request. |connection_id| uniquely |  | ||||||
|   // identifies the connection, |client_address| is the requesting IPv4 or IPv6 |  | ||||||
|   // client address including port number, and |request| contains the request |  | ||||||
|   // contents (URL, function, headers and optional POST data). Execute |  | ||||||
|   // |callback| either synchronously or asynchronously to accept or decline the |  | ||||||
|   // WebSocket connection. If the request is accepted then OnWebSocketConnected |  | ||||||
|   // will be called after the WebSocket has connected and incoming messages will |  | ||||||
|   // be delivered to the OnWebSocketMessage callback. If the request is declined |  | ||||||
|   // then the client will be disconnected and OnClientDisconnected will be |  | ||||||
|   // called. Call the cef_server_t::SendWebSocketMessage function after |  | ||||||
|   // receiving the OnWebSocketConnected callback to respond with WebSocket |  | ||||||
|   // messages. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* on_web_socket_request)(struct _cef_server_handler_t* self, |  | ||||||
|                                             struct _cef_server_t* server, |  | ||||||
|                                             int connection_id, |  | ||||||
|                                             const cef_string_t* client_address, |  | ||||||
|                                             struct _cef_request_t* request, |  | ||||||
|                                             struct _cef_callback_t* callback); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called after the client has accepted the WebSocket connection for |server| |  | ||||||
|   // and |connection_id| via the OnWebSocketRequest callback. See |  | ||||||
|   // OnWebSocketRequest documentation for intended usage. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* on_web_socket_connected)( |  | ||||||
|       struct _cef_server_handler_t* self, |  | ||||||
|       struct _cef_server_t* server, |  | ||||||
|       int connection_id); |  | ||||||
|  |  | ||||||
|   /// |  | ||||||
|   // Called when |server| receives an WebSocket message. |connection_id| |  | ||||||
|   // uniquely identifies the connection, |data| is the message content and |  | ||||||
|   // |data_size| is the size of |data| in bytes. Do not keep a reference to |  | ||||||
|   // |data| outside of this function. See OnWebSocketRequest documentation for |  | ||||||
|   // intended usage. |  | ||||||
|   /// |  | ||||||
|   void(CEF_CALLBACK* on_web_socket_message)(struct _cef_server_handler_t* self, |  | ||||||
|                                             struct _cef_server_t* server, |  | ||||||
|                                             int connection_id, |  | ||||||
|                                             const void* data, |  | ||||||
|                                             size_t data_size); |  | ||||||
| } cef_server_handler_t; |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus |  | ||||||
| } |  | ||||||
| #endif |  | ||||||
|  |  | ||||||
| #endif  // CEF_INCLUDE_CAPI_CEF_SERVER_CAPI_H_ |  | ||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=3aae2c2e717093121c6236d799cd4d7334cb153c$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_SSL_INFO_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_SSL_INFO_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_SSL_INFO_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_SSL_INFO_CAPI_H_ | ||||||
| @@ -48,6 +46,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure representing SSL information. | // Structure representing SSL information. | ||||||
| /// | /// | ||||||
| @@ -55,13 +54,14 @@ typedef struct _cef_sslinfo_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns a bitmask containing any and all problems verifying the server |   // Returns a bitmask containing any and all problems verifying the server | ||||||
|   // certificate. |   // certificate. | ||||||
|   /// |   /// | ||||||
|   cef_cert_status_t(CEF_CALLBACK* get_cert_status)(struct _cef_sslinfo_t* self); |   cef_cert_status_t (CEF_CALLBACK *get_cert_status)( | ||||||
|  |       struct _cef_sslinfo_t* self); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns the X.509 certificate. |   // Returns the X.509 certificate. | ||||||
| @@ -70,6 +70,7 @@ typedef struct _cef_sslinfo_t { | |||||||
|       struct _cef_sslinfo_t* self); |       struct _cef_sslinfo_t* self); | ||||||
| } cef_sslinfo_t; | } cef_sslinfo_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Returns true (1) if the certificate status has any error, major or minor. | // Returns true (1) if the certificate status has any error, major or minor. | ||||||
| /// | /// | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=4a448fc89af9db6e12499d3284b2b1309f889cfb$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_SSL_STATUS_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_SSL_STATUS_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_SSL_STATUS_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_SSL_STATUS_CAPI_H_ | ||||||
| @@ -48,6 +46,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure representing the SSL information for a navigation entry. | // Structure representing the SSL information for a navigation entry. | ||||||
| /// | /// | ||||||
| @@ -55,7 +54,7 @@ typedef struct _cef_sslstatus_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Returns true (1) if the status is related to a secure SSL/TLS connection. |   // Returns true (1) if the status is related to a secure SSL/TLS connection. | ||||||
| @@ -88,6 +87,7 @@ typedef struct _cef_sslstatus_t { | |||||||
|       struct _cef_sslstatus_t* self); |       struct _cef_sslstatus_t* self); | ||||||
| } cef_sslstatus_t; | } cef_sslstatus_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| // Copyright (c) 2018 Marshall A. Greenblatt. All rights reserved. | // Copyright (c) 2017 Marshall A. Greenblatt. All rights reserved. | ||||||
| // | // | ||||||
| // Redistribution and use in source and binary forms, with or without | // Redistribution and use in source and binary forms, with or without | ||||||
| // modification, are permitted provided that the following conditions are | // modification, are permitted provided that the following conditions are | ||||||
| @@ -33,8 +33,6 @@ | |||||||
| // by hand. See the translator.README.txt file in the tools directory for | // by hand. See the translator.README.txt file in the tools directory for | ||||||
| // more information. | // more information. | ||||||
| // | // | ||||||
| // $hash=13955a9608af96bba910c2d10c0050fe98c5d8dd$ |  | ||||||
| // |  | ||||||
|  |  | ||||||
| #ifndef CEF_INCLUDE_CAPI_CEF_STREAM_CAPI_H_ | #ifndef CEF_INCLUDE_CAPI_CEF_STREAM_CAPI_H_ | ||||||
| #define CEF_INCLUDE_CAPI_CEF_STREAM_CAPI_H_ | #define CEF_INCLUDE_CAPI_CEF_STREAM_CAPI_H_ | ||||||
| @@ -46,6 +44,7 @@ | |||||||
| extern "C" { | extern "C" { | ||||||
| #endif | #endif | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure the client can implement to provide a custom stream reader. The | // Structure the client can implement to provide a custom stream reader. The | ||||||
| // functions of this structure may be called on any thread. | // functions of this structure may be called on any thread. | ||||||
| @@ -54,22 +53,19 @@ typedef struct _cef_read_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Read raw binary data. |   // Read raw binary data. | ||||||
|   /// |   /// | ||||||
|   size_t(CEF_CALLBACK* read)(struct _cef_read_handler_t* self, |   size_t (CEF_CALLBACK *read)(struct _cef_read_handler_t* self, void* ptr, | ||||||
|                              void* ptr, |       size_t size, size_t n); | ||||||
|                              size_t size, |  | ||||||
|                              size_t n); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Seek to the specified offset position. |whence| may be any one of SEEK_CUR, |   // Seek to the specified offset position. |whence| may be any one of SEEK_CUR, | ||||||
|   // SEEK_END or SEEK_SET. Return zero on success and non-zero on failure. |   // SEEK_END or SEEK_SET. Return zero on success and non-zero on failure. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* seek)(struct _cef_read_handler_t* self, |   int (CEF_CALLBACK *seek)(struct _cef_read_handler_t* self, int64 offset, | ||||||
|                           int64 offset, |  | ||||||
|       int whence); |       int whence); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -90,6 +86,7 @@ typedef struct _cef_read_handler_t { | |||||||
|   int (CEF_CALLBACK *may_block)(struct _cef_read_handler_t* self); |   int (CEF_CALLBACK *may_block)(struct _cef_read_handler_t* self); | ||||||
| } cef_read_handler_t; | } cef_read_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used to read data from a stream. The functions of this structure | // Structure used to read data from a stream. The functions of this structure | ||||||
| // may be called on any thread. | // may be called on any thread. | ||||||
| @@ -98,22 +95,19 @@ typedef struct _cef_stream_reader_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Read raw binary data. |   // Read raw binary data. | ||||||
|   /// |   /// | ||||||
|   size_t(CEF_CALLBACK* read)(struct _cef_stream_reader_t* self, |   size_t (CEF_CALLBACK *read)(struct _cef_stream_reader_t* self, void* ptr, | ||||||
|                              void* ptr, |       size_t size, size_t n); | ||||||
|                              size_t size, |  | ||||||
|                              size_t n); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Seek to the specified offset position. |whence| may be any one of SEEK_CUR, |   // Seek to the specified offset position. |whence| may be any one of SEEK_CUR, | ||||||
|   // SEEK_END or SEEK_SET. Returns zero on success and non-zero on failure. |   // SEEK_END or SEEK_SET. Returns zero on success and non-zero on failure. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* seek)(struct _cef_stream_reader_t* self, |   int (CEF_CALLBACK *seek)(struct _cef_stream_reader_t* self, int64 offset, | ||||||
|                           int64 offset, |  | ||||||
|       int whence); |       int whence); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -134,6 +128,7 @@ typedef struct _cef_stream_reader_t { | |||||||
|   int (CEF_CALLBACK *may_block)(struct _cef_stream_reader_t* self); |   int (CEF_CALLBACK *may_block)(struct _cef_stream_reader_t* self); | ||||||
| } cef_stream_reader_t; | } cef_stream_reader_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Create a new cef_stream_reader_t object from a file. | // Create a new cef_stream_reader_t object from a file. | ||||||
| /// | /// | ||||||
| @@ -152,6 +147,7 @@ CEF_EXPORT cef_stream_reader_t* cef_stream_reader_create_for_data(void* data, | |||||||
| CEF_EXPORT cef_stream_reader_t* cef_stream_reader_create_for_handler( | CEF_EXPORT cef_stream_reader_t* cef_stream_reader_create_for_handler( | ||||||
|     cef_read_handler_t* handler); |     cef_read_handler_t* handler); | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure the client can implement to provide a custom stream writer. The | // Structure the client can implement to provide a custom stream writer. The | ||||||
| // functions of this structure may be called on any thread. | // functions of this structure may be called on any thread. | ||||||
| @@ -160,22 +156,19 @@ typedef struct _cef_write_handler_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Write raw binary data. |   // Write raw binary data. | ||||||
|   /// |   /// | ||||||
|   size_t (CEF_CALLBACK *write)(struct _cef_write_handler_t* self, |   size_t (CEF_CALLBACK *write)(struct _cef_write_handler_t* self, | ||||||
|                               const void* ptr, |       const void* ptr, size_t size, size_t n); | ||||||
|                               size_t size, |  | ||||||
|                               size_t n); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Seek to the specified offset position. |whence| may be any one of SEEK_CUR, |   // Seek to the specified offset position. |whence| may be any one of SEEK_CUR, | ||||||
|   // SEEK_END or SEEK_SET. Return zero on success and non-zero on failure. |   // SEEK_END or SEEK_SET. Return zero on success and non-zero on failure. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* seek)(struct _cef_write_handler_t* self, |   int (CEF_CALLBACK *seek)(struct _cef_write_handler_t* self, int64 offset, | ||||||
|                           int64 offset, |  | ||||||
|       int whence); |       int whence); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -196,6 +189,7 @@ typedef struct _cef_write_handler_t { | |||||||
|   int (CEF_CALLBACK *may_block)(struct _cef_write_handler_t* self); |   int (CEF_CALLBACK *may_block)(struct _cef_write_handler_t* self); | ||||||
| } cef_write_handler_t; | } cef_write_handler_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Structure used to write data to a stream. The functions of this structure may | // Structure used to write data to a stream. The functions of this structure may | ||||||
| // be called on any thread. | // be called on any thread. | ||||||
| @@ -204,22 +198,19 @@ typedef struct _cef_stream_writer_t { | |||||||
|   /// |   /// | ||||||
|   // Base structure. |   // Base structure. | ||||||
|   /// |   /// | ||||||
|   cef_base_ref_counted_t base; |   cef_base_t base; | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Write raw binary data. |   // Write raw binary data. | ||||||
|   /// |   /// | ||||||
|   size_t (CEF_CALLBACK *write)(struct _cef_stream_writer_t* self, |   size_t (CEF_CALLBACK *write)(struct _cef_stream_writer_t* self, | ||||||
|                               const void* ptr, |       const void* ptr, size_t size, size_t n); | ||||||
|                               size_t size, |  | ||||||
|                               size_t n); |  | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
|   // Seek to the specified offset position. |whence| may be any one of SEEK_CUR, |   // Seek to the specified offset position. |whence| may be any one of SEEK_CUR, | ||||||
|   // SEEK_END or SEEK_SET. Returns zero on success and non-zero on failure. |   // SEEK_END or SEEK_SET. Returns zero on success and non-zero on failure. | ||||||
|   /// |   /// | ||||||
|   int(CEF_CALLBACK* seek)(struct _cef_stream_writer_t* self, |   int (CEF_CALLBACK *seek)(struct _cef_stream_writer_t* self, int64 offset, | ||||||
|                           int64 offset, |  | ||||||
|       int whence); |       int whence); | ||||||
|  |  | ||||||
|   /// |   /// | ||||||
| @@ -240,6 +231,7 @@ typedef struct _cef_stream_writer_t { | |||||||
|   int (CEF_CALLBACK *may_block)(struct _cef_stream_writer_t* self); |   int (CEF_CALLBACK *may_block)(struct _cef_stream_writer_t* self); | ||||||
| } cef_stream_writer_t; | } cef_stream_writer_t; | ||||||
|  |  | ||||||
|  |  | ||||||
| /// | /// | ||||||
| // Create a new cef_stream_writer_t object for a file. | // Create a new cef_stream_writer_t object for a file. | ||||||
| /// | /// | ||||||
| @@ -252,6 +244,7 @@ CEF_EXPORT cef_stream_writer_t* cef_stream_writer_create_for_file( | |||||||
| CEF_EXPORT cef_stream_writer_t* cef_stream_writer_create_for_handler( | CEF_EXPORT cef_stream_writer_t* cef_stream_writer_create_for_handler( | ||||||
|     cef_write_handler_t* handler); |     cef_write_handler_t* handler); | ||||||
|  |  | ||||||
|  |  | ||||||
| #ifdef __cplusplus | #ifdef __cplusplus | ||||||
| } | } | ||||||
| #endif | #endif | ||||||
|   | |||||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user