mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-06-05 21:39:12 +02:00
Compare commits
409 Commits
Author | SHA1 | Date | |
---|---|---|---|
|
e76af7e6d6 | ||
|
1d7a1f96bf | ||
|
4deb4879a8 | ||
|
d692f803c8 | ||
|
9840ad9688 | ||
|
88b5034cf8 | ||
|
1b57edfc50 | ||
|
21db5606bf | ||
|
c1d356f5ab | ||
|
a5544b6fb1 | ||
|
87f49de296 | ||
|
5c235a209f | ||
|
6d71342015 | ||
|
404d11b785 | ||
|
b79d7a53b2 | ||
|
bdde55a296 | ||
|
203875394f | ||
|
0da33499ce | ||
|
e1d1f5e3e4 | ||
|
e6d7700746 | ||
|
686a5cab52 | ||
|
fe6e44886b | ||
|
c739fc029f | ||
|
31e1459f14 | ||
|
d38e4ef3ba | ||
|
2b5cb6a8ab | ||
|
c234e7f44b | ||
|
446b7d6535 | ||
|
a6c00b2ff6 | ||
|
69b884d39c | ||
|
3acdbac061 | ||
|
d470cf8204 | ||
|
cbbca050e0 | ||
|
69fbadd0bc | ||
|
4023fea237 | ||
|
5607a4d347 | ||
|
8f4a47479c | ||
|
02ea88f79f | ||
|
ddb0ab8187 | ||
|
ed4257c807 | ||
|
b7a172fefc | ||
|
68e1fcf3a4 | ||
|
1f35258023 | ||
|
60ce575e53 | ||
|
0d166c3c90 | ||
|
9b284ec8f7 | ||
|
b080705ec8 | ||
|
1cdf02815e | ||
|
cd3f617171 | ||
|
bd57a40256 | ||
|
c0a3c897cf | ||
|
231701d98b | ||
|
a461a89728 | ||
|
b95b3e6fd5 | ||
|
c4a6797059 | ||
|
ebb99fbd58 | ||
|
1d7e83336f | ||
|
2a19d3dc57 | ||
|
810c51026c | ||
|
5afde67593 | ||
|
3b98dbda79 | ||
|
c44aa35bfc | ||
|
4ed13d8c47 | ||
|
fe24ce3c71 | ||
|
cc40cbdd45 | ||
|
7c19cb90e1 | ||
|
47798d3dbf | ||
|
e4bb51f6f6 | ||
|
fd7444c7a4 | ||
|
c56ae7213e | ||
|
cb1830e16c | ||
|
39cafe3e6c | ||
|
15c7e80e3c | ||
|
8e79307a62 | ||
|
b0bceecba9 | ||
|
b6842f8b80 | ||
|
5fe6382906 | ||
|
bd1e188c77 | ||
|
701fc03f00 | ||
|
bc1b856b96 | ||
|
c7b30ee80f | ||
|
48137b9538 | ||
|
5a2cfb6907 | ||
|
6354d8daf1 | ||
|
aad216bf56 | ||
|
3f036edf2d | ||
|
32fc106ab0 | ||
|
0170f431a0 | ||
|
2156c9fd5d | ||
|
00118ddcdb | ||
|
e7626b2df6 | ||
|
8283317cb1 | ||
|
271c6f6446 | ||
|
311eaf827e | ||
|
002f4b5b4a | ||
|
17a1fd62ec | ||
|
ca636bb96e | ||
|
4e3668f93a | ||
|
6b13b1c627 | ||
|
29381355ef | ||
|
7328b9e40d | ||
|
b92749a58a | ||
|
49a34d9160 | ||
|
b5d84c254d | ||
|
d666ec5770 | ||
|
fe5b0dd668 | ||
|
c0e7854782 | ||
|
be6642df3f | ||
|
ed079792b6 | ||
|
0783b4c57d | ||
|
b537fc929b | ||
|
708d90a6ff | ||
|
5065aba1b4 | ||
|
65234a6830 | ||
|
b67cbc47e3 | ||
|
4fe529e2dc | ||
|
260dd0ca24 | ||
|
dca0435d2f | ||
|
62c93f01f4 | ||
|
81a0648ee1 | ||
|
744a194a6e | ||
|
96dc172980 | ||
|
f1effba336 | ||
|
d10cc16236 | ||
|
da1c3179a9 | ||
|
2e33954032 | ||
|
f60476b848 | ||
|
29c21f58e8 | ||
|
54a9c26b92 | ||
|
6253e69b70 | ||
|
8ba22e9e11 | ||
|
19ba8b2b8d | ||
|
a13b6dc7f6 | ||
|
52dac91167 | ||
|
526e934a12 | ||
|
b8f91c5431 | ||
|
5e616b2df0 | ||
|
9b06b028dc | ||
|
d4cf19db29 | ||
|
2c5dd120c7 | ||
|
ffea0d9c4a | ||
|
8db08e657d | ||
|
706193f3d9 | ||
|
bfed26c5fc | ||
|
71c8b4b2bb | ||
|
ec122a9148 | ||
|
90775f149f | ||
|
f071a4a988 | ||
|
cc3d77eec5 | ||
|
a79981bf7f | ||
|
70471059cf | ||
|
5dc3cc13e7 | ||
|
da3899d142 | ||
|
69fd43f789 | ||
|
d3a483ef59 | ||
|
bdb070c85c | ||
|
57bad703ee | ||
|
47fe9f834a | ||
|
2f1e782f62 | ||
|
2a86a02bdd | ||
|
132ac7a180 | ||
|
a0446a3c8a | ||
|
a02d2ab3e6 | ||
|
4ea1b6f293 | ||
|
befa827da1 | ||
|
0a64bb6f9b | ||
|
9fd312ce04 | ||
|
468e55e553 | ||
|
f1fe098e09 | ||
|
5af6227a6f | ||
|
0d50d5a8c6 | ||
|
a097b62b6e | ||
|
ffc703276a | ||
|
3592d36808 | ||
|
deb4664038 | ||
|
9f6995f839 | ||
|
784302280b | ||
|
7c2bd75f7a | ||
|
3507249202 | ||
|
5a9b8e2bc4 | ||
|
9a45102db0 | ||
|
1f55d2e12f | ||
|
9dc7653ddc | ||
|
e4acacee18 | ||
|
206b7b1c95 | ||
|
262a93b2f7 | ||
|
80c65f25a3 | ||
|
2f0b00f8f5 | ||
|
be734efe68 | ||
|
0dd7dca229 | ||
|
5613af8f53 | ||
|
a25f89f9e4 | ||
|
d6af79e7a6 | ||
|
f781ea373f | ||
|
738192addf | ||
|
2b1922746f | ||
|
3b652a9966 | ||
|
cf934a20a7 | ||
|
a9f1ce090a | ||
|
1886f68490 | ||
|
53ef570f57 | ||
|
d3d465b32e | ||
|
2b38e2f793 | ||
|
3837f209e1 | ||
|
21e01d4889 | ||
|
44323082b1 | ||
|
1b74ac5124 | ||
|
b2274f534d | ||
|
3476199bc5 | ||
|
6651523d86 | ||
|
f594ca3785 | ||
|
15caa9858d | ||
|
e6a96e2bec | ||
|
90aea56de6 | ||
|
a2a1b66ea5 | ||
|
8d7001adc3 | ||
|
f3e92b45fc | ||
|
64c2dc13ca | ||
|
a8a96235a8 | ||
|
29938f9cb0 | ||
|
d8ea7363f5 | ||
|
f8dd0dbfb4 | ||
|
bdec92caf8 | ||
|
4ae030fec1 | ||
|
c7d4d9690c | ||
|
39e64d8cc9 | ||
|
262ed72348 | ||
|
27c6a4eabc | ||
|
4df2933516 | ||
|
57d7d89b53 | ||
|
cab404578d | ||
|
ef6ae3071d | ||
|
b064ba08f3 | ||
|
f808926fbd | ||
|
f4ecc23213 | ||
|
0a633e361b | ||
|
2133d8f5b3 | ||
|
445da33efe | ||
|
a4b27a7248 | ||
|
52cb08b973 | ||
|
52a9794659 | ||
|
605c2bac86 | ||
|
01e1a0f44d | ||
|
52b4d7ba5a | ||
|
94d51ffe20 | ||
|
4fc5fb8690 | ||
|
b07a9e1843 | ||
|
8b46735b79 | ||
|
1353677a98 | ||
|
a576150ab5 | ||
|
7a033d7585 | ||
|
1f11ce8700 | ||
|
59bfb32221 | ||
|
04c042d9d1 | ||
|
8603545aef | ||
|
650755a092 | ||
|
71c588c16a | ||
|
0b99f92e97 | ||
|
05930b7bc9 | ||
|
12d0bccbd4 | ||
|
b5386249bd | ||
|
36a645ffd8 | ||
|
3bd2cd78c7 | ||
|
cbdda6b03b | ||
|
6355aaf33b | ||
|
e53bff712a | ||
|
b854992ae6 | ||
|
5042d71408 | ||
|
695ee2a041 | ||
|
cf8b7db4b4 | ||
|
5d8c6799fc | ||
|
bd368f5d3a | ||
|
87a04aba03 | ||
|
df4dddee0b | ||
|
eb63f9e7ae | ||
|
29b5999fd7 | ||
|
5707889555 | ||
|
ecdfd467f8 | ||
|
e5334a5a18 | ||
|
e5c4b27366 | ||
|
c18545a7f5 | ||
|
dc9e64308a | ||
|
b8e1c6a59d | ||
|
cf14b2a972 | ||
|
5a22a5c8a3 | ||
|
5e80ea3371 | ||
|
d0b3042940 | ||
|
de4f9e8908 | ||
|
ab94a13522 | ||
|
09c4142dad | ||
|
e0063880ac | ||
|
7ade772e0b | ||
|
a39c2a0068 | ||
|
17cab6d955 | ||
|
cad2498d87 | ||
|
6569ef09c5 | ||
|
78ea5d8c61 | ||
|
c3648f42b2 | ||
|
f90d5bc49e | ||
|
55e158fe81 | ||
|
5d48f277f2 | ||
|
2094a8e221 | ||
|
4b3c3132cb | ||
|
c83b3cda24 | ||
|
0a2c7a1070 | ||
|
178a44bd18 | ||
|
45d771dfb0 | ||
|
1726176b9b | ||
|
c6872cec5f | ||
|
14dd0c0d06 | ||
|
06af9c85da | ||
|
d509d5833d | ||
|
2c67350605 | ||
|
9ae4da3b38 | ||
|
8b79f9cbe7 | ||
|
3e4f8d1b9c | ||
|
f3b570cf8e | ||
|
d33b67cb33 | ||
|
ae9ede9aa6 | ||
|
584b19967a | ||
|
3c85154faf | ||
|
276423dcfb | ||
|
42f351a40d | ||
|
13f2282754 | ||
|
80cfb3c97c | ||
|
73082fd2ce | ||
|
bc29774553 | ||
|
ff68c01543 | ||
|
400fbf7839 | ||
|
f34406c57d | ||
|
adfa59f690 | ||
|
baf98ee6e9 | ||
|
dc2231cdfb | ||
|
4c41f14360 | ||
|
36ee304ed4 | ||
|
c3c5d6ff37 | ||
|
47d2651ea4 | ||
|
5c4ac32bb9 | ||
|
8b447e3a6f | ||
|
b065ca8cf4 | ||
|
2b906c31b5 | ||
|
b65d59f27e | ||
|
606e5dddf3 | ||
|
4f336c110b | ||
|
aae420aa8b | ||
|
b1a530c76a | ||
|
f6d626d979 | ||
|
2b2c6aa143 | ||
|
b66c2d1bea | ||
|
e65da8fab8 | ||
|
aef474b909 | ||
|
8a07a836e1 | ||
|
9f8be5ea6c | ||
|
83cb82d50f | ||
|
a986b1c226 | ||
|
d04b5d4f87 | ||
|
e646827d92 | ||
|
7ba45a0451 | ||
|
3af3eab3e4 | ||
|
d84b07a5cb | ||
|
c7ffa3a122 | ||
|
ecc89d7d93 | ||
|
30a321b1ce | ||
|
d7d0c2fc6d | ||
|
216e5b31dd | ||
|
47d69a842a | ||
|
74fc5d5573 | ||
|
7611c4dba6 | ||
|
25954e872e | ||
|
e2a9236106 | ||
|
882bc19fdd | ||
|
09bb643ef6 | ||
|
767c4422ac | ||
|
07bf5dbacc | ||
|
dfd1917d9b | ||
|
a046794e68 | ||
|
1e4e18240d | ||
|
8b45f32b33 | ||
|
25c75c5fc4 | ||
|
485f0b9caf | ||
|
fa643b269e | ||
|
60ee4a34aa | ||
|
f33c062d78 | ||
|
fce5af14a8 | ||
|
497e0d2d98 | ||
|
e0c878df5f | ||
|
5433d9fe5c | ||
|
dc35b3a93e | ||
|
4e43f90244 | ||
|
4d1fd05740 | ||
|
0089378a0a | ||
|
7e3b084819 | ||
|
53c365b752 | ||
|
9c359b682b | ||
|
7174c4c328 | ||
|
9ecd25a93b | ||
|
5ea0c141b5 | ||
|
12fc72147c | ||
|
cf7e10aacc | ||
|
09b4cbd32c | ||
|
8645e88e0e | ||
|
fa2464e843 | ||
|
51699e671a | ||
|
14c0f74707 | ||
|
77582a01b5 | ||
|
d7a153bdd4 | ||
|
7b352159df | ||
|
00f34d5e68 | ||
|
f8d90a8972 |
35
.github/ISSUE_TEMPLATE/bug_report.md
vendored
Normal file
35
.github/ISSUE_TEMPLATE/bug_report.md
vendored
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
---
|
||||||
|
name: Bug report
|
||||||
|
about: Create a report to help us improve
|
||||||
|
title: ''
|
||||||
|
labels: bug
|
||||||
|
assignees: ''
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**Describe the bug**
|
||||||
|
A clear and concise description of what the bug is.
|
||||||
|
|
||||||
|
**To Reproduce**
|
||||||
|
Steps to reproduce the behavior:
|
||||||
|
1. Go to '...'
|
||||||
|
2. Click on '....'
|
||||||
|
3. Scroll down to '....'
|
||||||
|
4. See error
|
||||||
|
|
||||||
|
**Expected behavior**
|
||||||
|
A clear and concise description of what you expected to happen and what happened instead.
|
||||||
|
|
||||||
|
**Screenshots**
|
||||||
|
If applicable, add screenshots to help explain your problem.
|
||||||
|
|
||||||
|
**Versions (please complete the following information):**
|
||||||
|
- OS: [e.g. Windows 10, MacOS 13.2, Ubuntu 22.10]
|
||||||
|
- CEF Version: [e.g. 111.2.2]
|
||||||
|
|
||||||
|
**Additional context**
|
||||||
|
Does the problem reproduce with the cefclient or cefsimple sample application at the same version?
|
||||||
|
|
||||||
|
Does the problem reproduce with Google Chrome at the same version?
|
||||||
|
|
||||||
|
Add any other context about the problem here.
|
20
.github/ISSUE_TEMPLATE/feature_request.md
vendored
Normal file
20
.github/ISSUE_TEMPLATE/feature_request.md
vendored
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
---
|
||||||
|
name: Feature request
|
||||||
|
about: Suggest an idea for this project
|
||||||
|
title: ''
|
||||||
|
labels: enhancement
|
||||||
|
assignees: ''
|
||||||
|
|
||||||
|
---
|
||||||
|
|
||||||
|
**Is your feature request related to a problem? Please describe.**
|
||||||
|
A clear and concise description of what the problem is. Ex. I'm always frustrated when [...]
|
||||||
|
|
||||||
|
**Describe the solution you'd like**
|
||||||
|
A clear and concise description of what you want to happen.
|
||||||
|
|
||||||
|
**Describe alternatives you've considered**
|
||||||
|
A clear and concise description of any alternative solutions or features you've considered.
|
||||||
|
|
||||||
|
**Additional context**
|
||||||
|
Add any other context or screenshots about the feature request here.
|
1
.gitignore
vendored
1
.gitignore
vendored
@@ -51,6 +51,5 @@ Thumbs.db
|
|||||||
/binary_distrib
|
/binary_distrib
|
||||||
/docs
|
/docs
|
||||||
# CEF generated files
|
# CEF generated files
|
||||||
/include/cef_config.h
|
|
||||||
/include/cef_version.h
|
/include/cef_version.h
|
||||||
.ccls-cache/
|
.ccls-cache/
|
||||||
|
@@ -7,6 +7,6 @@
|
|||||||
# https://bitbucket.org/chromiumembedded/cef/wiki/BranchesAndBuilding
|
# https://bitbucket.org/chromiumembedded/cef/wiki/BranchesAndBuilding
|
||||||
|
|
||||||
{
|
{
|
||||||
'chromium_checkout': 'refs/tags/106.0.5249.119',
|
'chromium_checkout': 'refs/tags/128.0.6613.138',
|
||||||
'depot_tools_checkout': 'b7ec673ccc'
|
'depot_tools_checkout': 'ac3b7937a3'
|
||||||
}
|
}
|
||||||
|
@@ -27,19 +27,8 @@
|
|||||||
# Files in the chromium/src directory that should be evaluated for changes.
|
# Files in the chromium/src directory that should be evaluated for changes.
|
||||||
# Similar changes may need to be applied to the CEF source code.
|
# Similar changes may need to be applied to the CEF source code.
|
||||||
'files': [
|
'files': [
|
||||||
'chrome/browser/browser_process.h',
|
'components/content_settings/core/common/content_settings_types.mojom',
|
||||||
'chrome/browser/extensions/api/tabs/tabs_api.*',
|
'components/permissions/request_type.h',
|
||||||
'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/browser/renderer_host/render_widget_host_view_base.*',
|
||||||
'content/public/browser/content_browser_client.*',
|
'content/public/browser/content_browser_client.*',
|
||||||
'content/public/browser/render_widget_host_view.h',
|
'content/public/browser/render_widget_host_view.h',
|
||||||
|
@@ -12,8 +12,8 @@
|
|||||||
# distribution include:
|
# distribution include:
|
||||||
#
|
#
|
||||||
# Linux: Ninja, GCC 7.5.0+, Unix Makefiles
|
# Linux: Ninja, GCC 7.5.0+, Unix Makefiles
|
||||||
# MacOS: Ninja, Xcode 12.2 to 13.0
|
# MacOS: Ninja, Xcode 12.2 to 15.0
|
||||||
# Windows: Ninja, Visual Studio 2019+
|
# Windows: Ninja, Visual Studio 2022
|
||||||
#
|
#
|
||||||
# Ninja is a cross-platform open-source tool for running fast builds using
|
# Ninja is a cross-platform open-source tool for running fast builds using
|
||||||
# pre-installed platform toolchains (GNU, clang, Xcode or MSVC). It can be
|
# pre-installed platform toolchains (GNU, clang, Xcode or MSVC). It can be
|
||||||
@@ -36,7 +36,7 @@
|
|||||||
#
|
#
|
||||||
# The below requirements must be met to build this CEF binary distribution.
|
# The below requirements must be met to build this CEF binary distribution.
|
||||||
#
|
#
|
||||||
# - CMake version 3.19 or newer.
|
# - CMake version 3.21 or newer.
|
||||||
#
|
#
|
||||||
# - Linux requirements:
|
# - Linux requirements:
|
||||||
# Currently supported distributions include Debian 10 (Buster), Ubuntu 18
|
# Currently supported distributions include Debian 10 (Buster), Ubuntu 18
|
||||||
@@ -48,15 +48,15 @@
|
|||||||
# libgtk3.0-dev (required by the cefclient target only)
|
# libgtk3.0-dev (required by the cefclient target only)
|
||||||
#
|
#
|
||||||
# - MacOS requirements:
|
# - MacOS requirements:
|
||||||
# Xcode 12.2 to 13.4 building on MacOS 10.15.4 (Catalina) or newer. Only
|
# Xcode 12.2 to 15.0 building on MacOS 10.15.4 (Catalina) or newer. Only
|
||||||
# 64-bit builds are supported. The Xcode command-line tools must also be
|
# 64-bit builds are supported. The Xcode command-line tools must also be
|
||||||
# installed. Newer Xcode versions may not have been been tested and are not
|
# installed. Newer Xcode versions may not have been been tested and are not
|
||||||
# recommended.
|
# recommended.
|
||||||
#
|
#
|
||||||
# - Windows requirements:
|
# - Windows requirements:
|
||||||
# Visual Studio 2019 or newer building on Windows 7 or newer. Windows 10
|
# Visual Studio 2022 building on Windows 10 or newer. Windows 10/11 64-bit is
|
||||||
# 64-bit is recommended. Newer versions will likely also work but may not have
|
# recommended. Newer versions will likely also work but may not have been
|
||||||
# been tested.
|
# tested.
|
||||||
#
|
#
|
||||||
# BUILD EXAMPLES
|
# BUILD EXAMPLES
|
||||||
#
|
#
|
||||||
@@ -96,35 +96,35 @@
|
|||||||
# > ninja cefclient cefsimple
|
# > ninja cefclient cefsimple
|
||||||
#
|
#
|
||||||
# To perform a Windows build using a 32-bit CEF binary distribution:
|
# To perform a Windows build using a 32-bit CEF binary distribution:
|
||||||
# Using the Visual Studio 2019 IDE:
|
# Using the Visual Studio 2022 IDE:
|
||||||
# > cmake -G "Visual Studio 16" -A Win32 ..
|
# > cmake -G "Visual Studio 17" -A Win32 ..
|
||||||
# Open build\cef.sln in Visual Studio and select Build > Build Solution.
|
# Open build\cef.sln in Visual Studio and select Build > Build Solution.
|
||||||
#
|
#
|
||||||
# Using Ninja with Visual Studio 2019 command-line tools:
|
# Using Ninja with Visual Studio 2022 command-line tools:
|
||||||
# (this path may be different depending on your Visual Studio installation)
|
# (this path may be different depending on your Visual Studio installation)
|
||||||
# > "C:\Program Files (x86)\Microsoft Visual Studio\2019\Professional\VC\Auxiliary\Build\vcvars32.bat"
|
# > "C:\Program Files\Microsoft Visual Studio\2022\Professional\VC\Auxiliary\Build\vcvars32.bat"
|
||||||
# > cmake -G "Ninja" -DCMAKE_BUILD_TYPE=Debug ..
|
# > cmake -G "Ninja" -DCMAKE_BUILD_TYPE=Debug ..
|
||||||
# > ninja cefclient cefsimple
|
# > ninja cefclient cefsimple
|
||||||
#
|
#
|
||||||
# To perform a Windows build using a 64-bit CEF binary distribution:
|
# To perform a Windows build using a 64-bit CEF binary distribution:
|
||||||
# Using the Visual Studio 2019 IDE:
|
# Using the Visual Studio 2022 IDE:
|
||||||
# > cmake -G "Visual Studio 16" -A x64 ..
|
# > cmake -G "Visual Studio 17" -A x64 ..
|
||||||
# Open build\cef.sln in Visual Studio and select Build > Build Solution.
|
# Open build\cef.sln in Visual Studio and select Build > Build Solution.
|
||||||
#
|
#
|
||||||
# Using Ninja with Visual Studio 2019 command-line tools:
|
# Using Ninja with Visual Studio 2022 command-line tools:
|
||||||
# (this path may be different depending on your Visual Studio installation)
|
# (this path may be different depending on your Visual Studio installation)
|
||||||
# > "C:\Program Files (x86)\Microsoft Visual Studio\2019\Professional\VC\Auxiliary\Build\vcvars64.bat"
|
# > "C:\Program Files\Microsoft Visual Studio\2022\Professional\VC\Auxiliary\Build\vcvars64.bat"
|
||||||
# > cmake -G "Ninja" -DCMAKE_BUILD_TYPE=Debug ..
|
# > cmake -G "Ninja" -DCMAKE_BUILD_TYPE=Debug ..
|
||||||
# > ninja cefclient cefsimple
|
# > ninja cefclient cefsimple
|
||||||
#
|
#
|
||||||
# To perform a Windows build using an ARM64 CEF binary distribution:
|
# To perform a Windows build using an ARM64 CEF binary distribution:
|
||||||
# Using the Visual Studio 2019 IDE:
|
# Using the Visual Studio 2022 IDE:
|
||||||
# > cmake -G "Visual Studio 16" -A arm64 ..
|
# > cmake -G "Visual Studio 17" -A arm64 ..
|
||||||
# Open build\cef.sln in Visual Studio and select Build > Build Solution.
|
# Open build\cef.sln in Visual Studio and select Build > Build Solution.
|
||||||
#
|
#
|
||||||
# Using Ninja with Visual Studio 2019 command-line tools:
|
# Using Ninja with Visual Studio 2022 command-line tools:
|
||||||
# (this path may be different depending on your Visual Studio installation)
|
# (this path may be different depending on your Visual Studio installation)
|
||||||
# > "C:\Program Files (x86)\Microsoft Visual Studio\2019\Professional\VC\Auxiliary\Build\vcvarsamd64_arm64.bat"
|
# > "C:\Program Files\Microsoft Visual Studio\2022\Professional\VC\Auxiliary\Build\vcvarsamd64_arm64.bat"
|
||||||
# > cmake -G "Ninja" -DCMAKE_BUILD_TYPE=Debug ..
|
# > cmake -G "Ninja" -DCMAKE_BUILD_TYPE=Debug ..
|
||||||
# > ninja cefsimple
|
# > ninja cefsimple
|
||||||
|
|
||||||
@@ -132,8 +132,8 @@
|
|||||||
# Global setup.
|
# Global setup.
|
||||||
#
|
#
|
||||||
|
|
||||||
# For VS2019 and Xcode 12+ support.
|
# For VS2022 and Xcode 12+ support.
|
||||||
cmake_minimum_required(VERSION 3.19)
|
cmake_minimum_required(VERSION 3.21)
|
||||||
|
|
||||||
# Only generate Debug and Release configuration types.
|
# Only generate Debug and Release configuration types.
|
||||||
set(CMAKE_CONFIGURATION_TYPES Debug Release)
|
set(CMAKE_CONFIGURATION_TYPES Debug Release)
|
||||||
@@ -240,16 +240,18 @@ PRINT_CEF_CONFIG()
|
|||||||
# Define the API documentation target.
|
# Define the API documentation target.
|
||||||
#
|
#
|
||||||
|
|
||||||
find_package(Doxygen)
|
if(EXISTS "${CMAKE_CURRENT_SOURCE_DIR}/Doxyfile")
|
||||||
if(DOXYGEN_FOUND)
|
find_package(Doxygen)
|
||||||
add_custom_target(apidocs ALL
|
if(DOXYGEN_FOUND)
|
||||||
# Generate documentation in the docs/html directory.
|
add_custom_target(apidocs ALL
|
||||||
COMMAND "${DOXYGEN_EXECUTABLE}" Doxyfile
|
# Generate documentation in the docs/html directory.
|
||||||
# Write a docs/index.html file.
|
COMMAND "${DOXYGEN_EXECUTABLE}" Doxyfile
|
||||||
COMMAND ${CMAKE_COMMAND} -E echo "<html><head><meta http-equiv=\"refresh\" content=\"0;URL='html/index.html'\"/></head></html>" > docs/index.html
|
# Write a docs/index.html file.
|
||||||
WORKING_DIRECTORY "${CEF_ROOT}"
|
COMMAND ${CMAKE_COMMAND} -E echo "<html><head><meta http-equiv=\"refresh\" content=\"0;URL='html/index.html'\"/></head></html>" > docs/index.html
|
||||||
COMMENT "Generating API documentation with Doxygen..."
|
WORKING_DIRECTORY "${CEF_ROOT}"
|
||||||
VERBATIM )
|
COMMENT "Generating API documentation with Doxygen..."
|
||||||
else()
|
VERBATIM )
|
||||||
message(WARNING "Doxygen must be installed to generate API documentation.")
|
else()
|
||||||
endif()
|
message(WARNING "Doxygen must be installed to generate API documentation.")
|
||||||
|
endif()
|
||||||
|
endif()
|
3
Doxyfile
3
Doxyfile
@@ -2375,7 +2375,8 @@ PREDEFINED = USING_CEF_SHARED \
|
|||||||
OS_WIN \
|
OS_WIN \
|
||||||
OS_LINUX \
|
OS_LINUX \
|
||||||
CEF_X11 \
|
CEF_X11 \
|
||||||
OS_MAC
|
OS_MAC \
|
||||||
|
ARCH_CPU_32_BITS
|
||||||
|
|
||||||
# If the MACRO_EXPANSION and EXPAND_ONLY_PREDEF tags are set to YES then this
|
# If the MACRO_EXPANSION and EXPAND_ONLY_PREDEF tags are set to YES then this
|
||||||
# tag can be used to specify a list of macro names that should be expanded. The
|
# tag can be used to specify a list of macro names that should be expanded. The
|
||||||
|
@@ -9,6 +9,7 @@ The Chromium Embedded Framework (CEF) is a simple framework for embedding Chromi
|
|||||||
* Branches and Building - https://bitbucket.org/chromiumembedded/cef/wiki/BranchesAndBuilding
|
* Branches and Building - https://bitbucket.org/chromiumembedded/cef/wiki/BranchesAndBuilding
|
||||||
* Announcements - https://groups.google.com/forum/#!forum/cef-announce
|
* Announcements - https://groups.google.com/forum/#!forum/cef-announce
|
||||||
* Support Forum - http://www.magpcss.org/ceforum/
|
* Support Forum - http://www.magpcss.org/ceforum/
|
||||||
|
* Issue Tracker - https://github.com/chromiumembedded/cef/issues
|
||||||
* C++ API Docs - [Stable release docs](https://cef-builds.spotifycdn.com/docs/stable.html) / [Beta release docs](https://cef-builds.spotifycdn.com/docs/beta.html)
|
* C++ API Docs - [Stable release docs](https://cef-builds.spotifycdn.com/docs/stable.html) / [Beta release docs](https://cef-builds.spotifycdn.com/docs/beta.html)
|
||||||
* Downloads - https://cef-builds.spotifycdn.com/index.html
|
* Downloads - https://cef-builds.spotifycdn.com/index.html
|
||||||
* Donations - http://www.magpcss.org/ceforum/donate.php
|
* Donations - http://www.magpcss.org/ceforum/donate.php
|
||||||
@@ -48,6 +49,7 @@ The base CEF framework includes support for the C and C++ programming languages.
|
|||||||
* Delphi - https://github.com/hgourvest/dcef3
|
* Delphi - https://github.com/hgourvest/dcef3
|
||||||
* Delphi - https://github.com/salvadordf/CEF4Delphi
|
* Delphi - https://github.com/salvadordf/CEF4Delphi
|
||||||
* Go - https://github.com/CzarekTomczak/cef2go
|
* Go - https://github.com/CzarekTomczak/cef2go
|
||||||
|
* Go - https://github.com/energye/energy
|
||||||
* Java - https://bitbucket.org/chromiumembedded/java-cef
|
* Java - https://bitbucket.org/chromiumembedded/java-cef
|
||||||
* Python - http://code.google.com/p/cefpython/
|
* Python - http://code.google.com/p/cefpython/
|
||||||
|
|
||||||
@@ -57,7 +59,7 @@ If you're the maintainer of a project not listed above and would like your proje
|
|||||||
|
|
||||||
CEF is still very much a work in progress. Some ways that you can help out:
|
CEF is still very much a work in progress. Some ways that you can help out:
|
||||||
|
|
||||||
\- Vote for issues in the [CEF issue tracker](https://bitbucket.org/chromiumembedded/cef/issues?status=new&status=open) that are important to you. This helps with development prioritization.
|
\- Vote for issues in the [CEF issue tracker](https://github.com/chromiumembedded/cef/issues) that are important to you. This helps with development prioritization.
|
||||||
|
|
||||||
\- Report any bugs that you find or feature requests that are important to you. Make sure to first search for existing issues before creating new ones. Please use the [CEF Forum](http://magpcss.org/ceforum) and not the issue tracker for usage questions. Each CEF issue should:
|
\- Report any bugs that you find or feature requests that are important to you. Make sure to first search for existing issues before creating new ones. Please use the [CEF Forum](http://magpcss.org/ceforum) and not the issue tracker for usage questions. Each CEF issue should:
|
||||||
|
|
||||||
@@ -68,7 +70,7 @@ CEF is still very much a work in progress. Some ways that you can help out:
|
|||||||
|
|
||||||
\- Write unit tests for new or existing functionality.
|
\- Write unit tests for new or existing functionality.
|
||||||
|
|
||||||
\- Pull requests and patches are welcome. View open issues in the [CEF issue tracker](https://bitbucket.org/chromiumembedded/cef/issues?status=new&status=open) or search for TODO(cef) in the source code for ideas.
|
\- Pull requests and patches are welcome. View open issues in the [CEF issue tracker](https://github.com/chromiumembedded/cef/issues) or search for TODO(cef) in the source code for ideas.
|
||||||
|
|
||||||
If you would like to contribute source code changes to CEF please follow the below guidelines:
|
If you would like to contribute source code changes to CEF please follow the below guidelines:
|
||||||
|
|
||||||
|
8
bazel/BUILD.bazel
Normal file
8
bazel/BUILD.bazel
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
# Copyright (c) 2024 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.
|
||||||
|
|
||||||
|
# Allow access from targets in other packages.
|
||||||
|
package(default_visibility = [
|
||||||
|
"//visibility:public",
|
||||||
|
])
|
65
bazel/copy_filegroups.bzl
Normal file
65
bazel/copy_filegroups.bzl
Normal file
@@ -0,0 +1,65 @@
|
|||||||
|
# Copyright (c) 2024 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.
|
||||||
|
|
||||||
|
def _copy_filegroups_impl(ctx):
|
||||||
|
inputs = ctx.files.filegroups
|
||||||
|
remove_prefixes = ctx.attr.remove_prefixes
|
||||||
|
add_prefix = ctx.attr.add_prefix
|
||||||
|
|
||||||
|
outputs = []
|
||||||
|
for f in inputs:
|
||||||
|
relative_path = f.path
|
||||||
|
if relative_path.startswith("external/"):
|
||||||
|
# Remove the "external/<repo>" component, if any.
|
||||||
|
relative_path = "/".join(relative_path.split("/")[2:])
|
||||||
|
|
||||||
|
for prefix in remove_prefixes:
|
||||||
|
# Add trailing forward slash if necessary.
|
||||||
|
if prefix[-1] != "/":
|
||||||
|
prefix += "/"
|
||||||
|
if len(prefix) > 0 and relative_path.startswith(prefix):
|
||||||
|
relative_path = relative_path[len(prefix):]
|
||||||
|
break
|
||||||
|
|
||||||
|
if len(add_prefix) > 0:
|
||||||
|
# Add trailing forward slash if necessary.
|
||||||
|
if add_prefix[-1] != "/":
|
||||||
|
add_prefix += "/"
|
||||||
|
relative_path = add_prefix + relative_path
|
||||||
|
|
||||||
|
out = ctx.actions.declare_file(relative_path)
|
||||||
|
outputs.append(out)
|
||||||
|
|
||||||
|
if relative_path.find("/") > 0:
|
||||||
|
command="mkdir -p $(dirname {}) && cp {} {}".format(out.path, f.path, out.path)
|
||||||
|
else:
|
||||||
|
command="cp {} {}".format(f.path, out.path)
|
||||||
|
|
||||||
|
ctx.actions.run_shell(
|
||||||
|
outputs=[out],
|
||||||
|
inputs=depset([f]),
|
||||||
|
command=command
|
||||||
|
)
|
||||||
|
|
||||||
|
# Small sanity check
|
||||||
|
if len(inputs) != len(outputs):
|
||||||
|
fail("Output count should be 1-to-1 with input count.")
|
||||||
|
|
||||||
|
return DefaultInfo(
|
||||||
|
files=depset(outputs),
|
||||||
|
runfiles=ctx.runfiles(files=outputs)
|
||||||
|
)
|
||||||
|
|
||||||
|
# Allows the file contents of |filegroups| to be copied next to a cc_binary
|
||||||
|
# target via the |data| attribute.
|
||||||
|
# Implementation based on https://stackoverflow.com/a/57983629
|
||||||
|
copy_filegroups = rule(
|
||||||
|
implementation=_copy_filegroups_impl,
|
||||||
|
attrs={
|
||||||
|
"filegroups": attr.label_list(),
|
||||||
|
"remove_prefixes": attr.string_list(default = []),
|
||||||
|
"add_prefix": attr.string(default = ""),
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
90
bazel/library_helpers.bzl
Normal file
90
bazel/library_helpers.bzl
Normal file
@@ -0,0 +1,90 @@
|
|||||||
|
# Copyright (c) 2024 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.
|
||||||
|
|
||||||
|
load("//bazel/win:variables.bzl",
|
||||||
|
WIN_COMMON_COPTS="COMMON_COPTS",
|
||||||
|
WIN_COMMON_COPTS_RELEASE="COMMON_COPTS_RELEASE",
|
||||||
|
WIN_COMMON_COPTS_DEBUG="COMMON_COPTS_DEBUG",
|
||||||
|
WIN_COMMON_DEFINES="COMMON_DEFINES",
|
||||||
|
WIN_COMMON_DEFINES_RELEASE="COMMON_DEFINES_RELEASE",
|
||||||
|
WIN_COMMON_DEFINES_DEBUG="COMMON_DEFINES_DEBUG")
|
||||||
|
load("//bazel/linux:variables.bzl",
|
||||||
|
LINUX_COMMON_COPTS="COMMON_COPTS",
|
||||||
|
LINUX_COMMON_COPTS_RELEASE="COMMON_COPTS_RELEASE",
|
||||||
|
LINUX_COMMON_COPTS_DEBUG="COMMON_COPTS_DEBUG",
|
||||||
|
LINUX_COMMON_DEFINES="COMMON_DEFINES",
|
||||||
|
LINUX_COMMON_DEFINES_RELEASE="COMMON_DEFINES_RELEASE",
|
||||||
|
LINUX_COMMON_DEFINES_DEBUG="COMMON_DEFINES_DEBUG")
|
||||||
|
load("//bazel/mac:variables.bzl",
|
||||||
|
MAC_COMMON_COPTS="COMMON_COPTS",
|
||||||
|
MAC_COMMON_COPTS_RELEASE="COMMON_COPTS_RELEASE",
|
||||||
|
MAC_COMMON_COPTS_DEBUG="COMMON_COPTS_DEBUG")
|
||||||
|
load("@rules_cc//cc:defs.bzl", "cc_library", "objc_library")
|
||||||
|
|
||||||
|
def declare_cc_library(copts=[], local_defines=[], **kwargs):
|
||||||
|
"""
|
||||||
|
cc_library wrapper that applies common copts and local_defines.
|
||||||
|
"""
|
||||||
|
# NOTE: objc_library does not support local_defines on MacOS, so on
|
||||||
|
# that platform we put the defines in copts instead.
|
||||||
|
cc_library(
|
||||||
|
copts = select({
|
||||||
|
"@platforms//os:windows": WIN_COMMON_COPTS,
|
||||||
|
"@platforms//os:linux": LINUX_COMMON_COPTS,
|
||||||
|
"@platforms//os:macos": MAC_COMMON_COPTS,
|
||||||
|
"//conditions:default": None,
|
||||||
|
}) + select({
|
||||||
|
"@cef//:windows_opt": WIN_COMMON_COPTS_RELEASE,
|
||||||
|
"@cef//:windows_dbg": WIN_COMMON_COPTS_DEBUG,
|
||||||
|
"@cef//:windows_fastbuild": WIN_COMMON_COPTS_RELEASE,
|
||||||
|
"@cef//:linux_opt": LINUX_COMMON_COPTS_RELEASE,
|
||||||
|
"@cef//:linux_dbg": LINUX_COMMON_COPTS_DEBUG,
|
||||||
|
"@cef//:linux_fastbuild": LINUX_COMMON_COPTS_RELEASE,
|
||||||
|
"@cef//:macos_opt": MAC_COMMON_COPTS_RELEASE,
|
||||||
|
"@cef//:macos_dbg": MAC_COMMON_COPTS_DEBUG,
|
||||||
|
"@cef//:macos_fastbuild": MAC_COMMON_COPTS_RELEASE,
|
||||||
|
"//conditions:default": None,
|
||||||
|
}) + copts,
|
||||||
|
local_defines = select({
|
||||||
|
"@platforms//os:windows": WIN_COMMON_DEFINES,
|
||||||
|
"@platforms//os:linux": LINUX_COMMON_DEFINES,
|
||||||
|
"//conditions:default": None,
|
||||||
|
}) + select({
|
||||||
|
"@cef//:windows_opt": WIN_COMMON_DEFINES_RELEASE,
|
||||||
|
"@cef//:windows_dbg": WIN_COMMON_DEFINES_DEBUG,
|
||||||
|
"@cef//:windows_fastbuild": WIN_COMMON_DEFINES_RELEASE,
|
||||||
|
"@cef//:linux_opt": LINUX_COMMON_DEFINES_RELEASE,
|
||||||
|
"@cef//:linux_dbg": LINUX_COMMON_DEFINES_DEBUG,
|
||||||
|
"@cef//:linux_fastbuild": LINUX_COMMON_DEFINES_RELEASE,
|
||||||
|
"//conditions:default": None,
|
||||||
|
}) + local_defines,
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
|
def declare_objc_library(copts=[], **kwargs):
|
||||||
|
"""
|
||||||
|
objc_library wrapper that applies common copts.
|
||||||
|
"""
|
||||||
|
# NOTE: objc_library does not support local_defines on MacOS, so on
|
||||||
|
# that platform we put the defines in copts instead.
|
||||||
|
objc_library(
|
||||||
|
copts = select({
|
||||||
|
"@platforms//os:windows": WIN_COMMON_COPTS,
|
||||||
|
"@platforms//os:linux": LINUX_COMMON_COPTS,
|
||||||
|
"@platforms//os:macos": MAC_COMMON_COPTS,
|
||||||
|
"//conditions:default": None,
|
||||||
|
}) + select({
|
||||||
|
"@cef//:windows_opt": WIN_COMMON_COPTS_RELEASE,
|
||||||
|
"@cef//:windows_dbg": WIN_COMMON_COPTS_DEBUG,
|
||||||
|
"@cef//:windows_fastbuild": WIN_COMMON_COPTS_RELEASE,
|
||||||
|
"@cef//:linux_opt": LINUX_COMMON_COPTS_RELEASE,
|
||||||
|
"@cef//:linux_dbg": LINUX_COMMON_COPTS_DEBUG,
|
||||||
|
"@cef//:linux_fastbuild": LINUX_COMMON_COPTS_RELEASE,
|
||||||
|
"@cef//:macos_opt": MAC_COMMON_COPTS_RELEASE,
|
||||||
|
"@cef//:macos_dbg": MAC_COMMON_COPTS_DEBUG,
|
||||||
|
"@cef//:macos_fastbuild": MAC_COMMON_COPTS_RELEASE,
|
||||||
|
"//conditions:default": None,
|
||||||
|
}) + copts,
|
||||||
|
**kwargs
|
||||||
|
)
|
8
bazel/linux/BUILD.bazel
Executable file
8
bazel/linux/BUILD.bazel
Executable file
@@ -0,0 +1,8 @@
|
|||||||
|
# Copyright (c) 2024 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.
|
||||||
|
|
||||||
|
# Allow access from targets in other packages.
|
||||||
|
package(default_visibility = [
|
||||||
|
"//visibility:public",
|
||||||
|
])
|
63
bazel/linux/exe_helpers.bzl
Executable file
63
bazel/linux/exe_helpers.bzl
Executable file
@@ -0,0 +1,63 @@
|
|||||||
|
# Copyright (c) 2024 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.
|
||||||
|
|
||||||
|
load("//bazel:copy_filegroups.bzl", "copy_filegroups")
|
||||||
|
load("//bazel/linux:fix_rpath.bzl", "fix_rpath")
|
||||||
|
load("//bazel/linux:variables.bzl",
|
||||||
|
"COMMON_LINKOPTS",
|
||||||
|
"COMMON_COPTS", "COMMON_COPTS_RELEASE", "COMMON_COPTS_DEBUG",
|
||||||
|
"COMMON_DEFINES", "COMMON_DEFINES_RELEASE", "COMMON_DEFINES_DEBUG")
|
||||||
|
load("@rules_cc//cc:defs.bzl", "cc_binary")
|
||||||
|
|
||||||
|
def declare_exe(name, srcs=[], deps=[], linkopts=[], copts=[], local_defines=[], data=[], **kwargs):
|
||||||
|
# Copy SOs and resources into the current project.
|
||||||
|
copy_target = "{}_sos_and_resources".format(name)
|
||||||
|
copy_filegroups(
|
||||||
|
name = copy_target,
|
||||||
|
filegroups = [
|
||||||
|
"@cef//:sos",
|
||||||
|
"@cef//:resources",
|
||||||
|
],
|
||||||
|
remove_prefixes = [
|
||||||
|
"Debug",
|
||||||
|
"Release",
|
||||||
|
"Resources",
|
||||||
|
],
|
||||||
|
)
|
||||||
|
|
||||||
|
# Executable target.
|
||||||
|
binary_target = "{}_incorrect_rpath".format(name)
|
||||||
|
cc_binary(
|
||||||
|
name = binary_target,
|
||||||
|
srcs = srcs,
|
||||||
|
deps = [
|
||||||
|
"@cef//:cef_wrapper",
|
||||||
|
"@cef//:cef",
|
||||||
|
"@cef//:cef_sandbox",
|
||||||
|
] + deps,
|
||||||
|
linkopts = COMMON_LINKOPTS + linkopts,
|
||||||
|
copts = COMMON_COPTS + select({
|
||||||
|
"@cef//:linux_dbg": COMMON_COPTS_DEBUG,
|
||||||
|
"//conditions:default": COMMON_COPTS_RELEASE,
|
||||||
|
}) + copts,
|
||||||
|
local_defines = COMMON_DEFINES + select({
|
||||||
|
"@cef//:linux_dbg": COMMON_DEFINES_DEBUG,
|
||||||
|
"//conditions:default": COMMON_DEFINES_RELEASE,
|
||||||
|
}) + local_defines,
|
||||||
|
data = [
|
||||||
|
":{}".format(copy_target),
|
||||||
|
] + data,
|
||||||
|
target_compatible_with = ["@platforms//os:linux"],
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
|
# Set rpath to $ORIGIN so that libraries can be loaded from next to the
|
||||||
|
# executable.
|
||||||
|
fix_rpath(
|
||||||
|
name = "{}_fixed_rpath".format(name),
|
||||||
|
src = ":{}".format(binary_target),
|
||||||
|
out = name,
|
||||||
|
target_compatible_with = ["@platforms//os:linux"],
|
||||||
|
)
|
||||||
|
|
41
bazel/linux/fix_rpath.bzl
Normal file
41
bazel/linux/fix_rpath.bzl
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
# Copyright (c) 2024 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.
|
||||||
|
|
||||||
|
def _fix_rpath_impl(ctx):
|
||||||
|
inputs = ctx.runfiles(files = [ctx.file.src])
|
||||||
|
# Bring over 'data' dependencies from the input.
|
||||||
|
inputs = inputs.merge_all([ctx.attr.src[DefaultInfo].default_runfiles])
|
||||||
|
|
||||||
|
src = ctx.file.src.path
|
||||||
|
out = ctx.outputs.out.path
|
||||||
|
|
||||||
|
ctx.actions.run_shell(
|
||||||
|
outputs = [ctx.outputs.out],
|
||||||
|
inputs = inputs.files,
|
||||||
|
arguments = [src, out],
|
||||||
|
command = "cp $1 $2 && " +
|
||||||
|
"chmod +w $2 && " +
|
||||||
|
"patchelf --remove-rpath $2 && " +
|
||||||
|
"patchelf --set-rpath '$ORIGIN' $2"
|
||||||
|
)
|
||||||
|
|
||||||
|
return [DefaultInfo(files = depset([ctx.outputs.out]))]
|
||||||
|
|
||||||
|
# Set rpath to $ORIGIN so that libraries can be loaded from next to the
|
||||||
|
# executable. The result can be confirmed with:
|
||||||
|
# $ objdump -x ./bazel-bin/path/to/binary | grep 'R.*PATH'
|
||||||
|
#
|
||||||
|
# Alternatively, define a custom CC toolchain that overrides
|
||||||
|
# 'runtime_library_search_directories'.
|
||||||
|
#
|
||||||
|
# This rule requires preinstallation of the patchelf package:
|
||||||
|
# $ sudo apt install patchelf
|
||||||
|
fix_rpath = rule(
|
||||||
|
implementation = _fix_rpath_impl,
|
||||||
|
attrs = {
|
||||||
|
"src": attr.label(allow_single_file = True),
|
||||||
|
"out": attr.output(mandatory = True),
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
7
bazel/linux/pkg_config/BUILD.bazel
Normal file
7
bazel/linux/pkg_config/BUILD.bazel
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
package(default_visibility = ["//visibility:public"])
|
||||||
|
|
||||||
|
exports_files([
|
||||||
|
"pkg_config.bzl",
|
||||||
|
"BUILD.tmpl",
|
||||||
|
])
|
||||||
|
|
32
bazel/linux/pkg_config/BUILD.tmpl
Normal file
32
bazel/linux/pkg_config/BUILD.tmpl
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
# vi: ft=bzl
|
||||||
|
package(default_visibility = ["//visibility:private"])
|
||||||
|
|
||||||
|
_imports = [p[:len(p)-2] for p in glob(["{}/**/*.a".format(d) for d in [%{deps}]])]
|
||||||
|
[cc_import(
|
||||||
|
name = i.replace("/", "_"),
|
||||||
|
hdrs = glob([%{hdrs}]),
|
||||||
|
# TODO: library extension for platform.
|
||||||
|
static_library = "{}.a".format(i),
|
||||||
|
shared_library = "{}.dylib".format(i),
|
||||||
|
) for i in _imports]
|
||||||
|
|
||||||
|
cc_library(
|
||||||
|
name = "internal_lib",
|
||||||
|
hdrs = glob([%{hdrs}]),
|
||||||
|
copts = [%{copts}],
|
||||||
|
includes = [%{includes}],
|
||||||
|
linkopts = [%{linkopts}],
|
||||||
|
deps = [(":" + i.replace("/", "_")) for i in _imports],
|
||||||
|
)
|
||||||
|
|
||||||
|
cc_library(
|
||||||
|
name = "lib",
|
||||||
|
hdrs = glob(["%{strip_include}/**/*.h"]),
|
||||||
|
copts = [%{extra_copts}],
|
||||||
|
linkopts = [%{extra_linkopts}],
|
||||||
|
deps = [":internal_lib"] + [%{extra_deps}],
|
||||||
|
visibility = ["//visibility:public"],
|
||||||
|
strip_include_prefix = "%{strip_include}",
|
||||||
|
include_prefix = "%{include_prefix}",
|
||||||
|
)
|
||||||
|
|
11
bazel/linux/pkg_config/README.cef
Normal file
11
bazel/linux/pkg_config/README.cef
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
Name: pkg_config
|
||||||
|
URL: https://github.com/cherrry/bazel_pkg_config
|
||||||
|
Version: 284219a
|
||||||
|
|
||||||
|
Description:
|
||||||
|
Bazel rules for pkg-config tools.
|
||||||
|
|
||||||
|
CEF-specific changes:
|
||||||
|
- Fix failure with duplicate symlinks.
|
||||||
|
- Remove `--static` flag from pkg-config invocation.
|
||||||
|
|
2
bazel/linux/pkg_config/WORKSPACE
Normal file
2
bazel/linux/pkg_config/WORKSPACE
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
workspace(name = "pkg_config")
|
||||||
|
|
194
bazel/linux/pkg_config/pkg_config.bzl
Normal file
194
bazel/linux/pkg_config/pkg_config.bzl
Normal file
@@ -0,0 +1,194 @@
|
|||||||
|
def _success(value):
|
||||||
|
return struct(error = None, value = value)
|
||||||
|
|
||||||
|
def _error(message):
|
||||||
|
return struct(error = message, value = None)
|
||||||
|
|
||||||
|
def _split(result, delimeter = " "):
|
||||||
|
if result.error != None:
|
||||||
|
return result
|
||||||
|
return _success([arg for arg in result.value.strip().split(delimeter) if arg])
|
||||||
|
|
||||||
|
def _find_binary(ctx, binary_name):
|
||||||
|
binary = ctx.which(binary_name)
|
||||||
|
if binary == None:
|
||||||
|
return _error("Unable to find binary: {}".format(binary_name))
|
||||||
|
return _success(binary)
|
||||||
|
|
||||||
|
def _execute(ctx, binary, args):
|
||||||
|
result = ctx.execute([binary] + args)
|
||||||
|
if result.return_code != 0:
|
||||||
|
return _error("Failed execute {} {}".format(binary, args))
|
||||||
|
return _success(result.stdout)
|
||||||
|
|
||||||
|
def _pkg_config(ctx, pkg_config, pkg_name, args):
|
||||||
|
return _execute(ctx, pkg_config, [pkg_name] + args)
|
||||||
|
|
||||||
|
def _check(ctx, pkg_config, pkg_name):
|
||||||
|
exist = _pkg_config(ctx, pkg_config, pkg_name, ["--exists"])
|
||||||
|
if exist.error != None:
|
||||||
|
return _error("Package {} does not exist".format(pkg_name))
|
||||||
|
|
||||||
|
if ctx.attr.version != "":
|
||||||
|
version = _pkg_config(ctx, pkg_config, pkg_name, ["--exact-version", ctx.attr.version])
|
||||||
|
if version.error != None:
|
||||||
|
return _error("Require {} version = {}".format(pkg_name, ctx.attr.version))
|
||||||
|
|
||||||
|
if ctx.attr.min_version != "":
|
||||||
|
version = _pkg_config(ctx, pkg_config, pkg_name, ["--atleast-version", ctx.attr.min_version])
|
||||||
|
if version.error != None:
|
||||||
|
return _error("Require {} version >= {}".format(pkg_name, ctx.attr.min_version))
|
||||||
|
|
||||||
|
if ctx.attr.max_version != "":
|
||||||
|
version = _pkg_config(ctx, pkg_config, pkg_name, ["--max-version", ctx.attr.max_version])
|
||||||
|
if version.error != None:
|
||||||
|
return _error("Require {} version <= {}".format(pkg_name, ctx.attr.max_version))
|
||||||
|
|
||||||
|
return _success(None)
|
||||||
|
|
||||||
|
def _extract_prefix(flags, prefix, strip = True):
|
||||||
|
stripped, remain = [], []
|
||||||
|
for arg in flags:
|
||||||
|
if arg.startswith(prefix):
|
||||||
|
if strip:
|
||||||
|
stripped += [arg[len(prefix):]]
|
||||||
|
else:
|
||||||
|
stripped += [arg]
|
||||||
|
else:
|
||||||
|
remain += [arg]
|
||||||
|
return stripped, remain
|
||||||
|
|
||||||
|
def _includes(ctx, pkg_config, pkg_name):
|
||||||
|
includes = _split(_pkg_config(ctx, pkg_config, pkg_name, ["--cflags-only-I"]))
|
||||||
|
if includes.error != None:
|
||||||
|
return includes
|
||||||
|
includes, unused = _extract_prefix(includes.value, "-I", strip = True)
|
||||||
|
return _success(includes)
|
||||||
|
|
||||||
|
def _copts(ctx, pkg_config, pkg_name):
|
||||||
|
return _split(_pkg_config(ctx, pkg_config, pkg_name, [
|
||||||
|
"--cflags-only-other",
|
||||||
|
"--libs-only-L",
|
||||||
|
]))
|
||||||
|
|
||||||
|
def _linkopts(ctx, pkg_config, pkg_name):
|
||||||
|
return _split(_pkg_config(ctx, pkg_config, pkg_name, [
|
||||||
|
"--libs-only-other",
|
||||||
|
"--libs-only-l",
|
||||||
|
]))
|
||||||
|
|
||||||
|
def _ignore_opts(opts, ignore_opts):
|
||||||
|
remain = []
|
||||||
|
for opt in opts:
|
||||||
|
if opt not in ignore_opts:
|
||||||
|
remain += [opt]
|
||||||
|
return remain
|
||||||
|
|
||||||
|
def _symlinks(ctx, basename, srcpaths):
|
||||||
|
result = []
|
||||||
|
root = ctx.path("")
|
||||||
|
base = root.get_child(basename)
|
||||||
|
rootlen = len(str(base)) - len(basename)
|
||||||
|
for src in [ctx.path(p) for p in srcpaths]:
|
||||||
|
dest = base.get_child(src.basename)
|
||||||
|
if not dest.exists:
|
||||||
|
ctx.symlink(src, dest)
|
||||||
|
result += [str(dest)[rootlen:]]
|
||||||
|
return result
|
||||||
|
|
||||||
|
def _deps(ctx, pkg_config, pkg_name):
|
||||||
|
deps = _split(_pkg_config(ctx, pkg_config, pkg_name, [
|
||||||
|
"--libs-only-L",
|
||||||
|
"--static",
|
||||||
|
]))
|
||||||
|
if deps.error != None:
|
||||||
|
return deps
|
||||||
|
deps, unused = _extract_prefix(deps.value, "-L", strip = True)
|
||||||
|
result = []
|
||||||
|
for dep in {dep: True for dep in deps}.keys():
|
||||||
|
base = "deps_" + dep.replace("/", "_").replace(".", "_")
|
||||||
|
result += _symlinks(ctx, base, [dep])
|
||||||
|
return _success(result)
|
||||||
|
|
||||||
|
def _fmt_array(array):
|
||||||
|
return ",".join(['"{}"'.format(a) for a in array])
|
||||||
|
|
||||||
|
def _fmt_glob(array):
|
||||||
|
return _fmt_array(["{}/**/*.h".format(a) for a in array])
|
||||||
|
|
||||||
|
def _pkg_config_impl(ctx):
|
||||||
|
pkg_name = ctx.attr.pkg_name
|
||||||
|
if pkg_name == "":
|
||||||
|
pkg_name = ctx.attr.name
|
||||||
|
|
||||||
|
pkg_config = _find_binary(ctx, "pkg-config")
|
||||||
|
if pkg_config.error != None:
|
||||||
|
return pkg_config
|
||||||
|
pkg_config = pkg_config.value
|
||||||
|
|
||||||
|
check = _check(ctx, pkg_config, pkg_name)
|
||||||
|
if check.error != None:
|
||||||
|
return check
|
||||||
|
|
||||||
|
includes = _includes(ctx, pkg_config, pkg_name)
|
||||||
|
if includes.error != None:
|
||||||
|
return includes
|
||||||
|
includes = includes.value
|
||||||
|
includes = _symlinks(ctx, "includes", includes)
|
||||||
|
strip_include = "includes"
|
||||||
|
if len(includes) == 1:
|
||||||
|
strip_include = includes[0]
|
||||||
|
if ctx.attr.strip_include != "":
|
||||||
|
strip_include += "/" + ctx.attr.strip_include
|
||||||
|
|
||||||
|
ignore_opts = ctx.attr.ignore_opts
|
||||||
|
copts = _copts(ctx, pkg_config, pkg_name)
|
||||||
|
if copts.error != None:
|
||||||
|
return copts
|
||||||
|
copts = _ignore_opts(copts.value, ignore_opts)
|
||||||
|
|
||||||
|
linkopts = _linkopts(ctx, pkg_config, pkg_name)
|
||||||
|
if linkopts.error != None:
|
||||||
|
return linkopts
|
||||||
|
linkopts = _ignore_opts(linkopts.value, ignore_opts)
|
||||||
|
|
||||||
|
deps = _deps(ctx, pkg_config, pkg_name)
|
||||||
|
if deps.error != None:
|
||||||
|
return deps
|
||||||
|
deps = deps.value
|
||||||
|
|
||||||
|
include_prefix = ctx.attr.name
|
||||||
|
if ctx.attr.include_prefix != "":
|
||||||
|
include_prefix = ctx.attr.include_prefix + "/" + ctx.attr.name
|
||||||
|
|
||||||
|
build = ctx.template("BUILD", Label("//:BUILD.tmpl"), substitutions = {
|
||||||
|
"%{name}": ctx.attr.name,
|
||||||
|
"%{hdrs}": _fmt_glob(includes),
|
||||||
|
"%{includes}": _fmt_array(includes),
|
||||||
|
"%{copts}": _fmt_array(copts),
|
||||||
|
"%{extra_copts}": _fmt_array(ctx.attr.copts),
|
||||||
|
"%{deps}": _fmt_array(deps),
|
||||||
|
"%{extra_deps}": _fmt_array(ctx.attr.deps),
|
||||||
|
"%{linkopts}": _fmt_array(linkopts),
|
||||||
|
"%{extra_linkopts}": _fmt_array(ctx.attr.linkopts),
|
||||||
|
"%{strip_include}": strip_include,
|
||||||
|
"%{include_prefix}": include_prefix,
|
||||||
|
}, executable = False)
|
||||||
|
|
||||||
|
pkg_config = repository_rule(
|
||||||
|
attrs = {
|
||||||
|
"pkg_name": attr.string(doc = "Package name for pkg-config query, default to name."),
|
||||||
|
"include_prefix": attr.string(doc = "Additional prefix when including file, e.g. third_party. Compatible with strip_include option to produce desired include paths."),
|
||||||
|
"strip_include": attr.string(doc = "Strip prefix when including file, e.g. libs, files not included will be invisible. Compatible with include_prefix option to produce desired include paths."),
|
||||||
|
"version": attr.string(doc = "Exact package version."),
|
||||||
|
"min_version": attr.string(doc = "Minimum package version."),
|
||||||
|
"max_version": attr.string(doc = "Maximum package version."),
|
||||||
|
"deps": attr.string_list(doc = "Dependency targets."),
|
||||||
|
"linkopts": attr.string_list(doc = "Extra linkopts value."),
|
||||||
|
"copts": attr.string_list(doc = "Extra copts value."),
|
||||||
|
"ignore_opts": attr.string_list(doc = "Ignore listed opts in copts or linkopts."),
|
||||||
|
},
|
||||||
|
local = True,
|
||||||
|
implementation = _pkg_config_impl,
|
||||||
|
)
|
||||||
|
|
68
bazel/linux/variables.bzl
Executable file
68
bazel/linux/variables.bzl
Executable file
@@ -0,0 +1,68 @@
|
|||||||
|
# Copyright (c) 2024 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.
|
||||||
|
|
||||||
|
#
|
||||||
|
# Distribution SOs.
|
||||||
|
#
|
||||||
|
|
||||||
|
SOS = [
|
||||||
|
"libcef.so",
|
||||||
|
"libEGL.so",
|
||||||
|
"libGLESv2.so",
|
||||||
|
"libvk_swiftshader.so",
|
||||||
|
"libvulkan.so.1",
|
||||||
|
]
|
||||||
|
|
||||||
|
#
|
||||||
|
# Common 'linkopts' for cc_binary targets.
|
||||||
|
#
|
||||||
|
|
||||||
|
# Standard link libraries.
|
||||||
|
STANDARD_LIBS = [
|
||||||
|
"X11",
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_LINKOPTS_DEBUG = [
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_LINKOPTS_RELEASE = [
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_LINKOPTS = [
|
||||||
|
"-l{}".format(lib) for lib in STANDARD_LIBS
|
||||||
|
] + select({
|
||||||
|
"@cef//:linux_dbg": COMMON_LINKOPTS_DEBUG,
|
||||||
|
"//conditions:default": COMMON_LINKOPTS_RELEASE,
|
||||||
|
})
|
||||||
|
|
||||||
|
#
|
||||||
|
# Common 'copts' for cc_libary and cc_binary targets.
|
||||||
|
#
|
||||||
|
|
||||||
|
COMMON_COPTS = [
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_COPTS_DEBUG = [
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_COPTS_RELEASE = [
|
||||||
|
]
|
||||||
|
|
||||||
|
#
|
||||||
|
# Common 'defines' for cc_libary targets.
|
||||||
|
#
|
||||||
|
|
||||||
|
COMMON_DEFINES = [
|
||||||
|
# Used by apps to test if the sandbox is enabled
|
||||||
|
"CEF_USE_SANDBOX",
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_DEFINES_DEBUG = [
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_DEFINES_RELEASE = [
|
||||||
|
# Not a debug build
|
||||||
|
"NDEBUG",
|
||||||
|
]
|
||||||
|
|
8
bazel/mac/BUILD.bazel
Normal file
8
bazel/mac/BUILD.bazel
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
# Copyright (c) 2024 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.
|
||||||
|
|
||||||
|
# Allow access from targets in other packages.
|
||||||
|
package(default_visibility = [
|
||||||
|
"//visibility:public",
|
||||||
|
])
|
113
bazel/mac/app_helpers.bzl
Normal file
113
bazel/mac/app_helpers.bzl
Normal file
@@ -0,0 +1,113 @@
|
|||||||
|
# Copyright (c) 2024 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.
|
||||||
|
|
||||||
|
load("@bazel_skylib//rules:expand_template.bzl", "expand_template")
|
||||||
|
load("@build_bazel_rules_apple//apple:macos.bzl", "macos_application")
|
||||||
|
load("//bazel:variables.bzl", "VERSION_PLIST")
|
||||||
|
load("//bazel/mac:variables.bzl",
|
||||||
|
"MACOS_DEPLOYMENT_TARGET",
|
||||||
|
"MACOS_BUNDLE_ID_BASE",
|
||||||
|
"CEF_FRAMEWORK_NAME",
|
||||||
|
"COMMON_LINKOPTS")
|
||||||
|
|
||||||
|
def _declare_helper_app(name, info_plist, deps, helper_base_name, helper_suffix, **kwargs):
|
||||||
|
"""
|
||||||
|
Creates a Helper .app target.
|
||||||
|
"""
|
||||||
|
helper_name = "{} Helper".format(name)
|
||||||
|
bundle_id_suffix = ""
|
||||||
|
|
||||||
|
if helper_suffix:
|
||||||
|
helper_name += " ({})".format(helper_suffix)
|
||||||
|
bundle_id_suffix += ".{}".format(helper_suffix.lower())
|
||||||
|
|
||||||
|
# Helper app bundle Info.plist.
|
||||||
|
expand_template(
|
||||||
|
name = "{}_InfoPList".format(helper_base_name),
|
||||||
|
template = info_plist,
|
||||||
|
out = "{}Info.plist".format(helper_base_name),
|
||||||
|
substitutions = {
|
||||||
|
"${EXECUTABLE_NAME}": helper_name,
|
||||||
|
"${PRODUCT_NAME}": name,
|
||||||
|
"${BUNDLE_ID_SUFFIX}": bundle_id_suffix,
|
||||||
|
"${VERSION_SHORT}": VERSION_PLIST,
|
||||||
|
"${VERSION_LONG}": VERSION_PLIST,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
|
# Helper app bundle.
|
||||||
|
macos_application(
|
||||||
|
name = helper_base_name,
|
||||||
|
bundle_name = helper_name,
|
||||||
|
bundle_id = "{}.{}.helper{}".format(MACOS_BUNDLE_ID_BASE, name.lower(), bundle_id_suffix),
|
||||||
|
infoplists = [":{}_InfoPList".format(helper_base_name)],
|
||||||
|
minimum_os_version = MACOS_DEPLOYMENT_TARGET,
|
||||||
|
deps = [
|
||||||
|
"@cef//:cef_sandbox",
|
||||||
|
] + deps,
|
||||||
|
**kwargs,
|
||||||
|
)
|
||||||
|
|
||||||
|
HELPERS = {
|
||||||
|
"HelperBase": "",
|
||||||
|
"HelperAlerts": "Alerts",
|
||||||
|
"HelperGPU": "GPU",
|
||||||
|
"HelperPlugin": "Plugin",
|
||||||
|
"HelperRenderer": "Renderer",
|
||||||
|
}
|
||||||
|
|
||||||
|
def declare_all_helper_apps(name, info_plist, deps, **kwargs):
|
||||||
|
"""
|
||||||
|
Creates all Helper .app targets.
|
||||||
|
"""
|
||||||
|
[_declare_helper_app(
|
||||||
|
name = name,
|
||||||
|
info_plist = info_plist,
|
||||||
|
deps = deps,
|
||||||
|
helper_base_name = h,
|
||||||
|
helper_suffix = v,
|
||||||
|
**kwargs,
|
||||||
|
) for h, v in HELPERS.items()]
|
||||||
|
|
||||||
|
def declare_main_app(name, info_plist, deps, resources, linkopts=[], **kwargs):
|
||||||
|
"""
|
||||||
|
Creates the main .app target.
|
||||||
|
"""
|
||||||
|
|
||||||
|
# Main app bundle Info.plist.
|
||||||
|
expand_template(
|
||||||
|
name = "InfoPList",
|
||||||
|
template = info_plist,
|
||||||
|
out = "Info.plist",
|
||||||
|
substitutions = {
|
||||||
|
"${EXECUTABLE_NAME}": name,
|
||||||
|
"${PRODUCT_NAME}": name,
|
||||||
|
"${VERSION_SHORT}": VERSION_PLIST,
|
||||||
|
"${VERSION_LONG}": VERSION_PLIST,
|
||||||
|
},
|
||||||
|
)
|
||||||
|
|
||||||
|
# Main app bindle.
|
||||||
|
macos_application(
|
||||||
|
name = name,
|
||||||
|
additional_contents = {
|
||||||
|
":HelperBase": "Frameworks",
|
||||||
|
":HelperAlerts": "Frameworks",
|
||||||
|
":HelperGPU": "Frameworks",
|
||||||
|
":HelperPlugin": "Frameworks",
|
||||||
|
":HelperRenderer": "Frameworks",
|
||||||
|
"@cef//:cef_framework": "Frameworks/{}.framework".format(CEF_FRAMEWORK_NAME),
|
||||||
|
},
|
||||||
|
bundle_name = name,
|
||||||
|
bundle_id = "{}.{}".format(MACOS_BUNDLE_ID_BASE, name.lower()),
|
||||||
|
infoplists = [":InfoPList"],
|
||||||
|
linkopts = COMMON_LINKOPTS + linkopts,
|
||||||
|
minimum_os_version = MACOS_DEPLOYMENT_TARGET,
|
||||||
|
resources = resources,
|
||||||
|
target_compatible_with = [
|
||||||
|
"@platforms//os:macos",
|
||||||
|
],
|
||||||
|
deps = deps,
|
||||||
|
**kwargs,
|
||||||
|
)
|
52
bazel/mac/variables.bzl
Normal file
52
bazel/mac/variables.bzl
Normal file
@@ -0,0 +1,52 @@
|
|||||||
|
# Copyright (c) 2024 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.
|
||||||
|
|
||||||
|
MACOS_DEPLOYMENT_TARGET="10.15"
|
||||||
|
MACOS_BUNDLE_ID_BASE="org.cef"
|
||||||
|
CEF_FRAMEWORK_NAME="Chromium Embedded Framework"
|
||||||
|
|
||||||
|
#
|
||||||
|
# Common 'linkopts' for macos_application targets.
|
||||||
|
#
|
||||||
|
|
||||||
|
# Standard link frameworks.
|
||||||
|
STANDARD_FRAMEWORKS = [
|
||||||
|
"AppKit",
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_LINKOPTS_DEBUG = [
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_LINKOPTS_RELEASE = [
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_LINKOPTS = [
|
||||||
|
"-framework {}".format(lib) for lib in STANDARD_FRAMEWORKS
|
||||||
|
] + select({
|
||||||
|
"@cef//:macos_dbg": COMMON_LINKOPTS_DEBUG,
|
||||||
|
"//conditions:default": COMMON_LINKOPTS_RELEASE,
|
||||||
|
})
|
||||||
|
|
||||||
|
#
|
||||||
|
# Common 'copts' for cc_libary, objc_library and macos_application targets.
|
||||||
|
# We include defines in 'copts' because objc_library does not support
|
||||||
|
# 'local_defines'. See https://github.com/bazelbuild/bazel/issues/17482.
|
||||||
|
#
|
||||||
|
|
||||||
|
COMMON_COPTS = [
|
||||||
|
"-Wno-undefined-var-template",
|
||||||
|
"-Wno-missing-field-initializers",
|
||||||
|
"-Wno-deprecated-copy",
|
||||||
|
|
||||||
|
# Used by apps to test if the sandbox is enabled
|
||||||
|
"-DCEF_USE_SANDBOX",
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_COPTS_DEBUG = [
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_COPTS_RELEASE = [
|
||||||
|
# Not a debug build
|
||||||
|
"-DNDEBUG",
|
||||||
|
]
|
8
bazel/win/BUILD.bazel
Normal file
8
bazel/win/BUILD.bazel
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
# Copyright (c) 2024 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.
|
||||||
|
|
||||||
|
# Allow access from targets in other packages.
|
||||||
|
package(default_visibility = [
|
||||||
|
"//visibility:public",
|
||||||
|
])
|
33
bazel/win/cc_env.bzl
Normal file
33
bazel/win/cc_env.bzl
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
# Copyright (c) 2024 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.
|
||||||
|
|
||||||
|
load("@bazel_tools//tools/cpp:toolchain_utils.bzl", "find_cpp_toolchain", _use_cpp_toolchain="use_cpp_toolchain")
|
||||||
|
load("@rules_cc//cc:action_names.bzl", "CPP_COMPILE_ACTION_NAME")
|
||||||
|
|
||||||
|
# Since we need windows.h and other headers, we should ensure we have the same
|
||||||
|
# development environment as a regular cl.exe call. So use the current toolchain
|
||||||
|
# to grab environment variables to feed into the actual rc.exe call
|
||||||
|
# Much of this is taken from:
|
||||||
|
# https://github.com/bazelbuild/rules_cc/blob/main/examples/my_c_archive/my_c_archive.bzl
|
||||||
|
def collect_compilation_env(ctx):
|
||||||
|
cc_toolchain = find_cpp_toolchain(ctx)
|
||||||
|
feature_configuration = cc_common.configure_features(
|
||||||
|
ctx = ctx,
|
||||||
|
cc_toolchain = cc_toolchain,
|
||||||
|
requested_features = ctx.features,
|
||||||
|
unsupported_features = ctx.disabled_features,
|
||||||
|
)
|
||||||
|
|
||||||
|
compiler_variables = cc_common.create_compile_variables(
|
||||||
|
feature_configuration = feature_configuration,
|
||||||
|
cc_toolchain = cc_toolchain,
|
||||||
|
)
|
||||||
|
|
||||||
|
return cc_common.get_environment_variables(
|
||||||
|
feature_configuration = feature_configuration,
|
||||||
|
action_name = CPP_COMPILE_ACTION_NAME,
|
||||||
|
variables = compiler_variables,
|
||||||
|
)
|
||||||
|
|
||||||
|
use_cpp_toolchain=_use_cpp_toolchain
|
82
bazel/win/exe_helpers.bzl
Normal file
82
bazel/win/exe_helpers.bzl
Normal file
@@ -0,0 +1,82 @@
|
|||||||
|
# Copyright (c) 2024 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.
|
||||||
|
|
||||||
|
load("//bazel:copy_filegroups.bzl", "copy_filegroups")
|
||||||
|
load("//bazel/win:mt.bzl", "add_manifest")
|
||||||
|
load("//bazel/win:rc.bzl", "compile_rc")
|
||||||
|
load("//bazel/win:variables.bzl",
|
||||||
|
"COMMON_LINKOPTS",
|
||||||
|
"COMMON_COPTS", "COMMON_COPTS_RELEASE", "COMMON_COPTS_DEBUG",
|
||||||
|
"COMMON_DEFINES", "COMMON_DEFINES_RELEASE", "COMMON_DEFINES_DEBUG")
|
||||||
|
load("@rules_cc//cc:defs.bzl", "cc_binary")
|
||||||
|
|
||||||
|
def declare_exe(name, srcs, manifest_srcs, rc_file, resources_srcs, resources_deps=[],
|
||||||
|
deps=[], linkopts=[], copts=[], local_defines=[], data=[],
|
||||||
|
additional_linker_inputs=[], features=[], **kwargs):
|
||||||
|
# Resource file.
|
||||||
|
res_target = "{}_res".format(name)
|
||||||
|
compile_rc(
|
||||||
|
name = res_target,
|
||||||
|
rc_file = rc_file,
|
||||||
|
srcs = resources_srcs,
|
||||||
|
deps = resources_deps,
|
||||||
|
out = "{}.res".format(name),
|
||||||
|
target_compatible_with = ["@platforms//os:windows"],
|
||||||
|
)
|
||||||
|
|
||||||
|
# Copy DLLs and resources into the current project.
|
||||||
|
copy_target = "{}_dlls_and_resources".format(name)
|
||||||
|
copy_filegroups(
|
||||||
|
name = copy_target,
|
||||||
|
filegroups = [
|
||||||
|
"@cef//:dlls",
|
||||||
|
"@cef//:resources",
|
||||||
|
],
|
||||||
|
remove_prefixes = [
|
||||||
|
"Debug",
|
||||||
|
"Release",
|
||||||
|
"Resources",
|
||||||
|
],
|
||||||
|
)
|
||||||
|
|
||||||
|
# Executable target.
|
||||||
|
binary_target = "{}_no_manifest".format(name)
|
||||||
|
cc_binary(
|
||||||
|
name = binary_target,
|
||||||
|
srcs = srcs,
|
||||||
|
deps = [
|
||||||
|
"@cef//:cef_wrapper",
|
||||||
|
"@cef//:cef",
|
||||||
|
"@cef//:cef_sandbox",
|
||||||
|
] + deps,
|
||||||
|
linkopts = [
|
||||||
|
"$(location :{})".format(res_target),
|
||||||
|
] + COMMON_LINKOPTS + linkopts,
|
||||||
|
copts = COMMON_COPTS + select({
|
||||||
|
"@cef//:windows_dbg": COMMON_COPTS_DEBUG,
|
||||||
|
"//conditions:default": COMMON_COPTS_RELEASE,
|
||||||
|
}) + copts,
|
||||||
|
local_defines = COMMON_DEFINES + select({
|
||||||
|
"@cef//:windows_dbg": COMMON_DEFINES_DEBUG,
|
||||||
|
"//conditions:default": COMMON_DEFINES_RELEASE,
|
||||||
|
}) + local_defines,
|
||||||
|
additional_linker_inputs = [
|
||||||
|
":{}".format(res_target),
|
||||||
|
] + additional_linker_inputs,
|
||||||
|
data = [
|
||||||
|
":{}".format(copy_target),
|
||||||
|
] + data,
|
||||||
|
features = ["generate_pdb_file"] + features,
|
||||||
|
target_compatible_with = ["@platforms//os:windows"],
|
||||||
|
**kwargs
|
||||||
|
)
|
||||||
|
|
||||||
|
# Add manifest and rename to final executable.
|
||||||
|
add_manifest(
|
||||||
|
name = name,
|
||||||
|
mt_files = manifest_srcs,
|
||||||
|
in_binary = ":{}".format(binary_target),
|
||||||
|
out_binary = "{}.exe".format(name),
|
||||||
|
target_compatible_with = ["@platforms//os:windows"],
|
||||||
|
)
|
72
bazel/win/mt.bzl
Normal file
72
bazel/win/mt.bzl
Normal file
@@ -0,0 +1,72 @@
|
|||||||
|
# Copyright (c) 2024 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.
|
||||||
|
|
||||||
|
load("//bazel/win:cc_env.bzl", "collect_compilation_env", "use_cpp_toolchain")
|
||||||
|
|
||||||
|
# Copy exe and pdb file without tracking the destination as an output.
|
||||||
|
# Based on https://github.com/bazelbuild/bazel-skylib/blob/main/rules/private/copy_file_private.bzl
|
||||||
|
def _write_copy_cmd(ctx, src, dst):
|
||||||
|
# Most Windows binaries built with MSVC use a certain argument quoting
|
||||||
|
# scheme. Bazel uses that scheme too to quote arguments. However,
|
||||||
|
# cmd.exe uses different semantics, so Bazel's quoting is wrong here.
|
||||||
|
# To fix that we write the command to a .bat file so no command line
|
||||||
|
# quoting or escaping is required.
|
||||||
|
bat = ctx.actions.declare_file(ctx.label.name + "-cmd.bat")
|
||||||
|
src_path = src.path.replace("/", "\\")
|
||||||
|
dst_path = dst.path.replace("/", "\\")
|
||||||
|
ctx.actions.write(
|
||||||
|
output = bat,
|
||||||
|
# Do not use lib/shell.bzl's shell.quote() method, because that uses
|
||||||
|
# Bash quoting syntax, which is different from cmd.exe's syntax.
|
||||||
|
content = "@copy /Y \"%s\" \"%s\" >NUL\n@copy /Y \"%s\" \"%s\" >NUL" % (
|
||||||
|
src_path,
|
||||||
|
dst_path,
|
||||||
|
src_path.replace(".exe", ".pdb"),
|
||||||
|
dst_path.replace(".exe", ".pdb"),
|
||||||
|
),
|
||||||
|
is_executable = True,
|
||||||
|
)
|
||||||
|
return bat
|
||||||
|
|
||||||
|
def _add_mt_impl(ctx):
|
||||||
|
mt_files = ctx.files.mt_files
|
||||||
|
input = ctx.attr.in_binary[DebugPackageInfo].unstripped_file
|
||||||
|
output = ctx.outputs.out_binary
|
||||||
|
bat = _write_copy_cmd(ctx, input, output)
|
||||||
|
|
||||||
|
inputs = mt_files + [input, bat]
|
||||||
|
|
||||||
|
# Bring over 'data' dependencies from the input.
|
||||||
|
deps_inputs = ctx.runfiles(files = inputs)
|
||||||
|
deps_inputs = deps_inputs.merge_all([ctx.attr.in_binary[DefaultInfo].default_runfiles])
|
||||||
|
|
||||||
|
ctx.actions.run(
|
||||||
|
executable = ctx.executable._tool,
|
||||||
|
inputs = deps_inputs.files,
|
||||||
|
outputs = [output],
|
||||||
|
env = collect_compilation_env(ctx),
|
||||||
|
# The bat file will be executed before the tool command.
|
||||||
|
arguments = [bat.path, "-nologo", "-manifest"] + [f.path for f in mt_files] +
|
||||||
|
["-outputresource:{}".format(output.path)],
|
||||||
|
mnemonic = "AddMT"
|
||||||
|
)
|
||||||
|
|
||||||
|
return DefaultInfo(files = depset([output]))
|
||||||
|
|
||||||
|
add_manifest = rule(
|
||||||
|
implementation = _add_mt_impl,
|
||||||
|
attrs = {
|
||||||
|
"mt_files": attr.label_list(allow_files = [".manifest"]),
|
||||||
|
"in_binary": attr.label(providers = [CcInfo], allow_single_file = True),
|
||||||
|
"out_binary": attr.output(),
|
||||||
|
"_cc_toolchain": attr.label(default = Label("@bazel_tools//tools/cpp:current_cc_toolchain")),
|
||||||
|
"_tool": attr.label(
|
||||||
|
default = "@winsdk//:mt_pybin",
|
||||||
|
executable = True,
|
||||||
|
cfg = "exec"
|
||||||
|
)
|
||||||
|
},
|
||||||
|
fragments = ["cpp"],
|
||||||
|
toolchains = use_cpp_toolchain(),
|
||||||
|
)
|
50
bazel/win/rc.bzl
Normal file
50
bazel/win/rc.bzl
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
# Copyright (c) 2024 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.
|
||||||
|
|
||||||
|
load("//bazel/win:cc_env.bzl", "collect_compilation_env", "use_cpp_toolchain")
|
||||||
|
|
||||||
|
def _compile_rc_impl(ctx):
|
||||||
|
rc_file = ctx.file.rc_file
|
||||||
|
output = ctx.outputs.out
|
||||||
|
|
||||||
|
inputs = [rc_file] + ctx.files.srcs
|
||||||
|
includes = ["/i{}/{}".format(ctx.label.package, i) for i in ctx.attr.includes]
|
||||||
|
|
||||||
|
# Grab all include paths/files required for the run
|
||||||
|
for dep in ctx.attr.deps:
|
||||||
|
comp_ctx = dep[CcInfo].compilation_context
|
||||||
|
|
||||||
|
includes += ["/i{}".format(i) for i in comp_ctx.quote_includes.to_list()]
|
||||||
|
includes += ["/i{}".format(i) for i in comp_ctx.system_includes.to_list()]
|
||||||
|
inputs += comp_ctx.headers.to_list()
|
||||||
|
|
||||||
|
ctx.actions.run(
|
||||||
|
executable = ctx.executable._tool,
|
||||||
|
inputs = inputs,
|
||||||
|
outputs = [output],
|
||||||
|
env = collect_compilation_env(ctx),
|
||||||
|
arguments = includes + ["/fo", output.path, rc_file.path],
|
||||||
|
mnemonic = "CompileRC"
|
||||||
|
)
|
||||||
|
|
||||||
|
return DefaultInfo(files = depset([output]))
|
||||||
|
|
||||||
|
compile_rc = rule(
|
||||||
|
implementation = _compile_rc_impl,
|
||||||
|
attrs = {
|
||||||
|
"rc_file": attr.label(allow_single_file = [".rc"]),
|
||||||
|
"srcs": attr.label_list(allow_files = True),
|
||||||
|
"deps": attr.label_list(providers = [CcInfo]),
|
||||||
|
"includes": attr.string_list(),
|
||||||
|
"out": attr.output(),
|
||||||
|
"_cc_toolchain": attr.label(default = Label("@bazel_tools//tools/cpp:current_cc_toolchain")),
|
||||||
|
"_tool": attr.label(
|
||||||
|
default = "@winsdk//:rc_pybin",
|
||||||
|
executable = True,
|
||||||
|
cfg = "exec"
|
||||||
|
)
|
||||||
|
},
|
||||||
|
fragments = ["cpp"],
|
||||||
|
toolchains = use_cpp_toolchain(),
|
||||||
|
)
|
124
bazel/win/setup_sdk.bzl
Normal file
124
bazel/win/setup_sdk.bzl
Normal file
@@ -0,0 +1,124 @@
|
|||||||
|
# Copyright (c) 2024 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.
|
||||||
|
|
||||||
|
load("@bazel_tools//tools/cpp:windows_cc_configure.bzl", "find_vc_path", "setup_vc_env_vars")
|
||||||
|
|
||||||
|
def _get_arch(rctx):
|
||||||
|
if rctx.os.arch == "amd64":
|
||||||
|
return "x64"
|
||||||
|
|
||||||
|
def _is_windows(rctx):
|
||||||
|
return rctx.os.name.find("windows") != -1
|
||||||
|
|
||||||
|
# Tools in the form <Target>: [<Tool>, <Other files needed for that target>]
|
||||||
|
TOOLS = {
|
||||||
|
"mt": {
|
||||||
|
"tool": "mt.exe",
|
||||||
|
"deps": [],
|
||||||
|
},
|
||||||
|
"rc": {
|
||||||
|
"tool": "rc.exe",
|
||||||
|
"deps": ["rcdll.dll"],
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
def _setup_tools(rctx, sdk_bin_path, sdk_metadata_path):
|
||||||
|
contents = ""
|
||||||
|
|
||||||
|
rctx.symlink(sdk_metadata_path, "VerUnionMetadata")
|
||||||
|
contents += """
|
||||||
|
exports_files(["VerUnionMetadata"])
|
||||||
|
"""
|
||||||
|
|
||||||
|
for toolname, toolcfg in TOOLS.items():
|
||||||
|
toolexec = toolcfg["tool"]
|
||||||
|
deps = toolcfg["deps"]
|
||||||
|
direct_deps = [toolexec] + deps
|
||||||
|
shared_deps = toolcfg.get("shared_deps", [])
|
||||||
|
|
||||||
|
# Symlink any tools into the right places
|
||||||
|
for dep in direct_deps:
|
||||||
|
rctx.symlink(
|
||||||
|
"{}/{}".format(sdk_bin_path, dep),
|
||||||
|
dep,
|
||||||
|
)
|
||||||
|
|
||||||
|
# Setting up a filegroup for those dependents
|
||||||
|
contents += """
|
||||||
|
filegroup(
|
||||||
|
name = "{}_deps",
|
||||||
|
srcs = {},
|
||||||
|
)
|
||||||
|
""".format(toolname, direct_deps + shared_deps)
|
||||||
|
|
||||||
|
# Now create a wrapper for this tool that simply calls it
|
||||||
|
rctx.template(
|
||||||
|
"{}_wrapper.py".format(toolname),
|
||||||
|
Label("//bazel/win:wrapper.py.tpl"),
|
||||||
|
substitutions = {
|
||||||
|
"${binary}": toolexec,
|
||||||
|
},
|
||||||
|
executable = True,
|
||||||
|
)
|
||||||
|
|
||||||
|
# And add that newly created wrapper to the BUILD.bazel file
|
||||||
|
contents += """
|
||||||
|
py_binary(
|
||||||
|
name = "{0}_pybin",
|
||||||
|
srcs = ["{0}_wrapper.py"],
|
||||||
|
main = "{0}_wrapper.py",
|
||||||
|
data = [
|
||||||
|
"@rules_python//python/runfiles",
|
||||||
|
":{0}_deps"
|
||||||
|
],
|
||||||
|
python_version = "PY3",
|
||||||
|
)
|
||||||
|
""".format(toolname)
|
||||||
|
|
||||||
|
return contents
|
||||||
|
|
||||||
|
def _setup_vc_debug_runtime(rctx, sdk_bin_path):
|
||||||
|
ucrtbased_dll = "ucrtbased.dll"
|
||||||
|
rctx.symlink("{}/ucrt/{}".format(sdk_bin_path, ucrtbased_dll), ucrtbased_dll)
|
||||||
|
|
||||||
|
contents = """
|
||||||
|
filegroup(
|
||||||
|
name = "vc_debug_runtime",
|
||||||
|
srcs = ["{}"],
|
||||||
|
)
|
||||||
|
""".format(ucrtbased_dll)
|
||||||
|
|
||||||
|
return contents
|
||||||
|
|
||||||
|
def _windows_sdk_impl(rctx):
|
||||||
|
# We only support Windows
|
||||||
|
if not _is_windows(rctx):
|
||||||
|
fail("This rule only supports Windows")
|
||||||
|
|
||||||
|
# Figure out where the SDK is, which is based on a registry key.
|
||||||
|
vc_path = find_vc_path(rctx)
|
||||||
|
env = setup_vc_env_vars(rctx, vc_path, envvars = ["WINDOWSSDKVERBINPATH", "WindowsSdkDir", "WindowsSDKVersion"])
|
||||||
|
sdk_bin_path = "{}{}".format(env["WINDOWSSDKVERBINPATH"], _get_arch(rctx))
|
||||||
|
sdk_metadata_path = "{}UnionMetadata/{}".format(env["WindowsSdkDir"], env["WindowsSDKVersion"])
|
||||||
|
|
||||||
|
# Start with some pre-amble
|
||||||
|
contents = """# Autogenerated by //bazel/win:sdk.bzl
|
||||||
|
load("@rules_python//python:defs.bzl", "py_binary")
|
||||||
|
|
||||||
|
package(default_visibility = ["//visibility:public"])
|
||||||
|
"""
|
||||||
|
|
||||||
|
# Handle setting up tools from our list
|
||||||
|
contents += _setup_tools(rctx, sdk_bin_path, sdk_metadata_path)
|
||||||
|
|
||||||
|
contents += _setup_vc_debug_runtime(rctx, sdk_bin_path)
|
||||||
|
|
||||||
|
rctx.file("BUILD.bazel", contents)
|
||||||
|
|
||||||
|
setup_sdk = repository_rule(
|
||||||
|
attrs = {},
|
||||||
|
local = True,
|
||||||
|
configure = True,
|
||||||
|
implementation = _windows_sdk_impl,
|
||||||
|
)
|
199
bazel/win/variables.bzl
Normal file
199
bazel/win/variables.bzl
Normal file
@@ -0,0 +1,199 @@
|
|||||||
|
# Copyright (c) 2024 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.
|
||||||
|
|
||||||
|
#
|
||||||
|
# Distribution DLLs.
|
||||||
|
#
|
||||||
|
|
||||||
|
# NOTE: libcef.dll is included via the //:cef dependency.
|
||||||
|
DLLS = [
|
||||||
|
"chrome_elf.dll",
|
||||||
|
"d3dcompiler_47.dll",
|
||||||
|
"libEGL.dll",
|
||||||
|
"libGLESv2.dll",
|
||||||
|
"vk_swiftshader.dll",
|
||||||
|
"vulkan-1.dll",
|
||||||
|
]
|
||||||
|
|
||||||
|
DLLS_X64 = [
|
||||||
|
"dxil.dll",
|
||||||
|
"dxcompiler.dll",
|
||||||
|
]
|
||||||
|
|
||||||
|
#
|
||||||
|
# Common 'linkopts' for cc_binary targets.
|
||||||
|
#
|
||||||
|
|
||||||
|
# Windows delayload DLLs.
|
||||||
|
# Delayload most libraries as the DLLs are simply not required at startup (or
|
||||||
|
# at all, depending on the process type). Some dlls open handles when they are
|
||||||
|
# loaded, and we may not want them to be loaded in renderers or other sandboxed
|
||||||
|
# processes. Conversely, some DLLs must be loaded before sandbox lockdown. In
|
||||||
|
# unsandboxed processes they will load when first needed. The linker will
|
||||||
|
# automatically ignore anything which is not linked to the binary at all (it is
|
||||||
|
# harmless to have an unmatched /delayload). This list should be kept in sync
|
||||||
|
# with Chromium's "delayloads" target from the //build/config/win/BUILD.gn file.
|
||||||
|
DELAYLOAD_DLLS = [
|
||||||
|
"api-ms-win-core-winrt-error-l1-1-0.dll",
|
||||||
|
"api-ms-win-core-winrt-l1-1-0.dll",
|
||||||
|
"api-ms-win-core-winrt-string-l1-1-0.dll",
|
||||||
|
"advapi32.dll",
|
||||||
|
"comctl32.dll",
|
||||||
|
"comdlg32.dll",
|
||||||
|
"credui.dll",
|
||||||
|
"cryptui.dll",
|
||||||
|
"d3d11.dll",
|
||||||
|
"d3d9.dll",
|
||||||
|
"dwmapi.dll",
|
||||||
|
"dxgi.dll",
|
||||||
|
"dxva2.dll",
|
||||||
|
"esent.dll",
|
||||||
|
"gdi32.dll",
|
||||||
|
"hid.dll",
|
||||||
|
"imagehlp.dll",
|
||||||
|
"imm32.dll",
|
||||||
|
"msi.dll",
|
||||||
|
"netapi32.dll",
|
||||||
|
"ncrypt.dll",
|
||||||
|
"ole32.dll",
|
||||||
|
"oleacc.dll",
|
||||||
|
"propsys.dll",
|
||||||
|
"psapi.dll",
|
||||||
|
"rpcrt4.dll",
|
||||||
|
"rstrtmgr.dll",
|
||||||
|
"setupapi.dll",
|
||||||
|
"shell32.dll",
|
||||||
|
"shlwapi.dll",
|
||||||
|
"uiautomationcore.dll",
|
||||||
|
"urlmon.dll",
|
||||||
|
"user32.dll",
|
||||||
|
"usp10.dll",
|
||||||
|
"uxtheme.dll",
|
||||||
|
"wer.dll",
|
||||||
|
"wevtapi.dll",
|
||||||
|
"wininet.dll",
|
||||||
|
"winusb.dll",
|
||||||
|
"wsock32.dll",
|
||||||
|
"wtsapi32.dll",
|
||||||
|
]
|
||||||
|
|
||||||
|
# Standard link libraries.
|
||||||
|
STANDARD_LIBS = [
|
||||||
|
"comctl32.lib",
|
||||||
|
"gdi32.lib",
|
||||||
|
"rpcrt4.lib",
|
||||||
|
"shlwapi.lib",
|
||||||
|
"user32.lib",
|
||||||
|
"ws2_32.lib",
|
||||||
|
]
|
||||||
|
|
||||||
|
# Sandbox link libraries.
|
||||||
|
SANDBOX_LIBS = [
|
||||||
|
"Advapi32.lib",
|
||||||
|
"dbghelp.lib",
|
||||||
|
"Delayimp.lib",
|
||||||
|
"ntdll.lib",
|
||||||
|
"OleAut32.lib",
|
||||||
|
"PowrProf.lib",
|
||||||
|
"Propsys.lib",
|
||||||
|
"psapi.lib",
|
||||||
|
"SetupAPI.lib",
|
||||||
|
"Shcore.lib",
|
||||||
|
"Shell32.lib",
|
||||||
|
"Userenv.lib",
|
||||||
|
"version.lib",
|
||||||
|
"wbemuuid.lib",
|
||||||
|
"WindowsApp.lib",
|
||||||
|
"winmm.lib",
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_LINKOPTS_DEBUG = [
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_LINKOPTS_RELEASE = [
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_LINKOPTS = [
|
||||||
|
# No default manifest (see compile_rc target).
|
||||||
|
"/MANIFEST:NO",
|
||||||
|
# Allow 32-bit processes to access 3GB of RAM.
|
||||||
|
"/LARGEADDRESSAWARE",
|
||||||
|
# Generate Debug information.
|
||||||
|
# TODO: Remove after fixing opt builds to work without it.
|
||||||
|
"/DEBUG",
|
||||||
|
] + [
|
||||||
|
"/DELAYLOAD:{}".format(dll) for dll in DELAYLOAD_DLLS
|
||||||
|
] + [
|
||||||
|
"/DEFAULTLIB:{}".format(lib) for lib in STANDARD_LIBS
|
||||||
|
] + select({
|
||||||
|
# Set the initial stack size to 0.5MiB, instead of the 1.5MiB minimum
|
||||||
|
# needed by CEF's main thread. This saves significant memory on threads
|
||||||
|
# (like those in the Windows thread pool, and others) whose stack size we
|
||||||
|
# can only control through this setting. The main thread (in 32-bit builds
|
||||||
|
# only) uses fibers to switch to a 4MiB stack at runtime via
|
||||||
|
# CefRunWinMainWithPreferredStackSize().
|
||||||
|
"@cef//:windows_32": ["/STACK:0x80000"],
|
||||||
|
# Increase the initial stack size to 8MiB from the default 1MiB.
|
||||||
|
"//conditions:default": ["/STACK:0x800000"],
|
||||||
|
}) + select({
|
||||||
|
"@cef//:windows_dbg": COMMON_LINKOPTS_DEBUG,
|
||||||
|
"//conditions:default": COMMON_LINKOPTS_RELEASE,
|
||||||
|
})
|
||||||
|
|
||||||
|
#
|
||||||
|
# Common 'copts' for cc_libary and cc_binary targets.
|
||||||
|
#
|
||||||
|
|
||||||
|
COMMON_COPTS = [
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_COPTS_DEBUG = [
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_COPTS_RELEASE = [
|
||||||
|
]
|
||||||
|
|
||||||
|
#
|
||||||
|
# Common 'defines' for cc_libary targets.
|
||||||
|
#
|
||||||
|
|
||||||
|
COMMON_DEFINES = [
|
||||||
|
# Windows platform
|
||||||
|
"WIN32",
|
||||||
|
"_WIN32",
|
||||||
|
"_WINDOWS",
|
||||||
|
# Unicode build
|
||||||
|
"UNICODE",
|
||||||
|
"_UNICODE",
|
||||||
|
# Targeting Windows 10. We can't say `=_WIN32_WINNT_WIN10` here because
|
||||||
|
# some files do `#if WINVER < 0x0600` without including windows.h before,
|
||||||
|
# and then _WIN32_WINNT_WIN10 isn't yet known to be 0x0A00.
|
||||||
|
"WINVER=0x0A00",
|
||||||
|
"_WIN32_WINNT=0x0A00",
|
||||||
|
"NTDDI_VERSION=NTDDI_WIN10_FE",
|
||||||
|
# Use the standard's templated min/max
|
||||||
|
"NOMINMAX",
|
||||||
|
# Exclude less common API declarations
|
||||||
|
"WIN32_LEAN_AND_MEAN",
|
||||||
|
# Disable exceptions
|
||||||
|
"_HAS_EXCEPTIONS=0",
|
||||||
|
|
||||||
|
# Required by cef_sandbox.lib
|
||||||
|
"PSAPI_VERSION=1",
|
||||||
|
# Used by apps to test if the sandbox is enabled
|
||||||
|
"CEF_USE_SANDBOX",
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_DEFINES_DEBUG = [
|
||||||
|
# Required by cef_sandbox.lib
|
||||||
|
# Disable iterator debugging
|
||||||
|
"HAS_ITERATOR_DEBUGGING=0",
|
||||||
|
"_ITERATOR_DEBUG_LEVEL=0",
|
||||||
|
]
|
||||||
|
|
||||||
|
COMMON_DEFINES_RELEASE = [
|
||||||
|
# Not a debug build
|
||||||
|
"NDEBUG",
|
||||||
|
"_NDEBUG",
|
||||||
|
]
|
69
bazel/win/wrapper.py.tpl
Normal file
69
bazel/win/wrapper.py.tpl
Normal file
@@ -0,0 +1,69 @@
|
|||||||
|
# Copyright (c) 2024 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.
|
||||||
|
|
||||||
|
import os
|
||||||
|
import subprocess
|
||||||
|
import sys
|
||||||
|
from rules_python.python.runfiles import runfiles
|
||||||
|
|
||||||
|
REPLACEMENTS = {
|
||||||
|
"XXX_GETCWD_XXX": os.getcwd(),
|
||||||
|
}
|
||||||
|
|
||||||
|
def replace_in_str(input):
|
||||||
|
output = input
|
||||||
|
for placeholder, replacement in REPLACEMENTS.items():
|
||||||
|
if placeholder in output:
|
||||||
|
output = output.replace(placeholder, replacement)
|
||||||
|
return output
|
||||||
|
|
||||||
|
def print_error(str):
|
||||||
|
print(str, file=sys.stderr)
|
||||||
|
|
||||||
|
r = runfiles.Create()
|
||||||
|
wrapped_binary = r.Rlocation("winsdk/${binary}")
|
||||||
|
args = list(map(replace_in_str, sys.argv[1:]))
|
||||||
|
|
||||||
|
# Optionally execute a script before tool execution.
|
||||||
|
if args[0].endswith('.bat') or args[0].endswith('.cmd'):
|
||||||
|
if sys.platform != 'win32':
|
||||||
|
raise RuntimeError("Error running bat file; unsupported platform")
|
||||||
|
|
||||||
|
# Execute the .bat file first.
|
||||||
|
bat_file = args[0].replace('/', '\\')
|
||||||
|
p = subprocess.run(
|
||||||
|
bat_file, shell=True,
|
||||||
|
stdout = subprocess.PIPE,
|
||||||
|
stderr = subprocess.STDOUT,
|
||||||
|
text=True)
|
||||||
|
if p.returncode != 0:
|
||||||
|
print_error("[Generated python wrapper] Error running bat file:")
|
||||||
|
print_error(f"CWD: {os.getcwd()}")
|
||||||
|
print_error(f"EXEC: {bat_file}")
|
||||||
|
print_error(f"Exec output:")
|
||||||
|
print_error(p.stdout)
|
||||||
|
raise RuntimeError(f"Error running bat file; {bat_file}")
|
||||||
|
|
||||||
|
args = args[1:]
|
||||||
|
|
||||||
|
try:
|
||||||
|
p = subprocess.run(
|
||||||
|
[wrapped_binary] + args,
|
||||||
|
stdout = subprocess.PIPE,
|
||||||
|
stderr = subprocess.STDOUT,
|
||||||
|
text=True)
|
||||||
|
if p.returncode != 0:
|
||||||
|
print_error("[Generated python wrapper] Error running command:")
|
||||||
|
print_error(f"CWD: {os.getcwd()}")
|
||||||
|
print_error(f"EXEC: {wrapped_binary}")
|
||||||
|
print_error(f"ARGS: {args}")
|
||||||
|
print_error(f"Exec output:")
|
||||||
|
print_error(p.stdout)
|
||||||
|
raise RuntimeError(f"Error running wrapped command; {wrapped_binary}")
|
||||||
|
except OSError as e:
|
||||||
|
print_error("[Generated python wrapper] Error running command:")
|
||||||
|
print_error(f"CWD: {os.getcwd()}")
|
||||||
|
print_error(f"EXEC: {wrapped_binary}")
|
||||||
|
print_error(f"ARGS: {args}")
|
||||||
|
raise
|
@@ -1,2 +1,2 @@
|
|||||||
@echo off
|
@echo off
|
||||||
python.bat tools\gclient_hook.py
|
python3.bat tools\gclient_hook.py
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
# Copyright (c) 2022 The Chromium Embedded Framework Authors. All rights
|
# Copyright (c) 2024 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,7 +8,7 @@
|
|||||||
# 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=ffc0502a0275b74228f1fd642566d3f020e538a0$
|
# $hash=e092ed49124ef5969b2052fd6ae5f6e6d89390ba$
|
||||||
#
|
#
|
||||||
|
|
||||||
{
|
{
|
||||||
@@ -35,8 +35,6 @@
|
|||||||
'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',
|
||||||
@@ -56,6 +54,7 @@
|
|||||||
'include/cef_parser.h',
|
'include/cef_parser.h',
|
||||||
'include/cef_path_util.h',
|
'include/cef_path_util.h',
|
||||||
'include/cef_permission_handler.h',
|
'include/cef_permission_handler.h',
|
||||||
|
'include/cef_preference.h',
|
||||||
'include/cef_print_handler.h',
|
'include/cef_print_handler.h',
|
||||||
'include/cef_print_settings.h',
|
'include/cef_print_settings.h',
|
||||||
'include/cef_process_message.h',
|
'include/cef_process_message.h',
|
||||||
@@ -82,8 +81,10 @@
|
|||||||
'include/cef_stream.h',
|
'include/cef_stream.h',
|
||||||
'include/cef_string_visitor.h',
|
'include/cef_string_visitor.h',
|
||||||
'include/cef_task.h',
|
'include/cef_task.h',
|
||||||
|
'include/cef_task_manager.h',
|
||||||
'include/cef_thread.h',
|
'include/cef_thread.h',
|
||||||
'include/cef_trace.h',
|
'include/cef_trace.h',
|
||||||
|
'include/cef_unresponsive_process_callback.h',
|
||||||
'include/cef_urlrequest.h',
|
'include/cef_urlrequest.h',
|
||||||
'include/cef_v8.h',
|
'include/cef_v8.h',
|
||||||
'include/cef_values.h',
|
'include/cef_values.h',
|
||||||
@@ -138,8 +139,6 @@
|
|||||||
'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',
|
||||||
@@ -159,6 +158,7 @@
|
|||||||
'include/capi/cef_parser_capi.h',
|
'include/capi/cef_parser_capi.h',
|
||||||
'include/capi/cef_path_util_capi.h',
|
'include/capi/cef_path_util_capi.h',
|
||||||
'include/capi/cef_permission_handler_capi.h',
|
'include/capi/cef_permission_handler_capi.h',
|
||||||
|
'include/capi/cef_preference_capi.h',
|
||||||
'include/capi/cef_print_handler_capi.h',
|
'include/capi/cef_print_handler_capi.h',
|
||||||
'include/capi/cef_print_settings_capi.h',
|
'include/capi/cef_print_settings_capi.h',
|
||||||
'include/capi/cef_process_message_capi.h',
|
'include/capi/cef_process_message_capi.h',
|
||||||
@@ -185,8 +185,10 @@
|
|||||||
'include/capi/cef_stream_capi.h',
|
'include/capi/cef_stream_capi.h',
|
||||||
'include/capi/cef_string_visitor_capi.h',
|
'include/capi/cef_string_visitor_capi.h',
|
||||||
'include/capi/cef_task_capi.h',
|
'include/capi/cef_task_capi.h',
|
||||||
|
'include/capi/cef_task_manager_capi.h',
|
||||||
'include/capi/cef_thread_capi.h',
|
'include/capi/cef_thread_capi.h',
|
||||||
'include/capi/cef_trace_capi.h',
|
'include/capi/cef_trace_capi.h',
|
||||||
|
'include/capi/cef_unresponsive_process_callback_capi.h',
|
||||||
'include/capi/cef_urlrequest_capi.h',
|
'include/capi/cef_urlrequest_capi.h',
|
||||||
'include/capi/cef_v8_capi.h',
|
'include/capi/cef_v8_capi.h',
|
||||||
'include/capi/cef_values_capi.h',
|
'include/capi/cef_values_capi.h',
|
||||||
@@ -300,10 +302,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',
|
||||||
@@ -316,8 +314,6 @@
|
|||||||
'libcef_dll/cpptoc/frame_cpptoc.h',
|
'libcef_dll/cpptoc/frame_cpptoc.h',
|
||||||
'libcef_dll/ctocpp/frame_handler_ctocpp.cc',
|
'libcef_dll/ctocpp/frame_handler_ctocpp.cc',
|
||||||
'libcef_dll/ctocpp/frame_handler_ctocpp.h',
|
'libcef_dll/ctocpp/frame_handler_ctocpp.h',
|
||||||
'libcef_dll/cpptoc/get_extension_resource_callback_cpptoc.cc',
|
|
||||||
'libcef_dll/cpptoc/get_extension_resource_callback_cpptoc.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',
|
||||||
@@ -382,6 +378,10 @@
|
|||||||
'libcef_dll/cpptoc/post_data_cpptoc.h',
|
'libcef_dll/cpptoc/post_data_cpptoc.h',
|
||||||
'libcef_dll/cpptoc/post_data_element_cpptoc.cc',
|
'libcef_dll/cpptoc/post_data_element_cpptoc.cc',
|
||||||
'libcef_dll/cpptoc/post_data_element_cpptoc.h',
|
'libcef_dll/cpptoc/post_data_element_cpptoc.h',
|
||||||
|
'libcef_dll/cpptoc/preference_manager_cpptoc.cc',
|
||||||
|
'libcef_dll/cpptoc/preference_manager_cpptoc.h',
|
||||||
|
'libcef_dll/cpptoc/preference_registrar_cpptoc.cc',
|
||||||
|
'libcef_dll/cpptoc/preference_registrar_cpptoc.h',
|
||||||
'libcef_dll/cpptoc/print_dialog_callback_cpptoc.cc',
|
'libcef_dll/cpptoc/print_dialog_callback_cpptoc.cc',
|
||||||
'libcef_dll/cpptoc/print_dialog_callback_cpptoc.h',
|
'libcef_dll/cpptoc/print_dialog_callback_cpptoc.h',
|
||||||
'libcef_dll/ctocpp/print_handler_ctocpp.cc',
|
'libcef_dll/ctocpp/print_handler_ctocpp.cc',
|
||||||
@@ -462,6 +462,8 @@
|
|||||||
'libcef_dll/ctocpp/string_visitor_ctocpp.h',
|
'libcef_dll/ctocpp/string_visitor_ctocpp.h',
|
||||||
'libcef_dll/ctocpp/task_ctocpp.cc',
|
'libcef_dll/ctocpp/task_ctocpp.cc',
|
||||||
'libcef_dll/ctocpp/task_ctocpp.h',
|
'libcef_dll/ctocpp/task_ctocpp.h',
|
||||||
|
'libcef_dll/cpptoc/task_manager_cpptoc.cc',
|
||||||
|
'libcef_dll/cpptoc/task_manager_cpptoc.h',
|
||||||
'libcef_dll/cpptoc/task_runner_cpptoc.cc',
|
'libcef_dll/cpptoc/task_runner_cpptoc.cc',
|
||||||
'libcef_dll/cpptoc/task_runner_cpptoc.h',
|
'libcef_dll/cpptoc/task_runner_cpptoc.h',
|
||||||
'libcef_dll/cpptoc/test/test_server_cpptoc.cc',
|
'libcef_dll/cpptoc/test/test_server_cpptoc.cc',
|
||||||
@@ -502,6 +504,8 @@
|
|||||||
'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/cpptoc/unresponsive_process_callback_cpptoc.cc',
|
||||||
|
'libcef_dll/cpptoc/unresponsive_process_callback_cpptoc.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.cc',
|
||||||
@@ -624,10 +628,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',
|
||||||
@@ -640,8 +640,6 @@
|
|||||||
'libcef_dll/ctocpp/frame_ctocpp.h',
|
'libcef_dll/ctocpp/frame_ctocpp.h',
|
||||||
'libcef_dll/cpptoc/frame_handler_cpptoc.cc',
|
'libcef_dll/cpptoc/frame_handler_cpptoc.cc',
|
||||||
'libcef_dll/cpptoc/frame_handler_cpptoc.h',
|
'libcef_dll/cpptoc/frame_handler_cpptoc.h',
|
||||||
'libcef_dll/ctocpp/get_extension_resource_callback_ctocpp.cc',
|
|
||||||
'libcef_dll/ctocpp/get_extension_resource_callback_ctocpp.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',
|
||||||
@@ -706,6 +704,10 @@
|
|||||||
'libcef_dll/ctocpp/post_data_ctocpp.h',
|
'libcef_dll/ctocpp/post_data_ctocpp.h',
|
||||||
'libcef_dll/ctocpp/post_data_element_ctocpp.cc',
|
'libcef_dll/ctocpp/post_data_element_ctocpp.cc',
|
||||||
'libcef_dll/ctocpp/post_data_element_ctocpp.h',
|
'libcef_dll/ctocpp/post_data_element_ctocpp.h',
|
||||||
|
'libcef_dll/ctocpp/preference_manager_ctocpp.cc',
|
||||||
|
'libcef_dll/ctocpp/preference_manager_ctocpp.h',
|
||||||
|
'libcef_dll/ctocpp/preference_registrar_ctocpp.cc',
|
||||||
|
'libcef_dll/ctocpp/preference_registrar_ctocpp.h',
|
||||||
'libcef_dll/ctocpp/print_dialog_callback_ctocpp.cc',
|
'libcef_dll/ctocpp/print_dialog_callback_ctocpp.cc',
|
||||||
'libcef_dll/ctocpp/print_dialog_callback_ctocpp.h',
|
'libcef_dll/ctocpp/print_dialog_callback_ctocpp.h',
|
||||||
'libcef_dll/cpptoc/print_handler_cpptoc.cc',
|
'libcef_dll/cpptoc/print_handler_cpptoc.cc',
|
||||||
@@ -786,6 +788,8 @@
|
|||||||
'libcef_dll/cpptoc/string_visitor_cpptoc.h',
|
'libcef_dll/cpptoc/string_visitor_cpptoc.h',
|
||||||
'libcef_dll/cpptoc/task_cpptoc.cc',
|
'libcef_dll/cpptoc/task_cpptoc.cc',
|
||||||
'libcef_dll/cpptoc/task_cpptoc.h',
|
'libcef_dll/cpptoc/task_cpptoc.h',
|
||||||
|
'libcef_dll/ctocpp/task_manager_ctocpp.cc',
|
||||||
|
'libcef_dll/ctocpp/task_manager_ctocpp.h',
|
||||||
'libcef_dll/ctocpp/task_runner_ctocpp.cc',
|
'libcef_dll/ctocpp/task_runner_ctocpp.cc',
|
||||||
'libcef_dll/ctocpp/task_runner_ctocpp.h',
|
'libcef_dll/ctocpp/task_runner_ctocpp.h',
|
||||||
'libcef_dll/ctocpp/test/test_server_ctocpp.cc',
|
'libcef_dll/ctocpp/test/test_server_ctocpp.cc',
|
||||||
@@ -826,6 +830,8 @@
|
|||||||
'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/ctocpp/unresponsive_process_callback_ctocpp.cc',
|
||||||
|
'libcef_dll/ctocpp/unresponsive_process_callback_ctocpp.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.cc',
|
||||||
|
107
cef_paths2.gypi
107
cef_paths2.gypi
@@ -8,7 +8,6 @@
|
|||||||
'include/base/cef_atomic_flag.h',
|
'include/base/cef_atomic_flag.h',
|
||||||
'include/base/cef_atomic_ref_count.h',
|
'include/base/cef_atomic_ref_count.h',
|
||||||
'include/base/cef_auto_reset.h',
|
'include/base/cef_auto_reset.h',
|
||||||
'include/base/cef_basictypes.h',
|
|
||||||
'include/base/cef_bind.h',
|
'include/base/cef_bind.h',
|
||||||
'include/base/cef_build.h',
|
'include/base/cef_build.h',
|
||||||
'include/base/cef_callback.h',
|
'include/base/cef_callback.h',
|
||||||
@@ -17,20 +16,20 @@
|
|||||||
'include/base/cef_callback_list.h',
|
'include/base/cef_callback_list.h',
|
||||||
'include/base/cef_cancelable_callback.h',
|
'include/base/cef_cancelable_callback.h',
|
||||||
'include/base/cef_compiler_specific.h',
|
'include/base/cef_compiler_specific.h',
|
||||||
|
'include/base/cef_dump_without_crashing.h',
|
||||||
'include/base/cef_lock.h',
|
'include/base/cef_lock.h',
|
||||||
'include/base/cef_logging.h',
|
'include/base/cef_logging.h',
|
||||||
'include/base/cef_macros.h',
|
'include/base/cef_macros.h',
|
||||||
'include/base/cef_platform_thread.h',
|
'include/base/cef_platform_thread.h',
|
||||||
'include/base/cef_ptr_util.h',
|
|
||||||
'include/base/cef_ref_counted.h',
|
'include/base/cef_ref_counted.h',
|
||||||
'include/base/cef_scoped_refptr.h',
|
'include/base/cef_scoped_refptr.h',
|
||||||
'include/base/cef_template_util.h',
|
|
||||||
'include/base/cef_thread_checker.h',
|
'include/base/cef_thread_checker.h',
|
||||||
'include/base/cef_trace_event.h',
|
'include/base/cef_trace_event.h',
|
||||||
'include/base/cef_tuple.h',
|
'include/base/cef_tuple.h',
|
||||||
'include/base/cef_weak_ptr.h',
|
'include/base/cef_weak_ptr.h',
|
||||||
'include/base/internal/cef_bind_internal.h',
|
'include/base/internal/cef_bind_internal.h',
|
||||||
'include/base/internal/cef_callback_internal.h',
|
'include/base/internal/cef_callback_internal.h',
|
||||||
|
'include/base/internal/cef_color_id_macros.inc',
|
||||||
'include/base/internal/cef_lock_impl.h',
|
'include/base/internal/cef_lock_impl.h',
|
||||||
'include/base/internal/cef_raw_scoped_refptr_mismatch_checker.h',
|
'include/base/internal/cef_raw_scoped_refptr_mismatch_checker.h',
|
||||||
'include/base/internal/cef_scoped_policy.h',
|
'include/base/internal/cef_scoped_policy.h',
|
||||||
@@ -45,6 +44,7 @@
|
|||||||
'include/internal/cef_types_wrappers.h',
|
'include/internal/cef_types_wrappers.h',
|
||||||
],
|
],
|
||||||
'includes_common_capi': [
|
'includes_common_capi': [
|
||||||
|
'include/internal/cef_dump_without_crashing_internal.h',
|
||||||
'include/internal/cef_logging_internal.h',
|
'include/internal/cef_logging_internal.h',
|
||||||
'include/internal/cef_string.h',
|
'include/internal/cef_string.h',
|
||||||
'include/internal/cef_string_list.h',
|
'include/internal/cef_string_list.h',
|
||||||
@@ -55,7 +55,10 @@
|
|||||||
'include/internal/cef_time.h',
|
'include/internal/cef_time.h',
|
||||||
'include/internal/cef_trace_event_internal.h',
|
'include/internal/cef_trace_event_internal.h',
|
||||||
'include/internal/cef_types.h',
|
'include/internal/cef_types.h',
|
||||||
|
'include/internal/cef_types_content_settings.h',
|
||||||
'include/internal/cef_types_geometry.h',
|
'include/internal/cef_types_geometry.h',
|
||||||
|
'include/internal/cef_types_runtime.h',
|
||||||
|
'include/internal/cef_types_color.h',
|
||||||
],
|
],
|
||||||
'includes_capi': [
|
'includes_capi': [
|
||||||
'include/capi/cef_base_capi.h',
|
'include/capi/cef_base_capi.h',
|
||||||
@@ -79,6 +82,7 @@
|
|||||||
'include/internal/cef_win.h',
|
'include/internal/cef_win.h',
|
||||||
],
|
],
|
||||||
'includes_win_capi': [
|
'includes_win_capi': [
|
||||||
|
'include/internal/cef_app_win.h',
|
||||||
'include/internal/cef_types_win.h',
|
'include/internal/cef_types_win.h',
|
||||||
],
|
],
|
||||||
'includes_mac': [
|
'includes_mac': [
|
||||||
@@ -121,6 +125,7 @@
|
|||||||
'libcef_dll/base/cef_atomic_flag.cc',
|
'libcef_dll/base/cef_atomic_flag.cc',
|
||||||
'libcef_dll/base/cef_callback_helpers.cc',
|
'libcef_dll/base/cef_callback_helpers.cc',
|
||||||
'libcef_dll/base/cef_callback_internal.cc',
|
'libcef_dll/base/cef_callback_internal.cc',
|
||||||
|
'libcef_dll/base/cef_dump_without_crashing.cc',
|
||||||
'libcef_dll/base/cef_lock.cc',
|
'libcef_dll/base/cef_lock.cc',
|
||||||
'libcef_dll/base/cef_lock_impl.cc',
|
'libcef_dll/base/cef_lock_impl.cc',
|
||||||
'libcef_dll/base/cef_logging.cc',
|
'libcef_dll/base/cef_logging.cc',
|
||||||
@@ -147,6 +152,8 @@
|
|||||||
'libcef_dll/wrapper/cef_byte_read_handler.cc',
|
'libcef_dll/wrapper/cef_byte_read_handler.cc',
|
||||||
'libcef_dll/wrapper/cef_closure_task.cc',
|
'libcef_dll/wrapper/cef_closure_task.cc',
|
||||||
'libcef_dll/wrapper/cef_message_router.cc',
|
'libcef_dll/wrapper/cef_message_router.cc',
|
||||||
|
'libcef_dll/wrapper/cef_message_router_utils.cc',
|
||||||
|
'libcef_dll/wrapper/cef_message_router_utils.h',
|
||||||
'libcef_dll/wrapper/cef_resource_manager.cc',
|
'libcef_dll/wrapper/cef_resource_manager.cc',
|
||||||
'libcef_dll/wrapper/cef_scoped_temp_dir.cc',
|
'libcef_dll/wrapper/cef_scoped_temp_dir.cc',
|
||||||
'libcef_dll/wrapper/cef_stream_resource_handler.cc',
|
'libcef_dll/wrapper/cef_stream_resource_handler.cc',
|
||||||
@@ -162,8 +169,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.cc',
|
||||||
'tests/shared/browser/file_util.h',
|
'tests/shared/browser/file_util.h',
|
||||||
'tests/shared/browser/geometry_util.cc',
|
'tests/shared/browser/geometry_util.cc',
|
||||||
@@ -218,6 +223,10 @@
|
|||||||
'tests/shared/browser/util_win.h',
|
'tests/shared/browser/util_win.h',
|
||||||
],
|
],
|
||||||
'cefclient_sources_browser': [
|
'cefclient_sources_browser': [
|
||||||
|
'tests/cefclient/browser/base_client_handler.cc',
|
||||||
|
'tests/cefclient/browser/base_client_handler.h',
|
||||||
|
'tests/cefclient/browser/binary_transfer_test.cc',
|
||||||
|
'tests/cefclient/browser/binary_transfer_test.h',
|
||||||
'tests/cefclient/browser/binding_test.cc',
|
'tests/cefclient/browser/binding_test.cc',
|
||||||
'tests/cefclient/browser/binding_test.h',
|
'tests/cefclient/browser/binding_test.h',
|
||||||
'tests/cefclient/browser/browser_window.cc',
|
'tests/cefclient/browser/browser_window.cc',
|
||||||
@@ -233,9 +242,15 @@
|
|||||||
'tests/cefclient/browser/client_handler_osr.h',
|
'tests/cefclient/browser/client_handler_osr.h',
|
||||||
'tests/cefclient/browser/client_handler_std.cc',
|
'tests/cefclient/browser/client_handler_std.cc',
|
||||||
'tests/cefclient/browser/client_handler_std.h',
|
'tests/cefclient/browser/client_handler_std.h',
|
||||||
|
'tests/cefclient/browser/client_prefs.cc',
|
||||||
|
'tests/cefclient/browser/client_prefs.h',
|
||||||
'tests/cefclient/browser/client_types.h',
|
'tests/cefclient/browser/client_types.h',
|
||||||
|
'tests/cefclient/browser/default_client_handler.cc',
|
||||||
|
'tests/cefclient/browser/default_client_handler.h',
|
||||||
'tests/cefclient/browser/dialog_test.cc',
|
'tests/cefclient/browser/dialog_test.cc',
|
||||||
'tests/cefclient/browser/dialog_test.h',
|
'tests/cefclient/browser/dialog_test.h',
|
||||||
|
'tests/cefclient/browser/hang_test.cc',
|
||||||
|
'tests/cefclient/browser/hang_test.h',
|
||||||
'tests/cefclient/browser/image_cache.cc',
|
'tests/cefclient/browser/image_cache.cc',
|
||||||
'tests/cefclient/browser/image_cache.h',
|
'tests/cefclient/browser/image_cache.h',
|
||||||
'tests/cefclient/browser/main_context.cc',
|
'tests/cefclient/browser/main_context.cc',
|
||||||
@@ -264,6 +279,8 @@
|
|||||||
'tests/cefclient/browser/scheme_test.h',
|
'tests/cefclient/browser/scheme_test.h',
|
||||||
'tests/cefclient/browser/server_test.cc',
|
'tests/cefclient/browser/server_test.cc',
|
||||||
'tests/cefclient/browser/server_test.h',
|
'tests/cefclient/browser/server_test.h',
|
||||||
|
'tests/cefclient/browser/task_manager_test.cc',
|
||||||
|
'tests/cefclient/browser/task_manager_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',
|
||||||
@@ -301,9 +318,11 @@
|
|||||||
'tests/cefclient/renderer/performance_test_tests.cc',
|
'tests/cefclient/renderer/performance_test_tests.cc',
|
||||||
],
|
],
|
||||||
'cefclient_sources_resources': [
|
'cefclient_sources_resources': [
|
||||||
|
'tests/cefclient/resources/binary_transfer.html',
|
||||||
'tests/cefclient/resources/binding.html',
|
'tests/cefclient/resources/binding.html',
|
||||||
'tests/cefclient/resources/dialogs.html',
|
'tests/cefclient/resources/dialogs.html',
|
||||||
'tests/cefclient/resources/draggable.html',
|
'tests/cefclient/resources/draggable.html',
|
||||||
|
'tests/cefclient/resources/hang.html',
|
||||||
'tests/cefclient/resources/ipc_performance.html',
|
'tests/cefclient/resources/ipc_performance.html',
|
||||||
'tests/cefclient/resources/localstorage.html',
|
'tests/cefclient/resources/localstorage.html',
|
||||||
'tests/cefclient/resources/logo.png',
|
'tests/cefclient/resources/logo.png',
|
||||||
@@ -316,19 +335,13 @@
|
|||||||
'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/server.html',
|
||||||
|
'tests/cefclient/resources/task_manager.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/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',
|
||||||
@@ -364,12 +377,14 @@
|
|||||||
'tests/cefclient/browser/window_test_runner_win.cc',
|
'tests/cefclient/browser/window_test_runner_win.cc',
|
||||||
'tests/cefclient/browser/window_test_runner_win.h',
|
'tests/cefclient/browser/window_test_runner_win.h',
|
||||||
'tests/cefclient/cefclient_win.cc',
|
'tests/cefclient/cefclient_win.cc',
|
||||||
'tests/cefclient/resources/win/cefclient.rc',
|
|
||||||
],
|
],
|
||||||
'cefclient_sources_resources_win': [
|
'cefclient_sources_resources_win': [
|
||||||
'tests/cefclient/resources/win/cefclient.exe.manifest',
|
'tests/cefclient/win/cefclient.exe.manifest',
|
||||||
'tests/cefclient/resources/win/cefclient.ico',
|
'tests/cefclient/win/cefclient.ico',
|
||||||
'tests/cefclient/resources/win/small.ico',
|
'tests/cefclient/win/small.ico',
|
||||||
|
],
|
||||||
|
'cefclient_sources_resources_win_rc': [
|
||||||
|
'tests/cefclient/win/cefclient.rc',
|
||||||
],
|
],
|
||||||
'cefclient_sources_mac': [
|
'cefclient_sources_mac': [
|
||||||
'tests/cefclient/browser/browser_window_osr_mac.h',
|
'tests/cefclient/browser/browser_window_osr_mac.h',
|
||||||
@@ -388,15 +403,16 @@
|
|||||||
'tests/cefclient/browser/temp_window_mac.mm',
|
'tests/cefclient/browser/temp_window_mac.mm',
|
||||||
'tests/cefclient/browser/text_input_client_osr_mac.h',
|
'tests/cefclient/browser/text_input_client_osr_mac.h',
|
||||||
'tests/cefclient/browser/text_input_client_osr_mac.mm',
|
'tests/cefclient/browser/text_input_client_osr_mac.mm',
|
||||||
|
'tests/cefclient/browser/views_window_mac.mm',
|
||||||
'tests/cefclient/browser/window_test_runner_mac.h',
|
'tests/cefclient/browser/window_test_runner_mac.h',
|
||||||
'tests/cefclient/browser/window_test_runner_mac.mm',
|
'tests/cefclient/browser/window_test_runner_mac.mm',
|
||||||
'tests/cefclient/cefclient_mac.mm',
|
'tests/cefclient/cefclient_mac.mm',
|
||||||
],
|
],
|
||||||
'cefclient_bundle_resources_mac': [
|
'cefclient_bundle_resources_mac': [
|
||||||
'tests/cefclient/resources/mac/cefclient.icns',
|
'tests/cefclient/mac/cefclient.icns',
|
||||||
'tests/cefclient/resources/mac/English.lproj/InfoPlist.strings',
|
'tests/cefclient/mac/English.lproj/InfoPlist.strings',
|
||||||
'tests/cefclient/resources/mac/English.lproj/MainMenu.xib',
|
'tests/cefclient/mac/English.lproj/MainMenu.xib',
|
||||||
'tests/cefclient/resources/mac/Info.plist',
|
'tests/cefclient/mac/Info.plist.in',
|
||||||
],
|
],
|
||||||
'cefclient_sources_linux': [
|
'cefclient_sources_linux': [
|
||||||
'tests/cefclient/browser/browser_window_osr_gtk.cc',
|
'tests/cefclient/browser/browser_window_osr_gtk.cc',
|
||||||
@@ -428,15 +444,17 @@
|
|||||||
'tests/cefsimple/simple_handler.h',
|
'tests/cefsimple/simple_handler.h',
|
||||||
],
|
],
|
||||||
'cefsimple_sources_win': [
|
'cefsimple_sources_win': [
|
||||||
'tests/cefsimple/cefsimple.rc',
|
|
||||||
'tests/cefsimple/cefsimple_win.cc',
|
'tests/cefsimple/cefsimple_win.cc',
|
||||||
'tests/cefsimple/simple_handler_win.cc',
|
|
||||||
'tests/cefsimple/resource.h',
|
'tests/cefsimple/resource.h',
|
||||||
|
'tests/cefsimple/simple_handler_win.cc',
|
||||||
],
|
],
|
||||||
'cefsimple_sources_resources_win': [
|
'cefsimple_sources_resources_win': [
|
||||||
'tests/cefsimple/cefsimple.exe.manifest',
|
'tests/cefsimple/win/cefsimple.exe.manifest',
|
||||||
'tests/cefsimple/res/cefsimple.ico',
|
'tests/cefsimple/win/cefsimple.ico',
|
||||||
'tests/cefsimple/res/small.ico',
|
'tests/cefsimple/win/small.ico',
|
||||||
|
],
|
||||||
|
'cefsimple_sources_resources_win_rc': [
|
||||||
|
'tests/cefsimple/win/cefsimple.rc',
|
||||||
],
|
],
|
||||||
'cefsimple_sources_mac': [
|
'cefsimple_sources_mac': [
|
||||||
'tests/cefsimple/cefsimple_mac.mm',
|
'tests/cefsimple/cefsimple_mac.mm',
|
||||||
@@ -449,7 +467,7 @@
|
|||||||
'tests/cefsimple/mac/cefsimple.icns',
|
'tests/cefsimple/mac/cefsimple.icns',
|
||||||
'tests/cefsimple/mac/English.lproj/InfoPlist.strings',
|
'tests/cefsimple/mac/English.lproj/InfoPlist.strings',
|
||||||
'tests/cefsimple/mac/English.lproj/MainMenu.xib',
|
'tests/cefsimple/mac/English.lproj/MainMenu.xib',
|
||||||
'tests/cefsimple/mac/Info.plist',
|
'tests/cefsimple/mac/Info.plist.in',
|
||||||
],
|
],
|
||||||
'cefsimple_sources_linux': [
|
'cefsimple_sources_linux': [
|
||||||
'tests/cefsimple/cefsimple_linux.cc',
|
'tests/cefsimple/cefsimple_linux.cc',
|
||||||
@@ -474,13 +492,6 @@
|
|||||||
'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/extensions/chrome_alarms_unittest.cc',
|
|
||||||
'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_handler_unittest.cc',
|
'tests/ceftests/frame_handler_unittest.cc',
|
||||||
'tests/ceftests/frame_unittest.cc',
|
'tests/ceftests/frame_unittest.cc',
|
||||||
@@ -491,6 +502,7 @@
|
|||||||
'tests/ceftests/jsdialog_unittest.cc',
|
'tests/ceftests/jsdialog_unittest.cc',
|
||||||
'tests/ceftests/life_span_unittest.cc',
|
'tests/ceftests/life_span_unittest.cc',
|
||||||
'tests/ceftests/media_access_unittest.cc',
|
'tests/ceftests/media_access_unittest.cc',
|
||||||
|
'tests/ceftests/message_router_binary_unittest.cc',
|
||||||
'tests/ceftests/message_router_harness_unittest.cc',
|
'tests/ceftests/message_router_harness_unittest.cc',
|
||||||
'tests/ceftests/message_router_multi_query_unittest.cc',
|
'tests/ceftests/message_router_multi_query_unittest.cc',
|
||||||
'tests/ceftests/message_router_single_query_unittest.cc',
|
'tests/ceftests/message_router_single_query_unittest.cc',
|
||||||
@@ -573,24 +585,32 @@
|
|||||||
'ceftests_sources_win': [
|
'ceftests_sources_win': [
|
||||||
'tests/ceftests/resource_util_win_dir.cc',
|
'tests/ceftests/resource_util_win_dir.cc',
|
||||||
'tests/ceftests/resource_util_win_idmap.cc',
|
'tests/ceftests/resource_util_win_idmap.cc',
|
||||||
'tests/ceftests/resources/win/ceftests.rc',
|
|
||||||
],
|
],
|
||||||
'ceftests_sources_resources_win': [
|
'ceftests_sources_resources_win': [
|
||||||
'tests/ceftests/resources/win/ceftests.exe.manifest',
|
'tests/ceftests/win/ceftests.exe.manifest',
|
||||||
'tests/ceftests/resources/win/ceftests.ico',
|
'tests/ceftests/win/ceftests.ico',
|
||||||
'tests/ceftests/resources/win/small.ico',
|
'tests/ceftests/win/small.ico',
|
||||||
|
],
|
||||||
|
'ceftests_sources_resources_win_rc': [
|
||||||
|
'tests/ceftests/win/ceftests.rc',
|
||||||
],
|
],
|
||||||
'ceftests_sources_mac': [
|
'ceftests_sources_mac': [
|
||||||
'tests/ceftests/os_rendering_unittest_mac.h',
|
'tests/ceftests/os_rendering_unittest_mac.h',
|
||||||
'tests/ceftests/os_rendering_unittest_mac.mm',
|
'tests/ceftests/os_rendering_unittest_mac.mm',
|
||||||
'tests/ceftests/run_all_unittests_mac.mm',
|
'tests/ceftests/run_all_unittests_mac.mm',
|
||||||
],
|
],
|
||||||
'ceftests_sources_mac_helper': [
|
'ceftests_sources_mac_browser_shared': [
|
||||||
|
'tests/shared/renderer/client_app_renderer.h',
|
||||||
|
],
|
||||||
|
'ceftests_sources_mac_helper_shared': [
|
||||||
|
'tests/shared/browser/client_app_browser.h',
|
||||||
'tests/shared/browser/file_util.cc',
|
'tests/shared/browser/file_util.cc',
|
||||||
'tests/shared/browser/file_util.h',
|
'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',
|
||||||
|
],
|
||||||
|
'ceftests_sources_mac_helper': [
|
||||||
'tests/ceftests/audio_output_unittest.cc',
|
'tests/ceftests/audio_output_unittest.cc',
|
||||||
'tests/ceftests/client_app_delegates.cc',
|
'tests/ceftests/client_app_delegates.cc',
|
||||||
'tests/ceftests/cookie_unittest.cc',
|
'tests/ceftests/cookie_unittest.cc',
|
||||||
@@ -598,6 +618,7 @@
|
|||||||
'tests/ceftests/dom_unittest.cc',
|
'tests/ceftests/dom_unittest.cc',
|
||||||
'tests/ceftests/frame_unittest.cc',
|
'tests/ceftests/frame_unittest.cc',
|
||||||
'tests/ceftests/media_access_unittest.cc',
|
'tests/ceftests/media_access_unittest.cc',
|
||||||
|
'tests/ceftests/message_router_binary_unittest.cc',
|
||||||
'tests/ceftests/message_router_harness_unittest.cc',
|
'tests/ceftests/message_router_harness_unittest.cc',
|
||||||
'tests/ceftests/message_router_multi_query_unittest.cc',
|
'tests/ceftests/message_router_multi_query_unittest.cc',
|
||||||
'tests/ceftests/message_router_single_query_unittest.cc',
|
'tests/ceftests/message_router_single_query_unittest.cc',
|
||||||
@@ -645,10 +666,10 @@
|
|||||||
'tests/ceftests/v8_unittest.cc',
|
'tests/ceftests/v8_unittest.cc',
|
||||||
],
|
],
|
||||||
'ceftests_bundle_resources_mac': [
|
'ceftests_bundle_resources_mac': [
|
||||||
'tests/ceftests/resources/mac/ceftests.icns',
|
'tests/ceftests/mac/ceftests.icns',
|
||||||
'tests/ceftests/resources/mac/English.lproj/InfoPlist.strings',
|
'tests/ceftests/mac/English.lproj/InfoPlist.strings',
|
||||||
'tests/ceftests/resources/mac/English.lproj/MainMenu.xib',
|
'tests/ceftests/mac/English.lproj/MainMenu.xib',
|
||||||
'tests/ceftests/resources/mac/Info.plist',
|
'tests/ceftests/mac/Info.plist.in',
|
||||||
],
|
],
|
||||||
'ceftests_sources_linux': [
|
'ceftests_sources_linux': [
|
||||||
'tests/ceftests/resource_util_linux.cc',
|
'tests/ceftests/resource_util_linux.cc',
|
||||||
|
@@ -26,18 +26,14 @@ endif()
|
|||||||
|
|
||||||
# Determine the project architecture.
|
# Determine the project architecture.
|
||||||
if(NOT DEFINED PROJECT_ARCH)
|
if(NOT DEFINED PROJECT_ARCH)
|
||||||
if(OS_WINDOWS AND "${CMAKE_GENERATOR_PLATFORM}" STREQUAL "arm64")
|
if(("${CMAKE_HOST_SYSTEM_PROCESSOR}" STREQUAL "arm64") OR
|
||||||
|
("${CMAKE_CXX_COMPILER_ARCHITECTURE_ID}" STREQUAL "ARM64"))
|
||||||
set(PROJECT_ARCH "arm64")
|
set(PROJECT_ARCH "arm64")
|
||||||
elseif(CMAKE_SIZEOF_VOID_P MATCHES 8)
|
elseif(CMAKE_SIZEOF_VOID_P MATCHES 8)
|
||||||
set(PROJECT_ARCH "x86_64")
|
set(PROJECT_ARCH "x86_64")
|
||||||
else()
|
else()
|
||||||
set(PROJECT_ARCH "x86")
|
set(PROJECT_ARCH "x86")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(OS_MAC)
|
|
||||||
# PROJECT_ARCH should be specified on Mac OS X.
|
|
||||||
message(WARNING "No PROJECT_ARCH value specified, using ${PROJECT_ARCH}")
|
|
||||||
endif()
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(${CMAKE_GENERATOR} STREQUAL "Ninja")
|
if(${CMAKE_GENERATOR} STREQUAL "Ninja")
|
||||||
@@ -308,13 +304,14 @@ if(OS_MAC)
|
|||||||
# Standard libraries.
|
# Standard libraries.
|
||||||
set(CEF_STANDARD_LIBS
|
set(CEF_STANDARD_LIBS
|
||||||
-lpthread
|
-lpthread
|
||||||
"-framework Cocoa"
|
|
||||||
"-framework AppKit"
|
"-framework AppKit"
|
||||||
|
"-framework Cocoa"
|
||||||
|
"-framework IOSurface"
|
||||||
)
|
)
|
||||||
|
|
||||||
# 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.15 10.14 10.13)
|
foreach(OS_VERSION 14.2 14.0 10.15)
|
||||||
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})
|
||||||
@@ -322,7 +319,7 @@ if(OS_MAC)
|
|||||||
endforeach()
|
endforeach()
|
||||||
|
|
||||||
# Target SDK.
|
# Target SDK.
|
||||||
set(CEF_TARGET_SDK "10.13")
|
set(CEF_TARGET_SDK "10.15")
|
||||||
list(APPEND CEF_COMPILER_FLAGS
|
list(APPEND CEF_COMPILER_FLAGS
|
||||||
-mmacosx-version-min=${CEF_TARGET_SDK}
|
-mmacosx-version-min=${CEF_TARGET_SDK}
|
||||||
)
|
)
|
||||||
@@ -350,6 +347,10 @@ if(OS_MAC)
|
|||||||
CEF_USE_SANDBOX # Used by apps to test if the sandbox is enabled
|
CEF_USE_SANDBOX # Used by apps to test if the sandbox is enabled
|
||||||
)
|
)
|
||||||
|
|
||||||
|
list(APPEND CEF_STANDARD_LIBS
|
||||||
|
-lsandbox
|
||||||
|
)
|
||||||
|
|
||||||
# CEF sandbox library paths.
|
# CEF sandbox library paths.
|
||||||
set(CEF_SANDBOX_LIB_DEBUG "${CEF_BINARY_DIR_DEBUG}/cef_sandbox.a")
|
set(CEF_SANDBOX_LIB_DEBUG "${CEF_BINARY_DIR_DEBUG}/cef_sandbox.a")
|
||||||
set(CEF_SANDBOX_LIB_RELEASE "${CEF_BINARY_DIR_RELEASE}/cef_sandbox.a")
|
set(CEF_SANDBOX_LIB_RELEASE "${CEF_BINARY_DIR_RELEASE}/cef_sandbox.a")
|
||||||
@@ -359,6 +360,7 @@ if(OS_MAC)
|
|||||||
# Format is "<name suffix>:<target suffix>:<plist suffix>".
|
# Format is "<name suffix>:<target suffix>:<plist suffix>".
|
||||||
set(CEF_HELPER_APP_SUFFIXES
|
set(CEF_HELPER_APP_SUFFIXES
|
||||||
"::"
|
"::"
|
||||||
|
" (Alerts):_alerts:.alerts"
|
||||||
" (GPU):_gpu:.gpu"
|
" (GPU):_gpu:.gpu"
|
||||||
" (Plugin):_plugin:.plugin"
|
" (Plugin):_plugin:.plugin"
|
||||||
" (Renderer):_renderer:.renderer"
|
" (Renderer):_renderer:.renderer"
|
||||||
@@ -435,11 +437,66 @@ if(OS_WINDOWS)
|
|||||||
list(APPEND CEF_EXE_LINKER_FLAGS
|
list(APPEND CEF_EXE_LINKER_FLAGS
|
||||||
/MANIFEST:NO # No default manifest (see ADD_WINDOWS_MANIFEST macro usage)
|
/MANIFEST:NO # No default manifest (see ADD_WINDOWS_MANIFEST macro usage)
|
||||||
/LARGEADDRESSAWARE # Allow 32-bit processes to access 3GB of RAM
|
/LARGEADDRESSAWARE # Allow 32-bit processes to access 3GB of RAM
|
||||||
|
|
||||||
|
# Delayload most libraries as the dlls are simply not required at startup (or
|
||||||
|
# at all, depending on the process type). Some dlls open handles when they are
|
||||||
|
# loaded, and we may not want them to be loaded in renderers or other sandboxed
|
||||||
|
# processes. Conversely, some dlls must be loaded before sandbox lockdown. In
|
||||||
|
# unsandboxed processes they will load when first needed. The linker will
|
||||||
|
# automatically ignore anything which is not linked to the binary at all (it is
|
||||||
|
# harmless to have an unmatched /delayload). This list should be kept in sync
|
||||||
|
# with Chromium's "delayloads" target from the //build/config/win/BUILD.gn file.
|
||||||
|
/DELAYLOAD:api-ms-win-core-winrt-error-l1-1-0.dll
|
||||||
|
/DELAYLOAD:api-ms-win-core-winrt-l1-1-0.dll
|
||||||
|
/DELAYLOAD:api-ms-win-core-winrt-string-l1-1-0.dll
|
||||||
|
/DELAYLOAD:advapi32.dll
|
||||||
|
/DELAYLOAD:comctl32.dll
|
||||||
|
/DELAYLOAD:comdlg32.dll
|
||||||
|
/DELAYLOAD:credui.dll
|
||||||
|
/DELAYLOAD:cryptui.dll
|
||||||
|
/DELAYLOAD:d3d11.dll
|
||||||
|
/DELAYLOAD:d3d9.dll
|
||||||
|
/DELAYLOAD:dwmapi.dll
|
||||||
|
/DELAYLOAD:dxgi.dll
|
||||||
|
/DELAYLOAD:dxva2.dll
|
||||||
|
/DELAYLOAD:esent.dll
|
||||||
|
/DELAYLOAD:gdi32.dll
|
||||||
|
/DELAYLOAD:hid.dll
|
||||||
|
/DELAYLOAD:imagehlp.dll
|
||||||
|
/DELAYLOAD:imm32.dll
|
||||||
|
/DELAYLOAD:msi.dll
|
||||||
|
/DELAYLOAD:netapi32.dll
|
||||||
|
/DELAYLOAD:ncrypt.dll
|
||||||
|
/DELAYLOAD:ole32.dll
|
||||||
|
/DELAYLOAD:oleacc.dll
|
||||||
|
/DELAYLOAD:propsys.dll
|
||||||
|
/DELAYLOAD:psapi.dll
|
||||||
|
/DELAYLOAD:rpcrt4.dll
|
||||||
|
/DELAYLOAD:rstrtmgr.dll
|
||||||
|
/DELAYLOAD:setupapi.dll
|
||||||
|
/DELAYLOAD:shell32.dll
|
||||||
|
/DELAYLOAD:shlwapi.dll
|
||||||
|
/DELAYLOAD:uiautomationcore.dll
|
||||||
|
/DELAYLOAD:urlmon.dll
|
||||||
|
/DELAYLOAD:user32.dll
|
||||||
|
/DELAYLOAD:usp10.dll
|
||||||
|
/DELAYLOAD:uxtheme.dll
|
||||||
|
/DELAYLOAD:wer.dll
|
||||||
|
/DELAYLOAD:wevtapi.dll
|
||||||
|
/DELAYLOAD:wininet.dll
|
||||||
|
/DELAYLOAD:winusb.dll
|
||||||
|
/DELAYLOAD:wsock32.dll
|
||||||
|
/DELAYLOAD:wtsapi32.dll
|
||||||
)
|
)
|
||||||
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
|
# Targeting Windows 10. We can't say `=_WIN32_WINNT_WIN10` here because
|
||||||
|
# some files do `#if WINVER < 0x0600` without including windows.h before,
|
||||||
|
# and then _WIN32_WINNT_WIN10 isn't yet known to be 0x0A00.
|
||||||
|
WINVER=0x0A00
|
||||||
|
_WIN32_WINNT=0x0A00
|
||||||
|
NTDDI_VERSION=NTDDI_WIN10_FE
|
||||||
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
|
||||||
@@ -448,6 +505,23 @@ if(OS_WINDOWS)
|
|||||||
NDEBUG _NDEBUG # Not a debug build
|
NDEBUG _NDEBUG # Not a debug build
|
||||||
)
|
)
|
||||||
|
|
||||||
|
if(PROJECT_ARCH STREQUAL "x86")
|
||||||
|
# Set the initial stack size to 0.5MiB, instead of the 1.5MiB minimum
|
||||||
|
# needed by CEF's main thread. This saves significant memory on threads
|
||||||
|
# (like those in the Windows thread pool, and others) whose stack size we
|
||||||
|
# can only control through this setting. The main thread (in 32-bit builds
|
||||||
|
# only) uses fibers to switch to a 4MiB stack at runtime via
|
||||||
|
# CefRunWinMainWithPreferredStackSize().
|
||||||
|
list(APPEND CEF_EXE_LINKER_FLAGS
|
||||||
|
/STACK:0x80000
|
||||||
|
)
|
||||||
|
else()
|
||||||
|
# Increase the initial stack size to 8MiB from the default 1MiB.
|
||||||
|
list(APPEND CEF_EXE_LINKER_FLAGS
|
||||||
|
/STACK:0x800000
|
||||||
|
)
|
||||||
|
endif()
|
||||||
|
|
||||||
# Standard libraries.
|
# Standard libraries.
|
||||||
set(CEF_STANDARD_LIBS
|
set(CEF_STANDARD_LIBS
|
||||||
comctl32.lib
|
comctl32.lib
|
||||||
@@ -470,6 +544,7 @@ if(OS_WINDOWS)
|
|||||||
# List of CEF binary files.
|
# List of CEF binary files.
|
||||||
set(CEF_BINARY_FILES
|
set(CEF_BINARY_FILES
|
||||||
chrome_elf.dll
|
chrome_elf.dll
|
||||||
|
d3dcompiler_47.dll
|
||||||
libcef.dll
|
libcef.dll
|
||||||
libEGL.dll
|
libEGL.dll
|
||||||
libGLESv2.dll
|
libGLESv2.dll
|
||||||
@@ -480,9 +555,10 @@ if(OS_WINDOWS)
|
|||||||
vulkan-1.dll
|
vulkan-1.dll
|
||||||
)
|
)
|
||||||
|
|
||||||
if(NOT PROJECT_ARCH STREQUAL "arm64")
|
if(PROJECT_ARCH STREQUAL "x86_64")
|
||||||
list(APPEND CEF_BINARY_FILES
|
list(APPEND CEF_BINARY_FILES
|
||||||
d3dcompiler_47.dll
|
dxil.dll
|
||||||
|
dxcompiler.dll
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
@@ -509,14 +585,18 @@ if(OS_WINDOWS)
|
|||||||
Advapi32.lib
|
Advapi32.lib
|
||||||
dbghelp.lib
|
dbghelp.lib
|
||||||
Delayimp.lib
|
Delayimp.lib
|
||||||
|
ntdll.lib
|
||||||
OleAut32.lib
|
OleAut32.lib
|
||||||
PowrProf.lib
|
PowrProf.lib
|
||||||
Propsys.lib
|
Propsys.lib
|
||||||
psapi.lib
|
psapi.lib
|
||||||
SetupAPI.lib
|
SetupAPI.lib
|
||||||
Shell32.lib
|
Shell32.lib
|
||||||
|
Shcore.lib
|
||||||
|
Userenv.lib
|
||||||
version.lib
|
version.lib
|
||||||
wbemuuid.lib
|
wbemuuid.lib
|
||||||
|
WindowsApp.lib
|
||||||
winmm.lib
|
winmm.lib
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@@ -73,8 +73,9 @@ class AutoReset {
|
|||||||
}
|
}
|
||||||
|
|
||||||
~AutoReset() {
|
~AutoReset() {
|
||||||
if (scoped_variable_)
|
if (scoped_variable_) {
|
||||||
*scoped_variable_ = std::move(original_value_);
|
*scoped_variable_ = std::move(original_value_);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@@ -71,7 +71,7 @@
|
|||||||
|
|
||||||
#if defined(USING_CHROMIUM_INCLUDES)
|
#if defined(USING_CHROMIUM_INCLUDES)
|
||||||
// When building CEF include the Chromium header directly.
|
// When building CEF include the Chromium header directly.
|
||||||
#include "base/bind.h"
|
#include "base/functional/bind.h"
|
||||||
#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
|
||||||
@@ -84,7 +84,6 @@
|
|||||||
|
|
||||||
#include "include/base/cef_build.h"
|
#include "include/base/cef_build.h"
|
||||||
#include "include/base/cef_compiler_specific.h"
|
#include "include/base/cef_compiler_specific.h"
|
||||||
#include "include/base/cef_template_util.h"
|
|
||||||
#include "include/base/internal/cef_bind_internal.h"
|
#include "include/base/internal/cef_bind_internal.h"
|
||||||
|
|
||||||
#if defined(OS_APPLE) && !HAS_FEATURE(objc_arc)
|
#if defined(OS_APPLE) && !HAS_FEATURE(objc_arc)
|
||||||
@@ -97,35 +96,34 @@ namespace base {
|
|||||||
/// Bind as OnceCallback.
|
/// Bind as OnceCallback.
|
||||||
///
|
///
|
||||||
template <typename Functor, typename... Args>
|
template <typename Functor, typename... Args>
|
||||||
inline OnceCallback<internal::MakeUnboundRunType<Functor, Args...>> BindOnce(
|
inline OnceCallback<cef_internal::MakeUnboundRunType<Functor, Args...>>
|
||||||
Functor&& functor,
|
BindOnce(Functor&& functor, Args&&... args) {
|
||||||
Args&&... args) {
|
static_assert(!cef_internal::IsOnceCallback<std::decay_t<Functor>>() ||
|
||||||
static_assert(!internal::IsOnceCallback<std::decay_t<Functor>>() ||
|
|
||||||
(std::is_rvalue_reference<Functor&&>() &&
|
(std::is_rvalue_reference<Functor&&>() &&
|
||||||
!std::is_const<std::remove_reference_t<Functor>>()),
|
!std::is_const<std::remove_reference_t<Functor>>()),
|
||||||
"BindOnce requires non-const rvalue for OnceCallback binding."
|
"BindOnce requires non-const rvalue for OnceCallback binding."
|
||||||
" I.e.: base::BindOnce(std::move(callback)).");
|
" I.e.: base::BindOnce(std::move(callback)).");
|
||||||
static_assert(
|
static_assert(
|
||||||
conjunction<
|
std::conjunction<cef_internal::AssertBindArgIsNotBasePassed<
|
||||||
internal::AssertBindArgIsNotBasePassed<std::decay_t<Args>>...>::value,
|
std::decay_t<Args>>...>::value,
|
||||||
"Use std::move() instead of base::Passed() with base::BindOnce()");
|
"Use std::move() instead of base::Passed() with base::BindOnce()");
|
||||||
|
|
||||||
return internal::BindImpl<OnceCallback>(std::forward<Functor>(functor),
|
return cef_internal::BindImpl<OnceCallback>(std::forward<Functor>(functor),
|
||||||
std::forward<Args>(args)...);
|
std::forward<Args>(args)...);
|
||||||
}
|
}
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Bind as RepeatingCallback.
|
/// Bind as RepeatingCallback.
|
||||||
///
|
///
|
||||||
template <typename Functor, typename... Args>
|
template <typename Functor, typename... Args>
|
||||||
inline RepeatingCallback<internal::MakeUnboundRunType<Functor, Args...>>
|
inline RepeatingCallback<cef_internal::MakeUnboundRunType<Functor, Args...>>
|
||||||
BindRepeating(Functor&& functor, Args&&... args) {
|
BindRepeating(Functor&& functor, Args&&... args) {
|
||||||
static_assert(
|
static_assert(
|
||||||
!internal::IsOnceCallback<std::decay_t<Functor>>(),
|
!cef_internal::IsOnceCallback<std::decay_t<Functor>>(),
|
||||||
"BindRepeating cannot bind OnceCallback. Use BindOnce with std::move().");
|
"BindRepeating cannot bind OnceCallback. Use BindOnce with std::move().");
|
||||||
|
|
||||||
return internal::BindImpl<RepeatingCallback>(std::forward<Functor>(functor),
|
return cef_internal::BindImpl<RepeatingCallback>(
|
||||||
std::forward<Args>(args)...);
|
std::forward<Functor>(functor), std::forward<Args>(args)...);
|
||||||
}
|
}
|
||||||
|
|
||||||
///
|
///
|
||||||
@@ -175,8 +173,8 @@ RepeatingCallback<Signature> BindRepeating(
|
|||||||
/// to compile because Foo does not support the AddRef() and Release() methods.
|
/// to compile because Foo does not support the AddRef() and Release() methods.
|
||||||
///
|
///
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline internal::UnretainedWrapper<T> Unretained(T* o) {
|
inline cef_internal::UnretainedWrapper<T> Unretained(T* o) {
|
||||||
return internal::UnretainedWrapper<T>(o);
|
return cef_internal::UnretainedWrapper<T>(o);
|
||||||
}
|
}
|
||||||
|
|
||||||
///
|
///
|
||||||
@@ -201,12 +199,12 @@ inline internal::UnretainedWrapper<T> Unretained(T* o) {
|
|||||||
/// </pre>
|
/// </pre>
|
||||||
///
|
///
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline internal::RetainedRefWrapper<T> RetainedRef(T* o) {
|
inline cef_internal::RetainedRefWrapper<T> RetainedRef(T* o) {
|
||||||
return internal::RetainedRefWrapper<T>(o);
|
return cef_internal::RetainedRefWrapper<T>(o);
|
||||||
}
|
}
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline internal::RetainedRefWrapper<T> RetainedRef(scoped_refptr<T> o) {
|
inline cef_internal::RetainedRefWrapper<T> RetainedRef(scoped_refptr<T> o) {
|
||||||
return internal::RetainedRefWrapper<T>(std::move(o));
|
return cef_internal::RetainedRefWrapper<T>(std::move(o));
|
||||||
}
|
}
|
||||||
|
|
||||||
///
|
///
|
||||||
@@ -234,14 +232,14 @@ inline internal::RetainedRefWrapper<T> RetainedRef(scoped_refptr<T> o) {
|
|||||||
/// reference to the callback is deleted.
|
/// reference to the callback is deleted.
|
||||||
///
|
///
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline internal::OwnedWrapper<T> Owned(T* o) {
|
inline cef_internal::OwnedWrapper<T> Owned(T* o) {
|
||||||
return internal::OwnedWrapper<T>(o);
|
return cef_internal::OwnedWrapper<T>(o);
|
||||||
}
|
}
|
||||||
|
|
||||||
template <typename T, typename Deleter>
|
template <typename T, typename Deleter>
|
||||||
inline internal::OwnedWrapper<T, Deleter> Owned(
|
inline cef_internal::OwnedWrapper<T, Deleter> Owned(
|
||||||
std::unique_ptr<T, Deleter>&& ptr) {
|
std::unique_ptr<T, Deleter>&& ptr) {
|
||||||
return internal::OwnedWrapper<T, Deleter>(std::move(ptr));
|
return cef_internal::OwnedWrapper<T, Deleter>(std::move(ptr));
|
||||||
}
|
}
|
||||||
|
|
||||||
///
|
///
|
||||||
@@ -277,8 +275,8 @@ inline internal::OwnedWrapper<T, Deleter> Owned(
|
|||||||
/// an object owned by the callback.
|
/// an object owned by the callback.
|
||||||
///
|
///
|
||||||
template <typename T>
|
template <typename T>
|
||||||
internal::OwnedRefWrapper<std::decay_t<T>> OwnedRef(T&& t) {
|
cef_internal::OwnedRefWrapper<std::decay_t<T>> OwnedRef(T&& t) {
|
||||||
return internal::OwnedRefWrapper<std::decay_t<T>>(std::forward<T>(t));
|
return cef_internal::OwnedRefWrapper<std::decay_t<T>>(std::forward<T>(t));
|
||||||
}
|
}
|
||||||
|
|
||||||
///
|
///
|
||||||
@@ -329,12 +327,12 @@ internal::OwnedRefWrapper<std::decay_t<T>> OwnedRef(T&& t) {
|
|||||||
///
|
///
|
||||||
template <typename T,
|
template <typename T,
|
||||||
std::enable_if_t<!std::is_lvalue_reference<T>::value>* = nullptr>
|
std::enable_if_t<!std::is_lvalue_reference<T>::value>* = nullptr>
|
||||||
inline internal::PassedWrapper<T> Passed(T&& scoper) {
|
inline cef_internal::PassedWrapper<T> Passed(T&& scoper) {
|
||||||
return internal::PassedWrapper<T>(std::move(scoper));
|
return cef_internal::PassedWrapper<T>(std::move(scoper));
|
||||||
}
|
}
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline internal::PassedWrapper<T> Passed(T* scoper) {
|
inline cef_internal::PassedWrapper<T> Passed(T* scoper) {
|
||||||
return internal::PassedWrapper<T>(std::move(*scoper));
|
return cef_internal::PassedWrapper<T>(std::move(*scoper));
|
||||||
}
|
}
|
||||||
|
|
||||||
///
|
///
|
||||||
@@ -357,8 +355,8 @@ inline internal::PassedWrapper<T> Passed(T* scoper) {
|
|||||||
/// </pre>
|
/// </pre>
|
||||||
///
|
///
|
||||||
template <typename T>
|
template <typename T>
|
||||||
inline internal::IgnoreResultHelper<T> IgnoreResult(T data) {
|
inline cef_internal::IgnoreResultHelper<T> IgnoreResult(T data) {
|
||||||
return internal::IgnoreResultHelper<T>(std::move(data));
|
return cef_internal::IgnoreResultHelper<T>(std::move(data));
|
||||||
}
|
}
|
||||||
|
|
||||||
#if defined(OS_APPLE) && !HAS_FEATURE(objc_arc)
|
#if defined(OS_APPLE) && !HAS_FEATURE(objc_arc)
|
||||||
|
@@ -69,7 +69,24 @@
|
|||||||
#if defined(USING_CHROMIUM_INCLUDES)
|
#if defined(USING_CHROMIUM_INCLUDES)
|
||||||
// When building CEF include the Chromium header directly.
|
// When building CEF include the Chromium header directly.
|
||||||
#include "build/build_config.h"
|
#include "build/build_config.h"
|
||||||
|
#include "cef/libcef/features/features.h"
|
||||||
|
|
||||||
|
// The following #defines are used in cef/include/ headers and CEF client-side
|
||||||
|
// code. CEF library-side code should use BUILDFLAG checks directly instead of
|
||||||
|
// these #defines. CEF client-side code will get these #defines from
|
||||||
|
// cef_config.h so any changes must also be reflected in
|
||||||
|
// tools/make_config_header.py.
|
||||||
|
|
||||||
|
#if BUILDFLAG(IS_LINUX)
|
||||||
|
#include "ui/base/ozone_buildflags.h"
|
||||||
|
#if BUILDFLAG(IS_OZONE_X11)
|
||||||
|
#define CEF_X11 1
|
||||||
|
#endif
|
||||||
|
#endif
|
||||||
|
|
||||||
#else // !USING_CHROMIUM_INCLUDES
|
#else // !USING_CHROMIUM_INCLUDES
|
||||||
|
#include "include/cef_config.h"
|
||||||
|
|
||||||
// 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
|
||||||
// updated to match.
|
// updated to match.
|
||||||
@@ -232,19 +249,19 @@
|
|||||||
|
|
||||||
// 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_16_BIT
|
||||||
#elif defined(OS_FUCHSIA)
|
#elif defined(OS_FUCHSIA)
|
||||||
#define WCHAR_T_IS_UTF32
|
#define WCHAR_T_IS_32_BIT
|
||||||
#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_32_BIT
|
||||||
#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
|
||||||
// other projects using base who manage their own dependencies and make sure
|
// other projects using base who manage their own dependencies and make sure
|
||||||
// short wchar works for them.
|
// short wchar works for them.
|
||||||
#define WCHAR_T_IS_UTF16
|
#define WCHAR_T_IS_16_BIT
|
||||||
#else
|
#else
|
||||||
#error Please add support for your compiler in include/base/cef_build.h
|
#error Please add support for your compiler in include/base/cef_build.h
|
||||||
#endif
|
#endif
|
||||||
@@ -253,7 +270,7 @@
|
|||||||
// The compiler thinks std::string::const_iterator and "const char*" are
|
// The compiler thinks std::string::const_iterator and "const char*" are
|
||||||
// equivalent types.
|
// equivalent types.
|
||||||
#define STD_STRING_ITERATOR_IS_CHAR_POINTER
|
#define STD_STRING_ITERATOR_IS_CHAR_POINTER
|
||||||
// The compiler thinks std::u16string::const_iterator and "char16*" are
|
// The compiler thinks std::u16string::const_iterator and "char16_t*" are
|
||||||
// equivalent types.
|
// equivalent types.
|
||||||
#define BASE_STRING16_ITERATOR_IS_CHAR16_POINTER
|
#define BASE_STRING16_ITERATOR_IS_CHAR16_POINTER
|
||||||
#endif
|
#endif
|
||||||
|
@@ -67,7 +67,7 @@
|
|||||||
|
|
||||||
#if defined(USING_CHROMIUM_INCLUDES)
|
#if defined(USING_CHROMIUM_INCLUDES)
|
||||||
// When building CEF include the Chromium header directly.
|
// When building CEF include the Chromium header directly.
|
||||||
#include "base/callback.h"
|
#include "base/functional/callback.h"
|
||||||
#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
|
||||||
@@ -83,18 +83,18 @@
|
|||||||
namespace base {
|
namespace base {
|
||||||
|
|
||||||
template <typename R, typename... Args>
|
template <typename R, typename... Args>
|
||||||
class OnceCallback<R(Args...)> : public internal::CallbackBase {
|
class OnceCallback<R(Args...)> : public cef_internal::CallbackBase {
|
||||||
public:
|
public:
|
||||||
using ResultType = R;
|
using ResultType = R;
|
||||||
using RunType = R(Args...);
|
using RunType = R(Args...);
|
||||||
using PolymorphicInvoke = R (*)(internal::BindStateBase*,
|
using PolymorphicInvoke = R (*)(cef_internal::BindStateBase*,
|
||||||
internal::PassingType<Args>...);
|
cef_internal::PassingType<Args>...);
|
||||||
|
|
||||||
constexpr OnceCallback() = default;
|
constexpr OnceCallback() = default;
|
||||||
OnceCallback(std::nullptr_t) = delete;
|
OnceCallback(std::nullptr_t) = delete;
|
||||||
|
|
||||||
explicit OnceCallback(internal::BindStateBase* bind_state)
|
explicit OnceCallback(cef_internal::BindStateBase* bind_state)
|
||||||
: internal::CallbackBase(bind_state) {}
|
: cef_internal::CallbackBase(bind_state) {}
|
||||||
|
|
||||||
OnceCallback(const OnceCallback&) = delete;
|
OnceCallback(const OnceCallback&) = delete;
|
||||||
OnceCallback& operator=(const OnceCallback&) = delete;
|
OnceCallback& operator=(const OnceCallback&) = delete;
|
||||||
@@ -103,10 +103,10 @@ class OnceCallback<R(Args...)> : public internal::CallbackBase {
|
|||||||
OnceCallback& operator=(OnceCallback&&) noexcept = default;
|
OnceCallback& operator=(OnceCallback&&) noexcept = default;
|
||||||
|
|
||||||
OnceCallback(RepeatingCallback<RunType> other)
|
OnceCallback(RepeatingCallback<RunType> other)
|
||||||
: internal::CallbackBase(std::move(other)) {}
|
: cef_internal::CallbackBase(std::move(other)) {}
|
||||||
|
|
||||||
OnceCallback& operator=(RepeatingCallback<RunType> other) {
|
OnceCallback& operator=(RepeatingCallback<RunType> other) {
|
||||||
static_cast<internal::CallbackBase&>(*this) = std::move(other);
|
static_cast<cef_internal::CallbackBase&>(*this) = std::move(other);
|
||||||
return *this;
|
return *this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -142,7 +142,7 @@ class OnceCallback<R(Args...)> : public internal::CallbackBase {
|
|||||||
OnceCallback<ThenR(Args...)> Then(OnceCallback<ThenR(ThenArgs...)> then) && {
|
OnceCallback<ThenR(Args...)> Then(OnceCallback<ThenR(ThenArgs...)> then) && {
|
||||||
CHECK(then);
|
CHECK(then);
|
||||||
return BindOnce(
|
return BindOnce(
|
||||||
internal::ThenHelper<
|
cef_internal::ThenHelper<
|
||||||
OnceCallback, OnceCallback<ThenR(ThenArgs...)>>::CreateTrampoline(),
|
OnceCallback, OnceCallback<ThenR(ThenArgs...)>>::CreateTrampoline(),
|
||||||
std::move(*this), std::move(then));
|
std::move(*this), std::move(then));
|
||||||
}
|
}
|
||||||
@@ -155,7 +155,7 @@ class OnceCallback<R(Args...)> : public internal::CallbackBase {
|
|||||||
RepeatingCallback<ThenR(ThenArgs...)> then) && {
|
RepeatingCallback<ThenR(ThenArgs...)> then) && {
|
||||||
CHECK(then);
|
CHECK(then);
|
||||||
return BindOnce(
|
return BindOnce(
|
||||||
internal::ThenHelper<
|
cef_internal::ThenHelper<
|
||||||
OnceCallback,
|
OnceCallback,
|
||||||
RepeatingCallback<ThenR(ThenArgs...)>>::CreateTrampoline(),
|
RepeatingCallback<ThenR(ThenArgs...)>>::CreateTrampoline(),
|
||||||
std::move(*this), std::move(then));
|
std::move(*this), std::move(then));
|
||||||
@@ -163,18 +163,19 @@ class OnceCallback<R(Args...)> : public internal::CallbackBase {
|
|||||||
};
|
};
|
||||||
|
|
||||||
template <typename R, typename... Args>
|
template <typename R, typename... Args>
|
||||||
class RepeatingCallback<R(Args...)> : public internal::CallbackBaseCopyable {
|
class RepeatingCallback<R(Args...)>
|
||||||
|
: public cef_internal::CallbackBaseCopyable {
|
||||||
public:
|
public:
|
||||||
using ResultType = R;
|
using ResultType = R;
|
||||||
using RunType = R(Args...);
|
using RunType = R(Args...);
|
||||||
using PolymorphicInvoke = R (*)(internal::BindStateBase*,
|
using PolymorphicInvoke = R (*)(cef_internal::BindStateBase*,
|
||||||
internal::PassingType<Args>...);
|
cef_internal::PassingType<Args>...);
|
||||||
|
|
||||||
constexpr RepeatingCallback() = default;
|
constexpr RepeatingCallback() = default;
|
||||||
RepeatingCallback(std::nullptr_t) = delete;
|
RepeatingCallback(std::nullptr_t) = delete;
|
||||||
|
|
||||||
explicit RepeatingCallback(internal::BindStateBase* bind_state)
|
explicit RepeatingCallback(cef_internal::BindStateBase* bind_state)
|
||||||
: internal::CallbackBaseCopyable(bind_state) {}
|
: cef_internal::CallbackBaseCopyable(bind_state) {}
|
||||||
|
|
||||||
// Copyable and movable.
|
// Copyable and movable.
|
||||||
RepeatingCallback(const RepeatingCallback&) = default;
|
RepeatingCallback(const RepeatingCallback&) = default;
|
||||||
@@ -224,7 +225,7 @@ class RepeatingCallback<R(Args...)> : public internal::CallbackBaseCopyable {
|
|||||||
RepeatingCallback<ThenR(ThenArgs...)> then) const& {
|
RepeatingCallback<ThenR(ThenArgs...)> then) const& {
|
||||||
CHECK(then);
|
CHECK(then);
|
||||||
return BindRepeating(
|
return BindRepeating(
|
||||||
internal::ThenHelper<
|
cef_internal::ThenHelper<
|
||||||
RepeatingCallback,
|
RepeatingCallback,
|
||||||
RepeatingCallback<ThenR(ThenArgs...)>>::CreateTrampoline(),
|
RepeatingCallback<ThenR(ThenArgs...)>>::CreateTrampoline(),
|
||||||
*this, std::move(then));
|
*this, std::move(then));
|
||||||
@@ -235,7 +236,7 @@ class RepeatingCallback<R(Args...)> : public internal::CallbackBaseCopyable {
|
|||||||
RepeatingCallback<ThenR(ThenArgs...)> then) && {
|
RepeatingCallback<ThenR(ThenArgs...)> then) && {
|
||||||
CHECK(then);
|
CHECK(then);
|
||||||
return BindRepeating(
|
return BindRepeating(
|
||||||
internal::ThenHelper<
|
cef_internal::ThenHelper<
|
||||||
RepeatingCallback,
|
RepeatingCallback,
|
||||||
RepeatingCallback<ThenR(ThenArgs...)>>::CreateTrampoline(),
|
RepeatingCallback<ThenR(ThenArgs...)>>::CreateTrampoline(),
|
||||||
std::move(*this), std::move(then));
|
std::move(*this), std::move(then));
|
||||||
|
@@ -34,7 +34,7 @@
|
|||||||
|
|
||||||
#if defined(USING_CHROMIUM_INCLUDES)
|
#if defined(USING_CHROMIUM_INCLUDES)
|
||||||
// When building CEF include the Chromium header directly.
|
// When building CEF include the Chromium header directly.
|
||||||
#include "base/callback_forward.h"
|
#include "base/functional/callback_forward.h"
|
||||||
#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
|
||||||
|
@@ -39,7 +39,7 @@
|
|||||||
|
|
||||||
#if defined(USING_CHROMIUM_INCLUDES)
|
#if defined(USING_CHROMIUM_INCLUDES)
|
||||||
// When building CEF include the Chromium header directly.
|
// When building CEF include the Chromium header directly.
|
||||||
#include "base/callback_helpers.h"
|
#include "base/functional/callback_helpers.h"
|
||||||
#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
|
||||||
|
@@ -86,7 +86,7 @@
|
|||||||
|
|
||||||
#if defined(USING_CHROMIUM_INCLUDES)
|
#if defined(USING_CHROMIUM_INCLUDES)
|
||||||
// When building CEF include the Chromium header directly.
|
// When building CEF include the Chromium header directly.
|
||||||
#include "base/callback_list.h"
|
#include "base/functional/callback_list.h"
|
||||||
#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
|
||||||
@@ -242,8 +242,9 @@ class CallbackListBase {
|
|||||||
// the reentrant Notify() call.
|
// the reentrant Notify() call.
|
||||||
template <typename... RunArgs>
|
template <typename... RunArgs>
|
||||||
void Notify(RunArgs&&... args) {
|
void Notify(RunArgs&&... args) {
|
||||||
if (empty())
|
if (empty()) {
|
||||||
return; // Nothing to do.
|
return; // Nothing to do.
|
||||||
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
AutoReset<bool> iterating(&iterating_, true);
|
AutoReset<bool> iterating(&iterating_, true);
|
||||||
@@ -257,18 +258,20 @@ class CallbackListBase {
|
|||||||
});
|
});
|
||||||
};
|
};
|
||||||
for (auto it = next_valid(callbacks_.begin()); it != callbacks_.end();
|
for (auto it = next_valid(callbacks_.begin()); it != callbacks_.end();
|
||||||
it = next_valid(it))
|
it = next_valid(it)) {
|
||||||
// NOTE: Intentionally does not call std::forward<RunArgs>(args)...,
|
// NOTE: Intentionally does not call std::forward<RunArgs>(args)...,
|
||||||
// since that would allow move-only arguments.
|
// since that would allow move-only arguments.
|
||||||
static_cast<CallbackListImpl*>(this)->RunCallback(it++, args...);
|
static_cast<CallbackListImpl*>(this)->RunCallback(it++, args...);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Re-entrant invocations shouldn't prune anything from the list. This can
|
// Re-entrant invocations shouldn't prune anything from the list. This can
|
||||||
// invalidate iterators from underneath higher call frames. It's safe to
|
// invalidate iterators from underneath higher call frames. It's safe to
|
||||||
// simply do nothing, since the outermost frame will continue through here
|
// simply do nothing, since the outermost frame will continue through here
|
||||||
// and prune all null callbacks below.
|
// and prune all null callbacks below.
|
||||||
if (iterating_)
|
if (iterating_) {
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
// Any null callbacks remaining in the list were canceled due to
|
// Any null callbacks remaining in the list were canceled due to
|
||||||
// Subscription destruction during iteration, and can safely be erased now.
|
// Subscription destruction during iteration, and can safely be erased now.
|
||||||
@@ -282,8 +285,9 @@ class CallbackListBase {
|
|||||||
// that were executed above have all been removed regardless of whether
|
// that were executed above have all been removed regardless of whether
|
||||||
// they're counted in |erased_callbacks_|.
|
// they're counted in |erased_callbacks_|.
|
||||||
if (removal_callback_ &&
|
if (removal_callback_ &&
|
||||||
(erased_callbacks || IsOnceCallback<CallbackType>::value))
|
(erased_callbacks || IsOnceCallback<CallbackType>::value)) {
|
||||||
removal_callback_.Run(); // May delete |this|!
|
removal_callback_.Run(); // May delete |this|!
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
@@ -295,8 +299,9 @@ class CallbackListBase {
|
|||||||
private:
|
private:
|
||||||
// Cancels the callback pointed to by |it|, which is guaranteed to be valid.
|
// Cancels the callback pointed to by |it|, which is guaranteed to be valid.
|
||||||
void CancelCallback(const typename Callbacks::iterator& it) {
|
void CancelCallback(const typename Callbacks::iterator& it) {
|
||||||
if (static_cast<CallbackListImpl*>(this)->CancelNullCallback(it))
|
if (static_cast<CallbackListImpl*>(this)->CancelNullCallback(it)) {
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (iterating_) {
|
if (iterating_) {
|
||||||
// Calling erase() here is unsafe, since the loop in Notify() may be
|
// Calling erase() here is unsafe, since the loop in Notify() may be
|
||||||
@@ -306,8 +311,9 @@ class CallbackListBase {
|
|||||||
it->Reset();
|
it->Reset();
|
||||||
} else {
|
} else {
|
||||||
callbacks_.erase(it);
|
callbacks_.erase(it);
|
||||||
if (removal_callback_)
|
if (removal_callback_) {
|
||||||
removal_callback_.Run(); // May delete |this|!
|
removal_callback_.Run(); // May delete |this|!
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -133,8 +133,9 @@ class CancelableCallbackImpl {
|
|||||||
|
|
||||||
// Returns a callback that can be disabled by calling Cancel().
|
// Returns a callback that can be disabled by calling Cancel().
|
||||||
CallbackType callback() const {
|
CallbackType callback() const {
|
||||||
if (!callback_)
|
if (!callback_) {
|
||||||
return CallbackType();
|
return CallbackType();
|
||||||
|
}
|
||||||
CallbackType forwarder;
|
CallbackType forwarder;
|
||||||
MakeForwarder(&forwarder);
|
MakeForwarder(&forwarder);
|
||||||
return forwarder;
|
return forwarder;
|
||||||
|
@@ -251,13 +251,6 @@
|
|||||||
#define HAS_FEATURE(FEATURE) 0
|
#define HAS_FEATURE(FEATURE) 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// Macro for telling -Wimplicit-fallthrough that a fallthrough is intentional.
|
|
||||||
#if defined(__clang__)
|
|
||||||
#define FALLTHROUGH [[clang::fallthrough]]
|
|
||||||
#else
|
|
||||||
#define FALLTHROUGH
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(COMPILER_GCC)
|
#if defined(COMPILER_GCC)
|
||||||
#define PRETTY_FUNCTION __PRETTY_FUNCTION__
|
#define PRETTY_FUNCTION __PRETTY_FUNCTION__
|
||||||
#elif defined(COMPILER_MSVC)
|
#elif defined(COMPILER_MSVC)
|
||||||
|
76
include/base/cef_dump_without_crashing.h
Normal file
76
include/base/cef_dump_without_crashing.h
Normal file
@@ -0,0 +1,76 @@
|
|||||||
|
// Copyright (c) 2024 Marshall A. Greenblatt. Portions copyright (c) 2012
|
||||||
|
// Google Inc. 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.
|
||||||
|
|
||||||
|
///
|
||||||
|
/// \file
|
||||||
|
/// Provides functions for generating crash dumps.
|
||||||
|
///
|
||||||
|
/// NOTE: The contents of this file are only available to applications that link
|
||||||
|
/// against the libcef_dll_wrapper target.
|
||||||
|
///
|
||||||
|
/// NOTE: Ensure crash reporting is configured before use. See
|
||||||
|
/// https://bitbucket.org/chromiumembedded/cef/wiki/CrashReporting.md for more
|
||||||
|
/// information
|
||||||
|
///
|
||||||
|
/// WARNING: Crash reporting should not be used in the main/browser process
|
||||||
|
/// before calling CefInitialize or in sub-processes before CefExecuteProcess.
|
||||||
|
///
|
||||||
|
|
||||||
|
#ifndef CEF_INCLUDE_BASE_CEF_DUMP_WITHOUT_CRASHING_H_
|
||||||
|
#define CEF_INCLUDE_BASE_CEF_DUMP_WITHOUT_CRASHING_H_
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
constexpr long long kOneDayInMilliseconds = 86400000;
|
||||||
|
|
||||||
|
///
|
||||||
|
/// CefDumpWithoutCrashing allows for generating crash dumps with a throttling
|
||||||
|
/// mechanism, preventing frequent dumps from being generated in a short period
|
||||||
|
/// of time from the same location. The |function_name|, |file_name|, and
|
||||||
|
/// |line_number| determine the location of the dump. The
|
||||||
|
/// |mseconds_between_dumps| is an interval between consecutive dumps in
|
||||||
|
/// milliseconds from the same location.
|
||||||
|
///
|
||||||
|
/// Returns true if the dump was successfully generated, false otherwise.
|
||||||
|
///
|
||||||
|
bool CefDumpWithoutCrashing(
|
||||||
|
long long mseconds_between_dumps = kOneDayInMilliseconds,
|
||||||
|
const char* function_name = __builtin_FUNCTION(),
|
||||||
|
const char* file_name = __builtin_FILE(),
|
||||||
|
int line_number = __builtin_LINE());
|
||||||
|
|
||||||
|
///
|
||||||
|
/// CefDumpWithoutCrashingUnthrottled allows for immediate crash dumping without
|
||||||
|
/// any throttling constraints.
|
||||||
|
///
|
||||||
|
/// Returns true if the dump was successfully generated, false otherwise.
|
||||||
|
///
|
||||||
|
bool CefDumpWithoutCrashingUnthrottled();
|
||||||
|
|
||||||
|
#endif // CEF_INCLUDE_BASE_CEF_DUMP_WITHOUT_CRASHING_H_
|
@@ -723,6 +723,13 @@ std::ostream& operator<<(std::ostream& out, const wchar_t* wstr);
|
|||||||
inline std::ostream& operator<<(std::ostream& out, const std::wstring& wstr) {
|
inline std::ostream& operator<<(std::ostream& out, const std::wstring& wstr) {
|
||||||
return out << wstr.c_str();
|
return out << wstr.c_str();
|
||||||
}
|
}
|
||||||
|
#if defined(WCHAR_T_IS_32_BIT)
|
||||||
|
std::ostream& operator<<(std::ostream& out, const char16_t* wstr);
|
||||||
|
#elif defined(WCHAR_T_IS_16_BIT)
|
||||||
|
inline std::ostream& operator<<(std::ostream& out, const char16_t* wstr) {
|
||||||
|
return operator<<(out, reinterpret_cast<const wchar_t*>(wstr));
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
// The NOTIMPLEMENTED() macro annotates codepaths which have
|
// The NOTIMPLEMENTED() macro annotates codepaths which have
|
||||||
// not been implemented yet.
|
// not been implemented yet.
|
||||||
|
@@ -43,7 +43,6 @@
|
|||||||
// 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/cef_basictypes.h"
|
|
||||||
#include "include/base/cef_build.h"
|
#include "include/base/cef_build.h"
|
||||||
#include "include/internal/cef_thread_internal.h"
|
#include "include/internal/cef_thread_internal.h"
|
||||||
|
|
||||||
|
@@ -50,7 +50,6 @@
|
|||||||
#include "include/base/cef_compiler_specific.h"
|
#include "include/base/cef_compiler_specific.h"
|
||||||
#include "include/base/cef_logging.h"
|
#include "include/base/cef_logging.h"
|
||||||
#include "include/base/cef_scoped_refptr.h"
|
#include "include/base/cef_scoped_refptr.h"
|
||||||
#include "include/base/cef_template_util.h"
|
|
||||||
#include "include/base/cef_thread_checker.h"
|
#include "include/base/cef_thread_checker.h"
|
||||||
|
|
||||||
namespace base {
|
namespace base {
|
||||||
@@ -105,13 +104,16 @@ class RefCountedBase {
|
|||||||
|
|
||||||
#if DCHECK_IS_ON()
|
#if DCHECK_IS_ON()
|
||||||
DCHECK(!in_dtor_);
|
DCHECK(!in_dtor_);
|
||||||
if (ref_count_ == 0)
|
if (ref_count_ == 0) {
|
||||||
in_dtor_ = true;
|
in_dtor_ = true;
|
||||||
|
}
|
||||||
|
|
||||||
if (ref_count_ >= 1)
|
if (ref_count_ >= 1) {
|
||||||
DCHECK(CalledOnValidThread());
|
DCHECK(CalledOnValidThread());
|
||||||
if (ref_count_ == 1)
|
}
|
||||||
|
if (ref_count_ == 1) {
|
||||||
thread_checker_.DetachFromThread();
|
thread_checker_.DetachFromThread();
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
return ref_count_ == 0;
|
return ref_count_ == 0;
|
||||||
@@ -482,7 +484,7 @@ class RefCountedData
|
|||||||
RefCountedData(const T& in_value) : data(in_value) {}
|
RefCountedData(const T& in_value) : data(in_value) {}
|
||||||
RefCountedData(T&& in_value) : data(std::move(in_value)) {}
|
RefCountedData(T&& in_value) : data(std::move(in_value)) {}
|
||||||
template <typename... Args>
|
template <typename... Args>
|
||||||
explicit RefCountedData(in_place_t, Args&&... args)
|
explicit RefCountedData(std::in_place_t, Args&&... args)
|
||||||
: data(std::forward<Args>(args)...) {}
|
: data(std::forward<Args>(args)...) {}
|
||||||
|
|
||||||
T data;
|
T data;
|
||||||
|
@@ -229,8 +229,9 @@ class TRIVIAL_ABI scoped_refptr {
|
|||||||
// should move or copy construct from an existing scoped_refptr<T> to the
|
// should move or copy construct from an existing scoped_refptr<T> to the
|
||||||
// ref-counted object.
|
// ref-counted object.
|
||||||
scoped_refptr(T* p) : ptr_(p) {
|
scoped_refptr(T* p) : ptr_(p) {
|
||||||
if (ptr_)
|
if (ptr_) {
|
||||||
AddRef(ptr_);
|
AddRef(ptr_);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// Copy constructor. This is required in addition to the copy conversion
|
// Copy constructor. This is required in addition to the copy conversion
|
||||||
@@ -261,8 +262,9 @@ class TRIVIAL_ABI scoped_refptr {
|
|||||||
"It's unsafe to override the ref count preference."
|
"It's unsafe to override the ref count preference."
|
||||||
" Please remove REQUIRE_ADOPTION_FOR_REFCOUNTED_TYPE"
|
" Please remove REQUIRE_ADOPTION_FOR_REFCOUNTED_TYPE"
|
||||||
" from subclasses.");
|
" from subclasses.");
|
||||||
if (ptr_)
|
if (ptr_) {
|
||||||
Release(ptr_);
|
Release(ptr_);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
T* get() const { return ptr_; }
|
T* get() const { return ptr_; }
|
||||||
|
@@ -97,21 +97,24 @@ class ScopedTypeRef {
|
|||||||
element_type object = Traits::InvalidValue(),
|
element_type object = Traits::InvalidValue(),
|
||||||
base::scoped_policy::OwnershipPolicy policy = base::scoped_policy::ASSUME)
|
base::scoped_policy::OwnershipPolicy policy = base::scoped_policy::ASSUME)
|
||||||
: object_(object) {
|
: object_(object) {
|
||||||
if (object_ && policy == base::scoped_policy::RETAIN)
|
if (object_ && policy == base::scoped_policy::RETAIN) {
|
||||||
object_ = Traits::Retain(object_);
|
object_ = Traits::Retain(object_);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ScopedTypeRef(const ScopedTypeRef<T, Traits>& that) : object_(that.object_) {
|
ScopedTypeRef(const ScopedTypeRef<T, Traits>& that) : object_(that.object_) {
|
||||||
if (object_)
|
if (object_) {
|
||||||
object_ = Traits::Retain(object_);
|
object_ = Traits::Retain(object_);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
// This allows passing an object to a function that takes its superclass.
|
// This allows passing an object to a function that takes its superclass.
|
||||||
template <typename R, typename RTraits>
|
template <typename R, typename RTraits>
|
||||||
explicit ScopedTypeRef(const ScopedTypeRef<R, RTraits>& that_as_subclass)
|
explicit ScopedTypeRef(const ScopedTypeRef<R, RTraits>& that_as_subclass)
|
||||||
: object_(that_as_subclass.get()) {
|
: object_(that_as_subclass.get()) {
|
||||||
if (object_)
|
if (object_) {
|
||||||
object_ = Traits::Retain(object_);
|
object_ = Traits::Retain(object_);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ScopedTypeRef(ScopedTypeRef<T, Traits>&& that) : object_(that.object_) {
|
ScopedTypeRef(ScopedTypeRef<T, Traits>&& that) : object_(that.object_) {
|
||||||
@@ -119,8 +122,9 @@ class ScopedTypeRef {
|
|||||||
}
|
}
|
||||||
|
|
||||||
~ScopedTypeRef() {
|
~ScopedTypeRef() {
|
||||||
if (object_)
|
if (object_) {
|
||||||
Traits::Release(object_);
|
Traits::Release(object_);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ScopedTypeRef& operator=(const ScopedTypeRef<T, Traits>& that) {
|
ScopedTypeRef& operator=(const ScopedTypeRef<T, Traits>& that) {
|
||||||
@@ -143,10 +147,12 @@ class ScopedTypeRef {
|
|||||||
void reset(element_type object = Traits::InvalidValue(),
|
void reset(element_type object = Traits::InvalidValue(),
|
||||||
base::scoped_policy::OwnershipPolicy policy =
|
base::scoped_policy::OwnershipPolicy policy =
|
||||||
base::scoped_policy::ASSUME) {
|
base::scoped_policy::ASSUME) {
|
||||||
if (object && policy == base::scoped_policy::RETAIN)
|
if (object && policy == base::scoped_policy::RETAIN) {
|
||||||
object = Traits::Retain(object);
|
object = Traits::Retain(object);
|
||||||
if (object_)
|
}
|
||||||
|
if (object_) {
|
||||||
Traits::Release(object_);
|
Traits::Release(object_);
|
||||||
|
}
|
||||||
object_ = object;
|
object_ = object;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -1,414 +0,0 @@
|
|||||||
// Copyright (c) 2014 Marshall A. Greenblatt. Portions copyright (c) 2011
|
|
||||||
// Google Inc. 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.
|
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_BASE_CEF_TEMPLATE_UTIL_H_
|
|
||||||
#define CEF_INCLUDE_BASE_CEF_TEMPLATE_UTIL_H_
|
|
||||||
#pragma once
|
|
||||||
|
|
||||||
#if defined(USING_CHROMIUM_INCLUDES)
|
|
||||||
// When building CEF include the Chromium header directly.
|
|
||||||
#include "base/template_util.h"
|
|
||||||
#else // !USING_CHROMIUM_INCLUDES
|
|
||||||
// The following is substantially similar to the Chromium implementation.
|
|
||||||
// If the Chromium implementation diverges the below implementation should be
|
|
||||||
// updated to match.
|
|
||||||
|
|
||||||
#include <stddef.h>
|
|
||||||
#include <iosfwd>
|
|
||||||
#include <iterator>
|
|
||||||
#include <type_traits>
|
|
||||||
#include <utility>
|
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
#include "include/base/cef_build.h"
|
|
||||||
|
|
||||||
// Some versions of libstdc++ have partial support for type_traits, but misses
|
|
||||||
// a smaller subset while removing some of the older non-standard stuff. Assume
|
|
||||||
// that all versions below 5.0 fall in this category, along with one 5.0
|
|
||||||
// experimental release. Test for this by consulting compiler major version,
|
|
||||||
// the only reliable option available, so theoretically this could fail should
|
|
||||||
// you attempt to mix an earlier version of libstdc++ with >= GCC5. But
|
|
||||||
// that's unlikely to work out, especially as GCC5 changed ABI.
|
|
||||||
#define CR_GLIBCXX_5_0_0 20150123
|
|
||||||
#if (defined(__GNUC__) && __GNUC__ < 5) || \
|
|
||||||
(defined(__GLIBCXX__) && __GLIBCXX__ == CR_GLIBCXX_5_0_0)
|
|
||||||
#define CR_USE_FALLBACKS_FOR_OLD_EXPERIMENTAL_GLIBCXX
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// This hacks around using gcc with libc++ which has some incompatibilies.
|
|
||||||
// - is_trivially_* doesn't work: https://llvm.org/bugs/show_bug.cgi?id=27538
|
|
||||||
// TODO(danakj): Remove this when android builders are all using a newer version
|
|
||||||
// of gcc, or the android ndk is updated to a newer libc++ that works with older
|
|
||||||
// gcc versions.
|
|
||||||
#if !defined(__clang__) && defined(_LIBCPP_VERSION)
|
|
||||||
#define CR_USE_FALLBACKS_FOR_GCC_WITH_LIBCXX
|
|
||||||
#endif
|
|
||||||
|
|
||||||
namespace base {
|
|
||||||
|
|
||||||
template <class T> struct is_non_const_reference : std::false_type {};
|
|
||||||
template <class T> struct is_non_const_reference<T&> : std::true_type {};
|
|
||||||
template <class T> struct is_non_const_reference<const T&> : std::false_type {};
|
|
||||||
|
|
||||||
namespace internal {
|
|
||||||
|
|
||||||
// Implementation detail of base::void_t below.
|
|
||||||
template <typename...>
|
|
||||||
struct make_void {
|
|
||||||
using type = void;
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace internal
|
|
||||||
|
|
||||||
// base::void_t is an implementation of std::void_t from C++17.
|
|
||||||
//
|
|
||||||
// We use |base::internal::make_void| as a helper struct to avoid a C++14
|
|
||||||
// defect:
|
|
||||||
// http://en.cppreference.com/w/cpp/types/void_t
|
|
||||||
// http://open-std.org/JTC1/SC22/WG21/docs/cwg_defects.html#1558
|
|
||||||
template <typename... Ts>
|
|
||||||
using void_t = typename ::base::internal::make_void<Ts...>::type;
|
|
||||||
|
|
||||||
namespace internal {
|
|
||||||
|
|
||||||
// Uses expression SFINAE to detect whether using operator<< would work.
|
|
||||||
template <typename T, typename = void>
|
|
||||||
struct SupportsOstreamOperator : std::false_type {};
|
|
||||||
template <typename T>
|
|
||||||
struct SupportsOstreamOperator<T,
|
|
||||||
decltype(void(std::declval<std::ostream&>()
|
|
||||||
<< std::declval<T>()))>
|
|
||||||
: std::true_type {};
|
|
||||||
|
|
||||||
template <typename T, typename = void>
|
|
||||||
struct SupportsToString : std::false_type {};
|
|
||||||
template <typename T>
|
|
||||||
struct SupportsToString<T, decltype(void(std::declval<T>().ToString()))>
|
|
||||||
: std::true_type {};
|
|
||||||
|
|
||||||
// Used to detect whether the given type is an iterator. This is normally used
|
|
||||||
// with std::enable_if to provide disambiguation for functions that take
|
|
||||||
// templatzed iterators as input.
|
|
||||||
template <typename T, typename = void>
|
|
||||||
struct is_iterator : std::false_type {};
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
struct is_iterator<T,
|
|
||||||
void_t<typename std::iterator_traits<T>::iterator_category>>
|
|
||||||
: std::true_type {};
|
|
||||||
|
|
||||||
// Helper to express preferences in an overload set. If more than one overload
|
|
||||||
// are available for a given set of parameters the overload with the higher
|
|
||||||
// priority will be chosen.
|
|
||||||
template <size_t I>
|
|
||||||
struct priority_tag : priority_tag<I - 1> {};
|
|
||||||
|
|
||||||
template <>
|
|
||||||
struct priority_tag<0> {};
|
|
||||||
|
|
||||||
} // namespace internal
|
|
||||||
|
|
||||||
// is_trivially_copyable is especially hard to get right.
|
|
||||||
// - Older versions of libstdc++ will fail to have it like they do for other
|
|
||||||
// type traits. This has become a subset of the second point, but used to be
|
|
||||||
// handled independently.
|
|
||||||
// - An experimental release of gcc includes most of type_traits but misses
|
|
||||||
// is_trivially_copyable, so we still have to avoid using libstdc++ in this
|
|
||||||
// case, which is covered by CR_USE_FALLBACKS_FOR_OLD_EXPERIMENTAL_GLIBCXX.
|
|
||||||
// - When compiling libc++ from before r239653, with a gcc compiler, the
|
|
||||||
// std::is_trivially_copyable can fail. So we need to work around that by not
|
|
||||||
// using the one in libc++ in this case. This is covered by the
|
|
||||||
// CR_USE_FALLBACKS_FOR_GCC_WITH_LIBCXX define, and is discussed in
|
|
||||||
// https://llvm.org/bugs/show_bug.cgi?id=27538#c1 where they point out that
|
|
||||||
// in libc++'s commit r239653 this is fixed by libc++ checking for gcc 5.1.
|
|
||||||
// - In both of the above cases we are using the gcc compiler. When defining
|
|
||||||
// this ourselves on compiler intrinsics, the __is_trivially_copyable()
|
|
||||||
// intrinsic is not available on gcc before version 5.1 (see the discussion in
|
|
||||||
// https://llvm.org/bugs/show_bug.cgi?id=27538#c1 again), so we must check for
|
|
||||||
// that version.
|
|
||||||
// - When __is_trivially_copyable() is not available because we are on gcc older
|
|
||||||
// than 5.1, we need to fall back to something, so we use __has_trivial_copy()
|
|
||||||
// instead based on what was done one-off in bit_cast() previously.
|
|
||||||
|
|
||||||
// TODO(crbug.com/554293): Remove this when all platforms have this in the std
|
|
||||||
// namespace and it works with gcc as needed.
|
|
||||||
#if defined(CR_USE_FALLBACKS_FOR_OLD_EXPERIMENTAL_GLIBCXX) || \
|
|
||||||
defined(CR_USE_FALLBACKS_FOR_GCC_WITH_LIBCXX)
|
|
||||||
template <typename T>
|
|
||||||
struct is_trivially_copyable {
|
|
||||||
// TODO(danakj): Remove this when android builders are all using a newer version
|
|
||||||
// of gcc, or the android ndk is updated to a newer libc++ that does this for
|
|
||||||
// us.
|
|
||||||
#if _GNUC_VER >= 501
|
|
||||||
static constexpr bool value = __is_trivially_copyable(T);
|
|
||||||
#else
|
|
||||||
static constexpr bool value =
|
|
||||||
__has_trivial_copy(T) && __has_trivial_destructor(T);
|
|
||||||
#endif
|
|
||||||
};
|
|
||||||
#else
|
|
||||||
template <class T>
|
|
||||||
using is_trivially_copyable = std::is_trivially_copyable<T>;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#if defined(__GNUC__) && !defined(__clang__) && __GNUC__ <= 7
|
|
||||||
// Workaround for g++7 and earlier family.
|
|
||||||
// Due to https://gcc.gnu.org/bugzilla/show_bug.cgi?id=80654, without this
|
|
||||||
// Optional<std::vector<T>> where T is non-copyable causes a compile error.
|
|
||||||
// As we know it is not trivially copy constructible, explicitly declare so.
|
|
||||||
template <typename T>
|
|
||||||
struct is_trivially_copy_constructible
|
|
||||||
: std::is_trivially_copy_constructible<T> {};
|
|
||||||
|
|
||||||
template <typename... T>
|
|
||||||
struct is_trivially_copy_constructible<std::vector<T...>> : std::false_type {};
|
|
||||||
#else
|
|
||||||
// Otherwise use std::is_trivially_copy_constructible as is.
|
|
||||||
template <typename T>
|
|
||||||
using is_trivially_copy_constructible = std::is_trivially_copy_constructible<T>;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// base::in_place_t is an implementation of std::in_place_t from
|
|
||||||
// C++17. A tag type used to request in-place construction in template vararg
|
|
||||||
// constructors.
|
|
||||||
|
|
||||||
// Specification:
|
|
||||||
// https://en.cppreference.com/w/cpp/utility/in_place
|
|
||||||
struct in_place_t {};
|
|
||||||
constexpr in_place_t in_place = {};
|
|
||||||
|
|
||||||
// base::in_place_type_t is an implementation of std::in_place_type_t from
|
|
||||||
// C++17. A tag type used for in-place construction when the type to construct
|
|
||||||
// needs to be specified, such as with base::unique_any, designed to be a
|
|
||||||
// drop-in replacement.
|
|
||||||
|
|
||||||
// Specification:
|
|
||||||
// http://en.cppreference.com/w/cpp/utility/in_place
|
|
||||||
template <typename T>
|
|
||||||
struct in_place_type_t {};
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
struct is_in_place_type_t {
|
|
||||||
static constexpr bool value = false;
|
|
||||||
};
|
|
||||||
|
|
||||||
template <typename... Ts>
|
|
||||||
struct is_in_place_type_t<in_place_type_t<Ts...>> {
|
|
||||||
static constexpr bool value = true;
|
|
||||||
};
|
|
||||||
|
|
||||||
// C++14 implementation of C++17's std::bool_constant.
|
|
||||||
//
|
|
||||||
// Reference: https://en.cppreference.com/w/cpp/types/integral_constant
|
|
||||||
// Specification: https://wg21.link/meta.type.synop
|
|
||||||
template <bool B>
|
|
||||||
using bool_constant = std::integral_constant<bool, B>;
|
|
||||||
|
|
||||||
// C++14 implementation of C++17's std::conjunction.
|
|
||||||
//
|
|
||||||
// Reference: https://en.cppreference.com/w/cpp/types/conjunction
|
|
||||||
// Specification: https://wg21.link/meta.logical#1.itemdecl:1
|
|
||||||
template <typename...>
|
|
||||||
struct conjunction : std::true_type {};
|
|
||||||
|
|
||||||
template <typename B1>
|
|
||||||
struct conjunction<B1> : B1 {};
|
|
||||||
|
|
||||||
template <typename B1, typename... Bn>
|
|
||||||
struct conjunction<B1, Bn...>
|
|
||||||
: std::conditional_t<static_cast<bool>(B1::value), conjunction<Bn...>, B1> {
|
|
||||||
};
|
|
||||||
|
|
||||||
// C++14 implementation of C++17's std::disjunction.
|
|
||||||
//
|
|
||||||
// Reference: https://en.cppreference.com/w/cpp/types/disjunction
|
|
||||||
// Specification: https://wg21.link/meta.logical#itemdecl:2
|
|
||||||
template <typename...>
|
|
||||||
struct disjunction : std::false_type {};
|
|
||||||
|
|
||||||
template <typename B1>
|
|
||||||
struct disjunction<B1> : B1 {};
|
|
||||||
|
|
||||||
template <typename B1, typename... Bn>
|
|
||||||
struct disjunction<B1, Bn...>
|
|
||||||
: std::conditional_t<static_cast<bool>(B1::value), B1, disjunction<Bn...>> {
|
|
||||||
};
|
|
||||||
|
|
||||||
// C++14 implementation of C++17's std::negation.
|
|
||||||
//
|
|
||||||
// Reference: https://en.cppreference.com/w/cpp/types/negation
|
|
||||||
// Specification: https://wg21.link/meta.logical#itemdecl:3
|
|
||||||
template <typename B>
|
|
||||||
struct negation : bool_constant<!static_cast<bool>(B::value)> {};
|
|
||||||
|
|
||||||
// Implementation of C++17's invoke_result.
|
|
||||||
//
|
|
||||||
// This implementation adds references to `Functor` and `Args` to work around
|
|
||||||
// some quirks of std::result_of. See the #Notes section of [1] for details.
|
|
||||||
//
|
|
||||||
// References:
|
|
||||||
// [1] https://en.cppreference.com/w/cpp/types/result_of
|
|
||||||
// [2] https://wg21.link/meta.trans.other#lib:invoke_result
|
|
||||||
#if ((defined(_MSVC_LANG) && _MSVC_LANG >= 201703L) || __cplusplus >= 201703L)
|
|
||||||
template <typename Functor, typename... Args>
|
|
||||||
using invoke_result = std::invoke_result<Functor, Args...>;
|
|
||||||
#else
|
|
||||||
template <typename Functor, typename... Args>
|
|
||||||
using invoke_result = std::result_of<Functor && (Args && ...)>;
|
|
||||||
#endif
|
|
||||||
|
|
||||||
// Implementation of C++17's std::invoke_result_t.
|
|
||||||
//
|
|
||||||
// Reference: https://wg21.link/meta.type.synop#lib:invoke_result_t
|
|
||||||
template <typename Functor, typename... Args>
|
|
||||||
using invoke_result_t = typename invoke_result<Functor, Args...>::type;
|
|
||||||
|
|
||||||
namespace internal {
|
|
||||||
|
|
||||||
// Base case, `InvokeResult` does not have a nested type member. This means `F`
|
|
||||||
// could not be invoked with `Args...` and thus is not invocable.
|
|
||||||
template <typename InvokeResult, typename R, typename = void>
|
|
||||||
struct IsInvocableImpl : std::false_type {};
|
|
||||||
|
|
||||||
// Happy case, `InvokeResult` does have a nested type member. Now check whether
|
|
||||||
// `InvokeResult::type` is convertible to `R`. Short circuit in case
|
|
||||||
// `std::is_void<R>`.
|
|
||||||
template <typename InvokeResult, typename R>
|
|
||||||
struct IsInvocableImpl<InvokeResult, R, void_t<typename InvokeResult::type>>
|
|
||||||
: disjunction<std::is_void<R>,
|
|
||||||
std::is_convertible<typename InvokeResult::type, R>> {};
|
|
||||||
|
|
||||||
} // namespace internal
|
|
||||||
|
|
||||||
// Implementation of C++17's std::is_invocable_r.
|
|
||||||
//
|
|
||||||
// Returns whether `F` can be invoked with `Args...` and the result is
|
|
||||||
// convertible to `R`.
|
|
||||||
//
|
|
||||||
// Reference: https://wg21.link/meta.rel#lib:is_invocable_r
|
|
||||||
template <typename R, typename F, typename... Args>
|
|
||||||
struct is_invocable_r
|
|
||||||
: internal::IsInvocableImpl<invoke_result<F, Args...>, R> {};
|
|
||||||
|
|
||||||
// Implementation of C++17's std::is_invocable.
|
|
||||||
//
|
|
||||||
// Returns whether `F` can be invoked with `Args...`.
|
|
||||||
//
|
|
||||||
// Reference: https://wg21.link/meta.rel#lib:is_invocable
|
|
||||||
template <typename F, typename... Args>
|
|
||||||
struct is_invocable : is_invocable_r<void, F, Args...> {};
|
|
||||||
|
|
||||||
namespace internal {
|
|
||||||
|
|
||||||
// The indirection with std::is_enum<T> is required, because instantiating
|
|
||||||
// std::underlying_type_t<T> when T is not an enum is UB prior to C++20.
|
|
||||||
template <typename T, bool = std::is_enum<T>::value>
|
|
||||||
struct IsScopedEnumImpl : std::false_type {};
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
struct IsScopedEnumImpl<T, /*std::is_enum<T>::value=*/true>
|
|
||||||
: negation<std::is_convertible<T, std::underlying_type_t<T>>> {};
|
|
||||||
|
|
||||||
} // namespace internal
|
|
||||||
|
|
||||||
// Implementation of C++23's std::is_scoped_enum
|
|
||||||
//
|
|
||||||
// Reference: https://en.cppreference.com/w/cpp/types/is_scoped_enum
|
|
||||||
template <typename T>
|
|
||||||
struct is_scoped_enum : internal::IsScopedEnumImpl<T> {};
|
|
||||||
|
|
||||||
// Implementation of C++20's std::remove_cvref.
|
|
||||||
//
|
|
||||||
// References:
|
|
||||||
// - https://en.cppreference.com/w/cpp/types/remove_cvref
|
|
||||||
// - https://wg21.link/meta.trans.other#lib:remove_cvref
|
|
||||||
template <typename T>
|
|
||||||
struct remove_cvref {
|
|
||||||
using type = std::remove_cv_t<std::remove_reference_t<T>>;
|
|
||||||
};
|
|
||||||
|
|
||||||
// Implementation of C++20's std::remove_cvref_t.
|
|
||||||
//
|
|
||||||
// References:
|
|
||||||
// - https://en.cppreference.com/w/cpp/types/remove_cvref
|
|
||||||
// - https://wg21.link/meta.type.synop#lib:remove_cvref_t
|
|
||||||
template <typename T>
|
|
||||||
using remove_cvref_t = typename remove_cvref<T>::type;
|
|
||||||
|
|
||||||
// Simplified implementation of C++20's std::iter_value_t.
|
|
||||||
// As opposed to std::iter_value_t, this implementation does not restrict
|
|
||||||
// the type of `Iter` and does not consider specializations of
|
|
||||||
// `indirectly_readable_traits`.
|
|
||||||
//
|
|
||||||
// Reference: https://wg21.link/readable.traits#2
|
|
||||||
template <typename Iter>
|
|
||||||
using iter_value_t =
|
|
||||||
typename std::iterator_traits<remove_cvref_t<Iter>>::value_type;
|
|
||||||
|
|
||||||
// Simplified implementation of C++20's std::iter_reference_t.
|
|
||||||
// As opposed to std::iter_reference_t, this implementation does not restrict
|
|
||||||
// the type of `Iter`.
|
|
||||||
//
|
|
||||||
// Reference: https://wg21.link/iterator.synopsis#:~:text=iter_reference_t
|
|
||||||
template <typename Iter>
|
|
||||||
using iter_reference_t = decltype(*std::declval<Iter&>());
|
|
||||||
|
|
||||||
// Simplified implementation of C++20's std::indirect_result_t. As opposed to
|
|
||||||
// std::indirect_result_t, this implementation does not restrict the type of
|
|
||||||
// `Func` and `Iters`.
|
|
||||||
//
|
|
||||||
// Reference: https://wg21.link/iterator.synopsis#:~:text=indirect_result_t
|
|
||||||
template <typename Func, typename... Iters>
|
|
||||||
using indirect_result_t = invoke_result_t<Func, iter_reference_t<Iters>...>;
|
|
||||||
|
|
||||||
// Simplified implementation of C++20's std::projected. As opposed to
|
|
||||||
// std::projected, this implementation does not explicitly restrict the type of
|
|
||||||
// `Iter` and `Proj`, but rather does so implicitly by requiring
|
|
||||||
// `indirect_result_t<Proj, Iter>` is a valid type. This is required for SFINAE
|
|
||||||
// friendliness.
|
|
||||||
//
|
|
||||||
// Reference: https://wg21.link/projected
|
|
||||||
template <typename Iter,
|
|
||||||
typename Proj,
|
|
||||||
typename IndirectResultT = indirect_result_t<Proj, Iter>>
|
|
||||||
struct projected {
|
|
||||||
using value_type = remove_cvref_t<IndirectResultT>;
|
|
||||||
|
|
||||||
IndirectResultT operator*() const; // not defined
|
|
||||||
};
|
|
||||||
|
|
||||||
} // namespace base
|
|
||||||
|
|
||||||
#undef CR_USE_FALLBACKS_FOR_GCC_WITH_LIBCXX
|
|
||||||
#undef CR_USE_FALLBACKS_FOR_OLD_EXPERIMENTAL_GLIBCXX
|
|
||||||
|
|
||||||
#endif // !USING_CHROMIUM_INCLUDES
|
|
||||||
|
|
||||||
#endif // CEF_INCLUDE_BASE_CEF_TEMPLATE_UTIL_H_
|
|
@@ -145,14 +145,6 @@
|
|||||||
/// free(str); // Trace system now has dangling pointer
|
/// free(str); // Trace system now has dangling pointer
|
||||||
/// </pre>
|
/// </pre>
|
||||||
///
|
///
|
||||||
/// To avoid this issue with the |name| and |arg_name| parameters, use the
|
|
||||||
/// TRACE_EVENT_COPY_XXX overloads of the macros at additional runtime
|
|
||||||
/// overhead.
|
|
||||||
///
|
|
||||||
/// Notes: The category must always be in a long-lived char* (i.e. static
|
|
||||||
/// const). The |arg_values|, when used, are always deep copied with
|
|
||||||
/// the _COPY macros.
|
|
||||||
///
|
|
||||||
///
|
///
|
||||||
/// Thread Safety:
|
/// Thread Safety:
|
||||||
/// All macros are thread safe and can be used from any process.
|
/// All macros are thread safe and can be used from any process.
|
||||||
@@ -179,15 +171,15 @@
|
|||||||
/// - 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_EVENT0(category, name) \
|
#define TRACE_EVENT0(category, name) \
|
||||||
cef_trace_event_begin(category, name, NULL, 0, NULL, 0, false); \
|
cef_trace_event_begin(category, name, NULL, 0, NULL, 0); \
|
||||||
CEF_INTERNAL_TRACE_END_ON_SCOPE_CLOSE(category, name)
|
CEF_INTERNAL_TRACE_END_ON_SCOPE_CLOSE(category, name)
|
||||||
#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); \
|
||||||
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, 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); \
|
||||||
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.
|
||||||
@@ -211,21 +203,13 @@
|
|||||||
/// literals). They may not include " chars.
|
/// literals). They may not include " chars.
|
||||||
///
|
///
|
||||||
#define TRACE_EVENT_INSTANT0(category, name) \
|
#define TRACE_EVENT_INSTANT0(category, name) \
|
||||||
cef_trace_event_instant(category, name, NULL, 0, NULL, 0, false)
|
cef_trace_event_instant(category, name, NULL, 0, NULL, 0)
|
||||||
#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)
|
||||||
#define TRACE_EVENT_INSTANT2(category, name, arg1_name, arg1_val, arg2_name, \
|
#define TRACE_EVENT_INSTANT2(category, name, arg1_name, arg1_val, arg2_name, \
|
||||||
arg2_val) \
|
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)
|
||||||
#define TRACE_EVENT_COPY_INSTANT0(category, name) \
|
|
||||||
cef_trace_event_instant(category, name, NULL, 0, NULL, 0, true)
|
|
||||||
#define TRACE_EVENT_COPY_INSTANT1(category, name, arg1_name, arg1_val) \
|
|
||||||
cef_trace_event_instant(category, name, arg1_name, arg1_val, NULL, 0, true)
|
|
||||||
#define TRACE_EVENT_COPY_INSTANT2(category, name, arg1_name, arg1_val, \
|
|
||||||
arg2_name, arg2_val) \
|
|
||||||
cef_trace_event_instant(category, name, arg1_name, arg1_val, arg2_name, \
|
|
||||||
arg2_val, true)
|
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Records a single BEGIN event called "name" immediately, with 0, 1 or 2
|
/// Records a single BEGIN event called "name" immediately, with 0, 1 or 2
|
||||||
@@ -235,21 +219,13 @@
|
|||||||
/// literals). They may not include " chars.
|
/// literals). They may not include " chars.
|
||||||
///
|
///
|
||||||
#define TRACE_EVENT_BEGIN0(category, name) \
|
#define TRACE_EVENT_BEGIN0(category, name) \
|
||||||
cef_trace_event_begin(category, name, NULL, 0, NULL, 0, false)
|
cef_trace_event_begin(category, name, NULL, 0, NULL, 0)
|
||||||
#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)
|
||||||
#define TRACE_EVENT_BEGIN2(category, name, arg1_name, arg1_val, arg2_name, \
|
#define TRACE_EVENT_BEGIN2(category, name, arg1_name, arg1_val, arg2_name, \
|
||||||
arg2_val) \
|
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)
|
||||||
#define TRACE_EVENT_COPY_BEGIN0(category, name) \
|
|
||||||
cef_trace_event_begin(category, name, NULL, 0, NULL, 0, true)
|
|
||||||
#define TRACE_EVENT_COPY_BEGIN1(category, name, arg1_name, arg1_val) \
|
|
||||||
cef_trace_event_begin(category, name, arg1_name, arg1_val, NULL, 0, true)
|
|
||||||
#define TRACE_EVENT_COPY_BEGIN2(category, name, arg1_name, arg1_val, \
|
|
||||||
arg2_name, arg2_val) \
|
|
||||||
cef_trace_event_begin(category, name, arg1_name, arg1_val, arg2_name, \
|
|
||||||
arg2_val, true)
|
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Records a single END event for "name" immediately. If the category
|
/// Records a single END event for "name" immediately. If the category
|
||||||
@@ -258,21 +234,12 @@
|
|||||||
/// literals). They may not include " chars.
|
/// literals). They may not include " chars.
|
||||||
///
|
///
|
||||||
#define TRACE_EVENT_END0(category, name) \
|
#define TRACE_EVENT_END0(category, name) \
|
||||||
cef_trace_event_end(category, name, NULL, 0, NULL, 0, false)
|
cef_trace_event_end(category, name, NULL, 0, NULL, 0)
|
||||||
#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)
|
||||||
#define TRACE_EVENT_END2(category, name, arg1_name, arg1_val, arg2_name, \
|
#define TRACE_EVENT_END2(category, name, arg1_name, arg1_val, arg2_name, \
|
||||||
arg2_val) \
|
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)
|
||||||
arg2_val, false)
|
|
||||||
#define TRACE_EVENT_COPY_END0(category, name) \
|
|
||||||
cef_trace_event_end(category, name, NULL, 0, NULL, 0, true)
|
|
||||||
#define TRACE_EVENT_COPY_END1(category, name, arg1_name, arg1_val) \
|
|
||||||
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, \
|
|
||||||
arg2_val) \
|
|
||||||
cef_trace_event_end(category, name, arg1_name, arg1_val, arg2_name, \
|
|
||||||
arg2_val, true)
|
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Records the value of a counter called "name" immediately. Value
|
/// Records the value of a counter called "name" immediately. Value
|
||||||
@@ -281,9 +248,7 @@
|
|||||||
/// literals). They may not include " chars.
|
/// literals). They may not include " chars.
|
||||||
///
|
///
|
||||||
#define TRACE_COUNTER1(category, name, value) \
|
#define TRACE_COUNTER1(category, name, value) \
|
||||||
cef_trace_counter(category, name, NULL, value, NULL, 0, false)
|
cef_trace_counter(category, name, NULL, value, NULL, 0)
|
||||||
#define TRACE_COPY_COUNTER1(category, name, value) \
|
|
||||||
cef_trace_counter(category, name, NULL, value, NULL, 0, true)
|
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Records the values of a multi-parted counter called "name" immediately.
|
/// Records the values of a multi-parted counter called "name" immediately.
|
||||||
@@ -295,11 +260,7 @@
|
|||||||
#define TRACE_COUNTER2(category, name, value1_name, value1_val, value2_name, \
|
#define TRACE_COUNTER2(category, name, value1_name, value1_val, value2_name, \
|
||||||
value2_val) \
|
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)
|
||||||
#define TRACE_COPY_COUNTER2(category, name, value1_name, value1_val, \
|
|
||||||
value2_name, value2_val) \
|
|
||||||
cef_trace_counter(category, name, value1_name, value1_val, value2_name, \
|
|
||||||
value2_val, true)
|
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Records the value of a counter called "name" immediately. Value
|
/// Records the value of a counter called "name" immediately. Value
|
||||||
@@ -312,9 +273,7 @@
|
|||||||
/// on two different processes will not collide.
|
/// on two different processes will not collide.
|
||||||
///
|
///
|
||||||
#define TRACE_COUNTER_ID1(category, name, id, value) \
|
#define TRACE_COUNTER_ID1(category, name, id, value) \
|
||||||
cef_trace_counter_id(category, name, id, NULL, value, NULL, 0, false)
|
cef_trace_counter_id(category, name, id, NULL, value, NULL, 0)
|
||||||
#define TRACE_COPY_COUNTER_ID1(category, name, id, value) \
|
|
||||||
cef_trace_counter_id(category, name, id, NULL, value, NULL, 0, true)
|
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Records the values of a multi-parted counter called "name" immediately.
|
/// Records the values of a multi-parted counter called "name" immediately.
|
||||||
@@ -330,11 +289,7 @@
|
|||||||
#define TRACE_COUNTER_ID2(category, name, id, value1_name, value1_val, \
|
#define TRACE_COUNTER_ID2(category, name, id, value1_name, value1_val, \
|
||||||
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)
|
||||||
#define TRACE_COPY_COUNTER_ID2(category, name, id, value1_name, value1_val, \
|
|
||||||
value2_name, value2_val) \
|
|
||||||
cef_trace_counter_id(category, name, id, value1_name, value1_val, \
|
|
||||||
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
|
||||||
@@ -355,23 +310,13 @@
|
|||||||
/// args.
|
/// args.
|
||||||
///
|
///
|
||||||
#define TRACE_EVENT_ASYNC_BEGIN0(category, name, id) \
|
#define TRACE_EVENT_ASYNC_BEGIN0(category, name, id) \
|
||||||
cef_trace_event_async_begin(category, name, id, NULL, 0, NULL, 0, false)
|
cef_trace_event_async_begin(category, name, id, NULL, 0, NULL, 0)
|
||||||
#define TRACE_EVENT_ASYNC_BEGIN1(category, name, id, arg1_name, arg1_val) \
|
#define TRACE_EVENT_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)
|
||||||
0, false)
|
|
||||||
#define TRACE_EVENT_ASYNC_BEGIN2(category, name, id, arg1_name, arg1_val, \
|
#define TRACE_EVENT_ASYNC_BEGIN2(category, name, id, arg1_name, arg1_val, \
|
||||||
arg2_name, arg2_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, false)
|
arg2_name, arg2_val)
|
||||||
#define TRACE_EVENT_COPY_ASYNC_BEGIN0(category, name, id) \
|
|
||||||
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) \
|
|
||||||
cef_trace_event_async_begin(category, name, id, arg1_name, arg1_val, NULL, \
|
|
||||||
0, true)
|
|
||||||
#define TRACE_EVENT_COPY_ASYNC_BEGIN2(category, name, id, arg1_name, arg1_val, \
|
|
||||||
arg2_name, arg2_val) \
|
|
||||||
cef_trace_event_async_begin(category, name, id, arg1_name, arg1_val, \
|
|
||||||
arg2_name, arg2_val, true)
|
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Records a single ASYNC_STEP_INTO event for |step| immediately. If the
|
/// Records a single ASYNC_STEP_INTO event for |step| immediately. If the
|
||||||
@@ -382,17 +327,10 @@
|
|||||||
/// 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)
|
||||||
#define TRACE_EVENT_ASYNC_STEP_INTO1(category, name, id, step, arg1_name, \
|
#define TRACE_EVENT_ASYNC_STEP_INTO1(category, name, id, step, arg1_name, \
|
||||||
arg1_val) \
|
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)
|
||||||
arg1_val, false)
|
|
||||||
#define TRACE_EVENT_COPY_ASYNC_STEP_INTO0(category, name, id, step) \
|
|
||||||
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, \
|
|
||||||
arg1_val) \
|
|
||||||
cef_trace_event_async_step_into(category, name, id, step, arg1_name, \
|
|
||||||
arg1_val, true)
|
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Records a single ASYNC_STEP_PAST event for |step| immediately. If the
|
/// Records a single ASYNC_STEP_PAST event for |step| immediately. If the
|
||||||
@@ -403,40 +341,23 @@
|
|||||||
/// 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)
|
||||||
#define TRACE_EVENT_ASYNC_STEP_PAST1(category, name, id, step, arg1_name, \
|
#define TRACE_EVENT_ASYNC_STEP_PAST1(category, name, id, step, arg1_name, \
|
||||||
arg1_val) \
|
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)
|
||||||
arg1_val, false)
|
|
||||||
#define TRACE_EVENT_COPY_ASYNC_STEP_PAST0(category, name, id, step) \
|
|
||||||
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, \
|
|
||||||
arg1_val) \
|
|
||||||
cef_trace_event_async_step_past(category, name, id, step, arg1_name, \
|
|
||||||
arg1_val, true)
|
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Records a single ASYNC_END event for "name" immediately. If the category
|
/// Records a single ASYNC_END event for "name" immediately. If the category
|
||||||
/// is not enabled, then this does nothing.
|
/// is not enabled, then this does nothing.
|
||||||
///
|
///
|
||||||
#define TRACE_EVENT_ASYNC_END0(category, name, id) \
|
#define TRACE_EVENT_ASYNC_END0(category, name, id) \
|
||||||
cef_trace_event_async_end(category, name, id, NULL, 0, NULL, 0, false)
|
cef_trace_event_async_end(category, name, id, NULL, 0, NULL, 0)
|
||||||
#define TRACE_EVENT_ASYNC_END1(category, name, id, arg1_name, arg1_val) \
|
#define TRACE_EVENT_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)
|
||||||
false)
|
|
||||||
#define TRACE_EVENT_ASYNC_END2(category, name, id, arg1_name, arg1_val, \
|
#define TRACE_EVENT_ASYNC_END2(category, name, id, arg1_name, arg1_val, \
|
||||||
arg2_name, arg2_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, false)
|
arg2_name, arg2_val)
|
||||||
#define TRACE_EVENT_COPY_ASYNC_END0(category, name, id) \
|
|
||||||
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) \
|
|
||||||
cef_trace_event_async_end(category, name, id, arg1_name, arg1_val, NULL, 0, \
|
|
||||||
true)
|
|
||||||
#define TRACE_EVENT_COPY_ASYNC_END2(category, name, id, arg1_name, arg1_val, \
|
|
||||||
arg2_name, arg2_val) \
|
|
||||||
cef_trace_event_async_end(category, name, id, arg1_name, arg1_val, \
|
|
||||||
arg2_name, arg2_val, true)
|
|
||||||
|
|
||||||
namespace cef_trace_event {
|
namespace cef_trace_event {
|
||||||
|
|
||||||
@@ -448,7 +369,7 @@ class CefTraceEndOnScopeClose {
|
|||||||
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);
|
||||||
}
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@@ -66,6 +66,7 @@
|
|||||||
// updated to match.
|
// updated to match.
|
||||||
|
|
||||||
#include <stddef.h>
|
#include <stddef.h>
|
||||||
|
|
||||||
#include <tuple>
|
#include <tuple>
|
||||||
#include <utility>
|
#include <utility>
|
||||||
|
|
||||||
|
@@ -123,7 +123,7 @@ class SupportsWeakPtr;
|
|||||||
template <typename T>
|
template <typename T>
|
||||||
class WeakPtr;
|
class WeakPtr;
|
||||||
|
|
||||||
namespace internal {
|
namespace cef_internal {
|
||||||
// These classes are part of the WeakPtr implementation.
|
// These classes are part of the WeakPtr implementation.
|
||||||
// DO NOT USE THESE CLASSES DIRECTLY YOURSELF.
|
// DO NOT USE THESE CLASSES DIRECTLY YOURSELF.
|
||||||
|
|
||||||
@@ -197,7 +197,7 @@ class WeakPtrBase {
|
|||||||
WeakPtrBase& operator=(WeakPtrBase&& other) noexcept = default;
|
WeakPtrBase& operator=(WeakPtrBase&& other) noexcept = default;
|
||||||
|
|
||||||
void reset() {
|
void reset() {
|
||||||
ref_ = internal::WeakReference();
|
ref_ = cef_internal::WeakReference();
|
||||||
ptr_ = 0;
|
ptr_ = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -225,7 +225,7 @@ class SupportsWeakPtrBase {
|
|||||||
template <typename Derived>
|
template <typename Derived>
|
||||||
static WeakPtr<Derived> StaticAsWeakPtr(Derived* t) {
|
static WeakPtr<Derived> StaticAsWeakPtr(Derived* t) {
|
||||||
static_assert(
|
static_assert(
|
||||||
std::is_base_of<internal::SupportsWeakPtrBase, Derived>::value,
|
std::is_base_of<cef_internal::SupportsWeakPtrBase, Derived>::value,
|
||||||
"AsWeakPtr argument must inherit from SupportsWeakPtr");
|
"AsWeakPtr argument must inherit from SupportsWeakPtr");
|
||||||
return AsWeakPtrImpl<Derived>(t);
|
return AsWeakPtrImpl<Derived>(t);
|
||||||
}
|
}
|
||||||
@@ -242,7 +242,7 @@ class SupportsWeakPtrBase {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace internal
|
} // namespace cef_internal
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
class WeakPtrFactory;
|
class WeakPtrFactory;
|
||||||
@@ -264,7 +264,7 @@ class WeakPtrFactory;
|
|||||||
/// </pre>
|
/// </pre>
|
||||||
///
|
///
|
||||||
template <typename T>
|
template <typename T>
|
||||||
class WeakPtr : public internal::WeakPtrBase {
|
class WeakPtr : public cef_internal::WeakPtrBase {
|
||||||
public:
|
public:
|
||||||
WeakPtr() = default;
|
WeakPtr() = default;
|
||||||
WeakPtr(std::nullptr_t) {}
|
WeakPtr(std::nullptr_t) {}
|
||||||
@@ -325,13 +325,13 @@ class WeakPtr : public internal::WeakPtrBase {
|
|||||||
bool WasInvalidated() const { return ptr_ && !ref_.IsValid(); }
|
bool WasInvalidated() const { return ptr_ && !ref_.IsValid(); }
|
||||||
|
|
||||||
private:
|
private:
|
||||||
friend class 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 internal::WeakReference& ref, T* ptr)
|
WeakPtr(const cef_internal::WeakReference& ref, T* ptr)
|
||||||
: WeakPtrBase(ref, reinterpret_cast<uintptr_t>(ptr)) {}
|
: WeakPtrBase(ref, reinterpret_cast<uintptr_t>(ptr)) {}
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -355,15 +355,15 @@ bool operator==(std::nullptr_t, const WeakPtr<T>& weak_ptr) {
|
|||||||
return weak_ptr == nullptr;
|
return weak_ptr == nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace internal {
|
namespace cef_internal {
|
||||||
class WeakPtrFactoryBase {
|
class WeakPtrFactoryBase {
|
||||||
protected:
|
protected:
|
||||||
WeakPtrFactoryBase(uintptr_t ptr);
|
WeakPtrFactoryBase(uintptr_t ptr);
|
||||||
~WeakPtrFactoryBase();
|
~WeakPtrFactoryBase();
|
||||||
internal::WeakReferenceOwner weak_reference_owner_;
|
cef_internal::WeakReferenceOwner weak_reference_owner_;
|
||||||
uintptr_t ptr_;
|
uintptr_t ptr_;
|
||||||
};
|
};
|
||||||
} // namespace internal
|
} // namespace cef_internal
|
||||||
|
|
||||||
///
|
///
|
||||||
/// A class may be composed of a WeakPtrFactory and thereby control how it
|
/// A class may be composed of a WeakPtrFactory and thereby control how it
|
||||||
@@ -374,7 +374,7 @@ class WeakPtrFactoryBase {
|
|||||||
/// bool.
|
/// bool.
|
||||||
///
|
///
|
||||||
template <class T>
|
template <class T>
|
||||||
class WeakPtrFactory : public internal::WeakPtrFactoryBase {
|
class WeakPtrFactory : public cef_internal::WeakPtrFactoryBase {
|
||||||
public:
|
public:
|
||||||
WeakPtrFactory() = delete;
|
WeakPtrFactory() = delete;
|
||||||
|
|
||||||
@@ -416,7 +416,7 @@ class WeakPtrFactory : public internal::WeakPtrFactoryBase {
|
|||||||
/// destroyed, its use can lead to subtle use-after-destroy issues.
|
/// destroyed, its use can lead to subtle use-after-destroy issues.
|
||||||
///
|
///
|
||||||
template <class T>
|
template <class T>
|
||||||
class SupportsWeakPtr : public internal::SupportsWeakPtrBase {
|
class SupportsWeakPtr : public cef_internal::SupportsWeakPtrBase {
|
||||||
public:
|
public:
|
||||||
SupportsWeakPtr() = default;
|
SupportsWeakPtr() = default;
|
||||||
|
|
||||||
@@ -431,7 +431,7 @@ class SupportsWeakPtr : public internal::SupportsWeakPtrBase {
|
|||||||
~SupportsWeakPtr() = default;
|
~SupportsWeakPtr() = default;
|
||||||
|
|
||||||
private:
|
private:
|
||||||
internal::WeakReferenceOwner weak_reference_owner_;
|
cef_internal::WeakReferenceOwner weak_reference_owner_;
|
||||||
};
|
};
|
||||||
|
|
||||||
///
|
///
|
||||||
@@ -459,7 +459,7 @@ class SupportsWeakPtr : public internal::SupportsWeakPtrBase {
|
|||||||
///
|
///
|
||||||
template <typename Derived>
|
template <typename Derived>
|
||||||
WeakPtr<Derived> AsWeakPtr(Derived* t) {
|
WeakPtr<Derived> AsWeakPtr(Derived* t) {
|
||||||
return internal::SupportsWeakPtrBase::StaticAsWeakPtr<Derived>(t);
|
return cef_internal::SupportsWeakPtrBase::StaticAsWeakPtr<Derived>(t);
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace base
|
} // namespace base
|
||||||
|
@@ -68,7 +68,6 @@
|
|||||||
#include "include/base/cef_build.h"
|
#include "include/base/cef_build.h"
|
||||||
#include "include/base/cef_compiler_specific.h"
|
#include "include/base/cef_compiler_specific.h"
|
||||||
#include "include/base/cef_logging.h"
|
#include "include/base/cef_logging.h"
|
||||||
#include "include/base/cef_template_util.h"
|
|
||||||
#include "include/base/cef_weak_ptr.h"
|
#include "include/base/cef_weak_ptr.h"
|
||||||
#include "include/base/internal/cef_callback_internal.h"
|
#include "include/base/internal/cef_callback_internal.h"
|
||||||
#include "include/base/internal/cef_raw_scoped_refptr_mismatch_checker.h"
|
#include "include/base/internal/cef_raw_scoped_refptr_mismatch_checker.h"
|
||||||
@@ -97,7 +96,7 @@ struct BindUnwrapTraits;
|
|||||||
template <typename Functor, typename BoundArgsTuple, typename SFINAE = void>
|
template <typename Functor, typename BoundArgsTuple, typename SFINAE = void>
|
||||||
struct CallbackCancellationTraits;
|
struct CallbackCancellationTraits;
|
||||||
|
|
||||||
namespace internal {
|
namespace cef_internal {
|
||||||
|
|
||||||
template <typename Functor, typename SFINAE = void>
|
template <typename Functor, typename SFINAE = void>
|
||||||
struct FunctorTraits;
|
struct FunctorTraits;
|
||||||
@@ -356,14 +355,14 @@ template <typename Functor, typename SFINAE = void>
|
|||||||
struct IsCallableObject : std::false_type {};
|
struct IsCallableObject : std::false_type {};
|
||||||
|
|
||||||
template <typename Callable>
|
template <typename Callable>
|
||||||
struct IsCallableObject<Callable, void_t<decltype(&Callable::operator())>>
|
struct IsCallableObject<Callable, std::void_t<decltype(&Callable::operator())>>
|
||||||
: std::true_type {};
|
: std::true_type {};
|
||||||
|
|
||||||
// HasRefCountedTypeAsRawPtr inherits from true_type when any of the |Args| is a
|
// HasRefCountedTypeAsRawPtr inherits from true_type when any of the |Args| is a
|
||||||
// raw pointer to a RefCounted type.
|
// raw pointer to a RefCounted type.
|
||||||
template <typename... Ts>
|
template <typename... Ts>
|
||||||
struct HasRefCountedTypeAsRawPtr
|
struct HasRefCountedTypeAsRawPtr
|
||||||
: disjunction<NeedsScopedRefptrButGetsRawPtr<Ts>...> {};
|
: std::disjunction<NeedsScopedRefptrButGetsRawPtr<Ts>...> {};
|
||||||
|
|
||||||
// ForceVoidReturn<>
|
// ForceVoidReturn<>
|
||||||
//
|
//
|
||||||
@@ -687,8 +686,9 @@ struct InvokeHelper<true, ReturnType> {
|
|||||||
static inline void MakeItSo(Functor&& functor,
|
static inline void MakeItSo(Functor&& functor,
|
||||||
BoundWeakPtr&& weak_ptr,
|
BoundWeakPtr&& weak_ptr,
|
||||||
RunArgs&&... args) {
|
RunArgs&&... args) {
|
||||||
if (!weak_ptr)
|
if (!weak_ptr) {
|
||||||
return;
|
return;
|
||||||
|
}
|
||||||
using Traits = MakeFunctorTraits<Functor>;
|
using Traits = MakeFunctorTraits<Functor>;
|
||||||
Traits::Invoke(std::forward<Functor>(functor),
|
Traits::Invoke(std::forward<Functor>(functor),
|
||||||
std::forward<BoundWeakPtr>(weak_ptr),
|
std::forward<BoundWeakPtr>(weak_ptr),
|
||||||
@@ -877,7 +877,7 @@ BanUnconstructedRefCountedReceiver(const Receiver& receiver, Unused&&...) {
|
|||||||
// This stores all the state passed into Bind().
|
// This stores all the state passed into Bind().
|
||||||
template <typename Functor, typename... BoundArgs>
|
template <typename Functor, typename... BoundArgs>
|
||||||
struct BindState final : BindStateBase {
|
struct BindState final : BindStateBase {
|
||||||
using IsCancellable = bool_constant<
|
using IsCancellable = std::bool_constant<
|
||||||
CallbackCancellationTraits<Functor,
|
CallbackCancellationTraits<Functor,
|
||||||
std::tuple<BoundArgs...>>::is_cancellable>;
|
std::tuple<BoundArgs...>>::is_cancellable>;
|
||||||
template <typename ForwardFunctor, typename... ForwardBoundArgs>
|
template <typename ForwardFunctor, typename... ForwardBoundArgs>
|
||||||
@@ -1251,7 +1251,7 @@ decltype(auto) BindImpl(Functor&& functor, Args&&... args) {
|
|||||||
// PolymorphicInvoke, to which CallbackType will cast back.
|
// PolymorphicInvoke, to which CallbackType will cast back.
|
||||||
using PolymorphicInvoke = typename CallbackType::PolymorphicInvoke;
|
using PolymorphicInvoke = typename CallbackType::PolymorphicInvoke;
|
||||||
PolymorphicInvoke invoke_func =
|
PolymorphicInvoke invoke_func =
|
||||||
GetInvokeFunc<Invoker>(bool_constant<kIsOnce>());
|
GetInvokeFunc<Invoker>(std::bool_constant<kIsOnce>());
|
||||||
|
|
||||||
using InvokeFuncStorage = BindStateBase::InvokeFuncStorage;
|
using InvokeFuncStorage = BindStateBase::InvokeFuncStorage;
|
||||||
return CallbackType(BindState::Create(
|
return CallbackType(BindState::Create(
|
||||||
@@ -1259,7 +1259,7 @@ decltype(auto) BindImpl(Functor&& functor, Args&&... args) {
|
|||||||
std::forward<Functor>(functor), std::forward<Args>(args)...));
|
std::forward<Functor>(functor), std::forward<Args>(args)...));
|
||||||
}
|
}
|
||||||
|
|
||||||
} // namespace internal
|
} // namespace cef_internal
|
||||||
|
|
||||||
// An injection point to control |this| pointer behavior on a method invocation.
|
// An injection point to control |this| pointer behavior on a method invocation.
|
||||||
// If IsWeakReceiver<> is true_type for |T| and |T| is used for a receiver of a
|
// If IsWeakReceiver<> is true_type for |T| and |T| is used for a receiver of a
|
||||||
@@ -1303,30 +1303,36 @@ struct BindUnwrapTraits {
|
|||||||
};
|
};
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct BindUnwrapTraits<internal::UnretainedWrapper<T>> {
|
struct BindUnwrapTraits<cef_internal::UnretainedWrapper<T>> {
|
||||||
static T* Unwrap(const internal::UnretainedWrapper<T>& o) { return o.get(); }
|
static T* Unwrap(const cef_internal::UnretainedWrapper<T>& o) {
|
||||||
};
|
|
||||||
|
|
||||||
template <typename T>
|
|
||||||
struct BindUnwrapTraits<internal::RetainedRefWrapper<T>> {
|
|
||||||
static T* Unwrap(const internal::RetainedRefWrapper<T>& o) { return o.get(); }
|
|
||||||
};
|
|
||||||
|
|
||||||
template <typename T, typename Deleter>
|
|
||||||
struct BindUnwrapTraits<internal::OwnedWrapper<T, Deleter>> {
|
|
||||||
static T* Unwrap(const internal::OwnedWrapper<T, Deleter>& o) {
|
|
||||||
return o.get();
|
return o.get();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct BindUnwrapTraits<internal::OwnedRefWrapper<T>> {
|
struct BindUnwrapTraits<cef_internal::RetainedRefWrapper<T>> {
|
||||||
static T& Unwrap(const internal::OwnedRefWrapper<T>& o) { return o.get(); }
|
static T* Unwrap(const cef_internal::RetainedRefWrapper<T>& o) {
|
||||||
|
return o.get();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template <typename T, typename Deleter>
|
||||||
|
struct BindUnwrapTraits<cef_internal::OwnedWrapper<T, Deleter>> {
|
||||||
|
static T* Unwrap(const cef_internal::OwnedWrapper<T, Deleter>& o) {
|
||||||
|
return o.get();
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct BindUnwrapTraits<internal::PassedWrapper<T>> {
|
struct BindUnwrapTraits<cef_internal::OwnedRefWrapper<T>> {
|
||||||
static T Unwrap(const internal::PassedWrapper<T>& o) { return o.Take(); }
|
static T& Unwrap(const cef_internal::OwnedRefWrapper<T>& o) {
|
||||||
|
return o.get();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
template <typename T>
|
||||||
|
struct BindUnwrapTraits<cef_internal::PassedWrapper<T>> {
|
||||||
|
static T Unwrap(const cef_internal::PassedWrapper<T>& o) { return o.Take(); }
|
||||||
};
|
};
|
||||||
|
|
||||||
#if defined(OS_WIN)
|
#if defined(OS_WIN)
|
||||||
@@ -1350,9 +1356,9 @@ template <typename Functor, typename... BoundArgs>
|
|||||||
struct CallbackCancellationTraits<
|
struct CallbackCancellationTraits<
|
||||||
Functor,
|
Functor,
|
||||||
std::tuple<BoundArgs...>,
|
std::tuple<BoundArgs...>,
|
||||||
std::enable_if_t<
|
std::enable_if_t<cef_internal::IsWeakMethod<
|
||||||
internal::IsWeakMethod<internal::FunctorTraits<Functor>::is_method,
|
cef_internal::FunctorTraits<Functor>::is_method,
|
||||||
BoundArgs...>::value>> {
|
BoundArgs...>::value>> {
|
||||||
static constexpr bool is_cancellable = true;
|
static constexpr bool is_cancellable = true;
|
||||||
|
|
||||||
template <typename Receiver, typename... Args>
|
template <typename Receiver, typename... Args>
|
||||||
|
@@ -43,7 +43,7 @@ namespace base {
|
|||||||
|
|
||||||
struct FakeBindState;
|
struct FakeBindState;
|
||||||
|
|
||||||
namespace internal {
|
namespace cef_internal {
|
||||||
|
|
||||||
class BindStateBase;
|
class BindStateBase;
|
||||||
class FinallyExecutorCommon;
|
class FinallyExecutorCommon;
|
||||||
@@ -269,7 +269,7 @@ struct ThenHelper<OriginalCallback<OriginalR(OriginalArgs...)>,
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace internal
|
} // namespace cef_internal
|
||||||
} // namespace base
|
} // namespace base
|
||||||
|
|
||||||
#endif // CEF_INCLUDE_BASE_INTERNAL_CEF_CALLBACK_INTERNAL_H_
|
#endif // CEF_INCLUDE_BASE_INTERNAL_CEF_CALLBACK_INTERNAL_H_
|
||||||
|
50
include/base/internal/cef_color_id_macros.inc
Normal file
50
include/base/internal/cef_color_id_macros.inc
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
// Copyright 2019 The Chromium Authors
|
||||||
|
// Use of this source code is governed by a BSD-style license that can be
|
||||||
|
// found in the LICENSE file.
|
||||||
|
|
||||||
|
// The following macros are used to declare both the color id enumerations and
|
||||||
|
// the stringized names of the enumeration elements for use in dump_colors. To
|
||||||
|
// stringize the element names, define STRINGIZE_COLOR_IDS prior to including
|
||||||
|
// this file. This file is intended to be included just before and just after
|
||||||
|
// the enumeration or string array declarations.
|
||||||
|
|
||||||
|
#if !defined(COLOR_ID_MACROS_DEFINED)
|
||||||
|
#define COLOR_ID_MACROS_DEFINED
|
||||||
|
#if defined(STRINGIZE_COLOR_IDS)
|
||||||
|
// Convert first token to string, throw away the rest.
|
||||||
|
#define D1(enum_name) #enum_name
|
||||||
|
#define D2(enum_name, enum_value) #enum_name
|
||||||
|
#else // defined(STRINGIZE_COLOR_IDS)
|
||||||
|
// Declare enum with optional assigned value.
|
||||||
|
#define D1(enum_name) enum_name
|
||||||
|
#define D2(enum_name, enum_value) enum_name = enum_value
|
||||||
|
#endif // defined(STRINGIZE_COLOR_IDS)
|
||||||
|
// Select which token in the declaration is the assigned value.
|
||||||
|
// Use first and optional third token, ignore optional second.
|
||||||
|
#define E1(enum_name) D1(enum_name)
|
||||||
|
#define E2(enum_name, old_enum_name) D1(enum_name)
|
||||||
|
#define E3(enum_name, old_enum_name, enum_value) D2(enum_name, enum_value)
|
||||||
|
#define GET_E(_1, _2, _3, macro_name, ...) macro_name
|
||||||
|
#if defined(COMPILER_MSVC)
|
||||||
|
// Workaround for MSVC not properly expanding __VA_ARGS__.
|
||||||
|
#define EXPAND(x) x
|
||||||
|
#define E_CPONLY(...) EXPAND(E(__VA_ARGS__))
|
||||||
|
#define E(...) EXPAND(GET_E(__VA_ARGS__, E3, E2, E1)(__VA_ARGS__)),
|
||||||
|
#else // !defined(COMPILER_MSVC)
|
||||||
|
#define E_CPONLY(...) E(__VA_ARGS__)
|
||||||
|
#define E(...) GET_E(__VA_ARGS__, E3, E2, E1)(__VA_ARGS__),
|
||||||
|
#endif // !defined(COMPILER_MSVC)
|
||||||
|
#else // !defined(COLOR_ID_MACROS_DEFINED)
|
||||||
|
#undef D1
|
||||||
|
#undef D2
|
||||||
|
#undef E1
|
||||||
|
#undef E2
|
||||||
|
#undef E3
|
||||||
|
#if defined(COMPILER_MSVC)
|
||||||
|
#undef EXPAND
|
||||||
|
#endif
|
||||||
|
#undef E_CPONLY
|
||||||
|
#undef GET_E
|
||||||
|
#undef E
|
||||||
|
#undef COLOR_ID_MACROS_DEFINED
|
||||||
|
#endif // !defined(COLOR_ID_MACROS_DEFINED)
|
@@ -34,8 +34,6 @@
|
|||||||
|
|
||||||
#include <type_traits>
|
#include <type_traits>
|
||||||
|
|
||||||
#include "include/base/cef_template_util.h"
|
|
||||||
|
|
||||||
// It is dangerous to post a task with a T* argument where T is a subtype of
|
// It is dangerous to post a task with a T* argument where T is a subtype of
|
||||||
// RefCounted(Base|ThreadSafeBase), since by the time the parameter is used, the
|
// RefCounted(Base|ThreadSafeBase), since by the time the parameter is used, the
|
||||||
// object may already have been deleted since it was not held with a
|
// object may already have been deleted since it was not held with a
|
||||||
@@ -47,28 +45,28 @@ namespace base {
|
|||||||
|
|
||||||
// This is a base internal implementation file used by task.h and callback.h.
|
// This is a base internal implementation file used by task.h and callback.h.
|
||||||
// Not for public consumption, so we wrap it in namespace internal.
|
// Not for public consumption, so we wrap it in namespace internal.
|
||||||
namespace internal {
|
namespace cef_internal {
|
||||||
|
|
||||||
template <typename T, typename = void>
|
template <typename T, typename = void>
|
||||||
struct IsRefCountedType : std::false_type {};
|
struct IsRefCountedType : std::false_type {};
|
||||||
|
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct IsRefCountedType<T,
|
struct IsRefCountedType<T,
|
||||||
void_t<decltype(std::declval<T*>()->AddRef()),
|
std::void_t<decltype(std::declval<T*>()->AddRef()),
|
||||||
decltype(std::declval<T*>()->Release())>>
|
decltype(std::declval<T*>()->Release())>>
|
||||||
: std::true_type {};
|
: std::true_type {};
|
||||||
|
|
||||||
// Human readable translation: you needed to be a scoped_refptr if you are a raw
|
// Human readable translation: you needed to be a scoped_refptr if you are a raw
|
||||||
// pointer type and are convertible to a RefCounted(Base|ThreadSafeBase) type.
|
// pointer type and are convertible to a RefCounted(Base|ThreadSafeBase) type.
|
||||||
template <typename T>
|
template <typename T>
|
||||||
struct NeedsScopedRefptrButGetsRawPtr
|
struct NeedsScopedRefptrButGetsRawPtr
|
||||||
: conjunction<std::is_pointer<T>,
|
: std::conjunction<std::is_pointer<T>,
|
||||||
IsRefCountedType<std::remove_pointer_t<T>>> {
|
IsRefCountedType<std::remove_pointer_t<T>>> {
|
||||||
static_assert(!std::is_reference<T>::value,
|
static_assert(!std::is_reference<T>::value,
|
||||||
"NeedsScopedRefptrButGetsRawPtr requires non-reference type.");
|
"NeedsScopedRefptrButGetsRawPtr requires non-reference type.");
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace internal
|
} // namespace cef_internal
|
||||||
|
|
||||||
} // namespace base
|
} // namespace base
|
||||||
|
|
||||||
|
@@ -38,13 +38,14 @@
|
|||||||
#include "include/base/cef_scoped_typeref_mac.h"
|
#include "include/base/cef_scoped_typeref_mac.h"
|
||||||
|
|
||||||
#if defined(__has_feature) && __has_feature(objc_arc)
|
#if defined(__has_feature) && __has_feature(objc_arc)
|
||||||
#error "Cannot include include/base/internal/cef_scoped_block_mac.h in file built with ARC."
|
#error \
|
||||||
|
"Cannot include include/base/internal/cef_scoped_block_mac.h in file built with ARC."
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
namespace base {
|
namespace base {
|
||||||
namespace mac {
|
namespace mac {
|
||||||
|
|
||||||
namespace internal {
|
namespace cef_internal {
|
||||||
|
|
||||||
template <typename B>
|
template <typename B>
|
||||||
struct ScopedBlockTraits {
|
struct ScopedBlockTraits {
|
||||||
@@ -53,12 +54,12 @@ struct ScopedBlockTraits {
|
|||||||
static void Release(B block) { Block_release(block); }
|
static void Release(B block) { Block_release(block); }
|
||||||
};
|
};
|
||||||
|
|
||||||
} // namespace internal
|
} // namespace cef_internal
|
||||||
|
|
||||||
// ScopedBlock<> is patterned after ScopedCFTypeRef<>, but uses Block_copy() and
|
// ScopedBlock<> is patterned after ScopedCFTypeRef<>, but uses Block_copy() and
|
||||||
// Block_release() instead of CFRetain() and CFRelease().
|
// Block_release() instead of CFRetain() and CFRelease().
|
||||||
template <typename B>
|
template <typename B>
|
||||||
using ScopedBlock = ScopedTypeRef<B, internal::ScopedBlockTraits<B>>;
|
using ScopedBlock = ScopedTypeRef<B, cef_internal::ScopedBlockTraits<B>>;
|
||||||
|
|
||||||
} // namespace mac
|
} // namespace mac
|
||||||
} // namespace base
|
} // namespace base
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=6bdc0ce413420b45510fcc7f415c6a6fb05f0112$
|
// $hash=6ea5d772fb4961ae4a658b4b730aa608fa93309f$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_ACCESSIBILITY_HANDLER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_ACCESSIBILITY_HANDLER_CAPI_H_
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=7c6894aae3e508aaa42a376532328316d9bd509c$
|
// $hash=608f4520d7901b6e18bf9164c9460f1b75bad8f4$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_APP_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_APP_CAPI_H_
|
||||||
@@ -91,11 +91,9 @@ typedef struct _cef_app_t {
|
|||||||
struct _cef_scheme_registrar_t* registrar);
|
struct _cef_scheme_registrar_t* registrar);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Return the handler for resource bundle events. If
|
/// Return the handler for resource bundle events. If no handler is returned
|
||||||
/// cef_settings_t.pack_loading_disabled is true (1) a handler must be
|
/// resources will be loaded from pack files. This function is called by the
|
||||||
/// returned. If no handler is returned resources will be loaded from pack
|
/// browser and render processes on multiple threads.
|
||||||
/// files. This function is called by the browser and render processes on
|
|
||||||
/// multiple threads.
|
|
||||||
///
|
///
|
||||||
struct _cef_resource_bundle_handler_t*(
|
struct _cef_resource_bundle_handler_t*(
|
||||||
CEF_CALLBACK* get_resource_bundle_handler)(struct _cef_app_t* self);
|
CEF_CALLBACK* get_resource_bundle_handler)(struct _cef_app_t* self);
|
||||||
@@ -133,19 +131,34 @@ CEF_EXPORT int cef_execute_process(const cef_main_args_t* args,
|
|||||||
|
|
||||||
///
|
///
|
||||||
/// This function should be called on the main application thread to initialize
|
/// This function should be called on the main application thread to initialize
|
||||||
/// the CEF browser process. The |application| parameter may be NULL. A return
|
/// the CEF browser process. The |application| parameter may be NULL. Returns
|
||||||
/// value of true (1) indicates that it succeeded and false (0) indicates that
|
/// true (1) if initialization succeeds. Returns false (0) if initialization
|
||||||
/// it failed. The |windows_sandbox_info| parameter is only used on Windows and
|
/// fails or if early exit is desired (for example, due to process singleton
|
||||||
/// may be NULL (see cef_sandbox_win.h for details).
|
/// relaunch behavior). If this function returns false (0) then the application
|
||||||
|
/// should exit immediately without calling any other CEF functions except,
|
||||||
|
/// optionally, CefGetErrorCode. The |windows_sandbox_info| parameter is only
|
||||||
|
/// used on Windows and may be NULL (see cef_sandbox_win.h for details).
|
||||||
///
|
///
|
||||||
CEF_EXPORT int cef_initialize(const cef_main_args_t* args,
|
CEF_EXPORT int cef_initialize(const 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);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// This function can optionally be called on the main application thread after
|
||||||
|
/// CefInitialize to retrieve the initialization exit code. When CefInitialize
|
||||||
|
/// returns true (1) the exit code will be 0 (CEF_RESULT_CODE_NORMAL_EXIT).
|
||||||
|
/// Otherwise, see cef_resultcode_t for possible exit code values including
|
||||||
|
/// browser process initialization errors and normal early exit conditions (such
|
||||||
|
/// as CEF_RESULT_CODE_NORMAL_EXIT_PROCESS_NOTIFIED for process singleton
|
||||||
|
/// relaunch behavior).
|
||||||
|
///
|
||||||
|
CEF_EXPORT int cef_get_exit_code(void);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// This function should be called on the main application thread to shut down
|
/// This function should be called on the main application thread to shut down
|
||||||
/// the CEF browser process before the application exits.
|
/// the CEF browser process before the application exits. Do not call any other
|
||||||
|
/// CEF functions after calling this function.
|
||||||
///
|
///
|
||||||
CEF_EXPORT void cef_shutdown(void);
|
CEF_EXPORT void cef_shutdown(void);
|
||||||
|
|
||||||
@@ -183,19 +196,6 @@ CEF_EXPORT void cef_run_message_loop(void);
|
|||||||
///
|
///
|
||||||
CEF_EXPORT void cef_quit_message_loop(void);
|
CEF_EXPORT void cef_quit_message_loop(void);
|
||||||
|
|
||||||
///
|
|
||||||
/// Set to true (1) before calling Windows APIs like TrackPopupMenu that enter a
|
|
||||||
/// modal message loop. Set to false (0) after exiting the modal message loop.
|
|
||||||
///
|
|
||||||
CEF_EXPORT void cef_set_osmodal_loop(int osModalLoop);
|
|
||||||
|
|
||||||
///
|
|
||||||
/// Call during process startup to enable High-DPI support on Windows 7 or
|
|
||||||
/// newer. Older versions of Windows should be left DPI-unaware because they do
|
|
||||||
/// not support DirectWrite and GDI fonts are kerned very badly.
|
|
||||||
///
|
|
||||||
CEF_EXPORT void cef_enable_highdpi_support(void);
|
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=4e243df31e29bc6e473d56e371ed6328d948959c$
|
// $hash=d98482eba93dcd8b6a6f69b2732162733c73203d$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_AUDIO_HANDLER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_AUDIO_HANDLER_CAPI_H_
|
||||||
@@ -93,7 +93,7 @@ typedef struct _cef_audio_handler_t {
|
|||||||
struct _cef_browser_t* browser,
|
struct _cef_browser_t* browser,
|
||||||
const float** data,
|
const float** data,
|
||||||
int frames,
|
int frames,
|
||||||
int64 pts);
|
int64_t pts);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Called on the UI thread when the stream has stopped. OnAudioSteamStopped
|
/// Called on the UI thread when the stream has stopped. OnAudioSteamStopped
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=c0704c0a87e8b57b20887be75700a30e887fee4f$
|
// $hash=b63947918eca8c31790cae16b2e8a0be7e9464dd$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_AUTH_CALLBACK_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_AUTH_CALLBACK_CAPI_H_
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=f8a604f73a04bec535d72ec7d05906da8c953b6b$
|
// $hash=7c786570b1c7af912a31c6f0c3d742e8aeb38fd8$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_BROWSER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_BROWSER_CAPI_H_
|
||||||
@@ -165,15 +165,16 @@ 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_by_identifier)(
|
||||||
struct _cef_browser_t* self,
|
struct _cef_browser_t* self,
|
||||||
int64 identifier);
|
const cef_string_t* 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.
|
||||||
///
|
///
|
||||||
struct _cef_frame_t*(CEF_CALLBACK* get_frame)(struct _cef_browser_t* self,
|
struct _cef_frame_t*(CEF_CALLBACK* get_frame_by_name)(
|
||||||
const cef_string_t* name);
|
struct _cef_browser_t* self,
|
||||||
|
const cef_string_t* name);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Returns the number of frames that currently exist.
|
/// Returns the number of frames that currently exist.
|
||||||
@@ -184,8 +185,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,
|
cef_string_list_t identifiers);
|
||||||
int64* identifiers);
|
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Returns the names of all existing frames.
|
/// Returns the names of all existing frames.
|
||||||
@@ -365,16 +365,38 @@ typedef struct _cef_browser_host_t {
|
|||||||
struct _cef_browser_host_t* self);
|
struct _cef_browser_host_t* self);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Get the current zoom level. The default zoom level is 0.0. This function
|
/// Returns true (1) if this browser can execute the specified zoom command.
|
||||||
/// can only be called on the UI thread.
|
/// This function can only be called on the UI thread.
|
||||||
|
///
|
||||||
|
int(CEF_CALLBACK* can_zoom)(struct _cef_browser_host_t* self,
|
||||||
|
cef_zoom_command_t command);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Execute a zoom command in this browser. If called on the UI thread the
|
||||||
|
/// change will be applied immediately. Otherwise, the change will be applied
|
||||||
|
/// asynchronously on the UI thread.
|
||||||
|
///
|
||||||
|
void(CEF_CALLBACK* zoom)(struct _cef_browser_host_t* self,
|
||||||
|
cef_zoom_command_t command);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Get the default zoom level. This value will be 0.0 by default but can be
|
||||||
|
/// configured. This function can only be called on the UI thread.
|
||||||
|
///
|
||||||
|
double(CEF_CALLBACK* get_default_zoom_level)(
|
||||||
|
struct _cef_browser_host_t* self);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Get the current zoom level. This function can only be called on the UI
|
||||||
|
/// thread.
|
||||||
///
|
///
|
||||||
double(CEF_CALLBACK* get_zoom_level)(struct _cef_browser_host_t* self);
|
double(CEF_CALLBACK* get_zoom_level)(struct _cef_browser_host_t* self);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Change the zoom level to the specified value. Specify 0.0 to reset the
|
/// Change the zoom level to the specified value. Specify 0.0 to reset the
|
||||||
/// zoom level. If called on the UI thread the change will be applied
|
/// zoom level to the default. If called on the UI thread the change will be
|
||||||
/// immediately. Otherwise, the change will be applied asynchronously on the
|
/// applied immediately. Otherwise, the change will be applied asynchronously
|
||||||
/// UI thread.
|
/// on the UI thread.
|
||||||
///
|
///
|
||||||
void(CEF_CALLBACK* set_zoom_level)(struct _cef_browser_host_t* self,
|
void(CEF_CALLBACK* set_zoom_level)(struct _cef_browser_host_t* self,
|
||||||
double zoomLevel);
|
double zoomLevel);
|
||||||
@@ -424,7 +446,7 @@ typedef struct _cef_browser_host_t {
|
|||||||
struct _cef_browser_host_t* self,
|
struct _cef_browser_host_t* self,
|
||||||
const cef_string_t* image_url,
|
const cef_string_t* image_url,
|
||||||
int is_favicon,
|
int is_favicon,
|
||||||
uint32 max_image_size,
|
uint32_t max_image_size,
|
||||||
int bypass_cache,
|
int bypass_cache,
|
||||||
struct _cef_download_image_callback_t* callback);
|
struct _cef_download_image_callback_t* callback);
|
||||||
|
|
||||||
@@ -884,20 +906,6 @@ typedef struct _cef_browser_host_t {
|
|||||||
const cef_size_t* min_size,
|
const cef_size_t* min_size,
|
||||||
const cef_size_t* max_size);
|
const cef_size_t* max_size);
|
||||||
|
|
||||||
///
|
|
||||||
/// Returns the extension hosted in this browser or NULL if no extension is
|
|
||||||
/// hosted. See cef_request_context_t::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_context_t::LoadExtension for details.
|
|
||||||
///
|
|
||||||
int(CEF_CALLBACK* is_background_host)(struct _cef_browser_host_t* self);
|
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Set whether the browser's audio is muted.
|
/// Set whether the browser's audio is muted.
|
||||||
///
|
///
|
||||||
@@ -909,6 +917,66 @@ typedef struct _cef_browser_host_t {
|
|||||||
/// be called on the UI thread.
|
/// be called on the UI thread.
|
||||||
///
|
///
|
||||||
int(CEF_CALLBACK* is_audio_muted)(struct _cef_browser_host_t* self);
|
int(CEF_CALLBACK* is_audio_muted)(struct _cef_browser_host_t* self);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Returns true (1) if the renderer is currently in browser fullscreen. This
|
||||||
|
/// differs from window fullscreen in that browser fullscreen is entered using
|
||||||
|
/// the JavaScript Fullscreen API and modifies CSS attributes such as the
|
||||||
|
/// ::backdrop pseudo-element and :fullscreen pseudo-structure. This function
|
||||||
|
/// can only be called on the UI thread.
|
||||||
|
///
|
||||||
|
int(CEF_CALLBACK* is_fullscreen)(struct _cef_browser_host_t* self);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Requests the renderer to exit browser fullscreen. In most cases exiting
|
||||||
|
/// window fullscreen should also exit browser fullscreen. With Alloy style
|
||||||
|
/// this function should be called in response to a user action such as
|
||||||
|
/// clicking the green traffic light button on MacOS
|
||||||
|
/// (cef_window_delegate_t::OnWindowFullscreenTransition callback) or pressing
|
||||||
|
/// the "ESC" key (cef_keyboard_handler_t::OnPreKeyEvent callback). With
|
||||||
|
/// Chrome style these standard exit actions are handled internally but
|
||||||
|
/// new/additional user actions can use this function. Set |will_cause_resize|
|
||||||
|
/// to true (1) if exiting browser fullscreen will cause a view resize.
|
||||||
|
///
|
||||||
|
void(CEF_CALLBACK* exit_fullscreen)(struct _cef_browser_host_t* self,
|
||||||
|
int will_cause_resize);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Returns true (1) if a Chrome command is supported and enabled. Values for
|
||||||
|
/// |command_id| can be found in the cef_command_ids.h file. This function can
|
||||||
|
/// only be called on the UI thread. Only used with Chrome style.
|
||||||
|
///
|
||||||
|
int(CEF_CALLBACK* can_execute_chrome_command)(
|
||||||
|
struct _cef_browser_host_t* self,
|
||||||
|
int command_id);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Execute a Chrome command. Values for |command_id| can be found in the
|
||||||
|
/// cef_command_ids.h file. |disposition| provides information about the
|
||||||
|
/// intended command target. Only used with Chrome style.
|
||||||
|
///
|
||||||
|
void(CEF_CALLBACK* execute_chrome_command)(
|
||||||
|
struct _cef_browser_host_t* self,
|
||||||
|
int command_id,
|
||||||
|
cef_window_open_disposition_t disposition);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Returns true (1) if the render process associated with this browser is
|
||||||
|
/// currently unresponsive as indicated by a lack of input event processing
|
||||||
|
/// for at least 15 seconds. To receive associated state change notifications
|
||||||
|
/// and optionally handle an unresponsive render process implement
|
||||||
|
/// cef_request_handler_t::OnRenderProcessUnresponsive. This function can only
|
||||||
|
/// be called on the UI thread.
|
||||||
|
///
|
||||||
|
int(CEF_CALLBACK* is_render_process_unresponsive)(
|
||||||
|
struct _cef_browser_host_t* self);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Returns the runtime style for this browser (ALLOY or CHROME). See
|
||||||
|
/// cef_runtime_style_t documentation for details.
|
||||||
|
///
|
||||||
|
cef_runtime_style_t(CEF_CALLBACK* get_runtime_style)(
|
||||||
|
struct _cef_browser_host_t* self);
|
||||||
} cef_browser_host_t;
|
} cef_browser_host_t;
|
||||||
|
|
||||||
///
|
///
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=c4ed4278e513daa2a1ccf42e50e242d61dfbb86f$
|
// $hash=56ad161a75ca5083812e11959053abbcafbb9a5d$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_BROWSER_PROCESS_HANDLER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_BROWSER_PROCESS_HANDLER_CAPI_H_
|
||||||
@@ -43,6 +43,8 @@
|
|||||||
#include "include/capi/cef_base_capi.h"
|
#include "include/capi/cef_base_capi.h"
|
||||||
#include "include/capi/cef_client_capi.h"
|
#include "include/capi/cef_client_capi.h"
|
||||||
#include "include/capi/cef_command_line_capi.h"
|
#include "include/capi/cef_command_line_capi.h"
|
||||||
|
#include "include/capi/cef_preference_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"
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
@@ -60,6 +62,32 @@ typedef struct _cef_browser_process_handler_t {
|
|||||||
///
|
///
|
||||||
cef_base_ref_counted_t base;
|
cef_base_ref_counted_t base;
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Provides an opportunity to register custom preferences prior to global and
|
||||||
|
/// request context initialization.
|
||||||
|
///
|
||||||
|
/// If |type| is CEF_PREFERENCES_TYPE_GLOBAL the registered preferences can be
|
||||||
|
/// accessed via cef_preference_manager_t::GetGlobalPreferences after
|
||||||
|
/// OnContextInitialized is called. Global preferences are registered a single
|
||||||
|
/// time at application startup. See related cef_settings_t.cache_path
|
||||||
|
/// configuration.
|
||||||
|
///
|
||||||
|
/// If |type| is CEF_PREFERENCES_TYPE_REQUEST_CONTEXT the preferences can be
|
||||||
|
/// accessed via the cef_request_context_t after
|
||||||
|
/// cef_request_context_handler_t::OnRequestContextInitialized is called.
|
||||||
|
/// Request context preferences are registered each time a new
|
||||||
|
/// cef_request_context_t is created. It is intended but not required that all
|
||||||
|
/// request contexts have the same registered preferences. See related
|
||||||
|
/// cef_request_context_settings_t.cache_path configuration.
|
||||||
|
///
|
||||||
|
/// Do not keep a reference to the |registrar| object. This function is called
|
||||||
|
/// on the browser process UI thread.
|
||||||
|
///
|
||||||
|
void(CEF_CALLBACK* on_register_custom_preferences)(
|
||||||
|
struct _cef_browser_process_handler_t* self,
|
||||||
|
cef_preferences_type_t type,
|
||||||
|
struct _cef_preference_registrar_t* registrar);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Called on the browser process UI thread immediately after the CEF context
|
/// Called on the browser process UI thread immediately after the CEF context
|
||||||
/// has been initialized.
|
/// has been initialized.
|
||||||
@@ -78,6 +106,29 @@ typedef struct _cef_browser_process_handler_t {
|
|||||||
struct _cef_browser_process_handler_t* self,
|
struct _cef_browser_process_handler_t* self,
|
||||||
struct _cef_command_line_t* command_line);
|
struct _cef_command_line_t* command_line);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Implement this function to provide app-specific behavior when an already
|
||||||
|
/// running app is relaunched with the same CefSettings.root_cache_path value.
|
||||||
|
/// For example, activate an existing app window or create a new app window.
|
||||||
|
/// |command_line| will be read-only. Do not keep a reference to
|
||||||
|
/// |command_line| outside of this function. Return true (1) if the relaunch
|
||||||
|
/// is handled or false (0) for default relaunch behavior. Default behavior
|
||||||
|
/// will create a new default styled Chrome window.
|
||||||
|
///
|
||||||
|
/// To avoid cache corruption only a single app instance is allowed to run for
|
||||||
|
/// a given CefSettings.root_cache_path value. On relaunch the app checks a
|
||||||
|
/// process singleton lock and then forwards the new launch arguments to the
|
||||||
|
/// already running app process before exiting early. Client apps should
|
||||||
|
/// therefore check the cef_initialize() return value for early exit before
|
||||||
|
/// proceeding.
|
||||||
|
///
|
||||||
|
/// This function will be called on the browser process UI thread.
|
||||||
|
///
|
||||||
|
int(CEF_CALLBACK* on_already_running_app_relaunch)(
|
||||||
|
struct _cef_browser_process_handler_t* self,
|
||||||
|
struct _cef_command_line_t* command_line,
|
||||||
|
const cef_string_t* current_directory);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Called from any thread when work has been scheduled for the browser
|
/// Called from any thread when work has been scheduled for the browser
|
||||||
/// process main (UI) thread. This callback is used in combination with
|
/// process main (UI) thread. This callback is used in combination with
|
||||||
@@ -93,17 +144,29 @@ typedef struct _cef_browser_process_handler_t {
|
|||||||
///
|
///
|
||||||
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_t delay_ms);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Return the default client for use with a newly created browser window. If
|
/// Return the default client for use with a newly created browser window
|
||||||
/// null is returned the browser will be unmanaged (no callbacks will be
|
/// (cef_browser_t object). If null is returned the cef_browser_t will be
|
||||||
/// executed for that browser) and application shutdown will be blocked until
|
/// unmanaged (no callbacks will be executed for that cef_browser_t) and
|
||||||
/// the browser window is closed manually. This function is currently only
|
/// application shutdown will be blocked until the browser window is closed
|
||||||
/// used with the chrome runtime.
|
/// manually. This function is currently only used with Chrome style when
|
||||||
|
/// creating new browser windows via Chrome UI.
|
||||||
///
|
///
|
||||||
struct _cef_client_t*(CEF_CALLBACK* get_default_client)(
|
struct _cef_client_t*(CEF_CALLBACK* get_default_client)(
|
||||||
struct _cef_browser_process_handler_t* self);
|
struct _cef_browser_process_handler_t* self);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Return the default handler for use with a new user or incognito profile
|
||||||
|
/// (cef_request_context_t object). If null is returned the
|
||||||
|
/// cef_request_context_t will be unmanaged (no callbacks will be executed for
|
||||||
|
/// that cef_request_context_t). This function is currently only used with
|
||||||
|
/// Chrome style when creating new browser windows via Chrome UI.
|
||||||
|
///
|
||||||
|
struct _cef_request_context_handler_t*(
|
||||||
|
CEF_CALLBACK* get_default_request_context_handler)(
|
||||||
|
struct _cef_browser_process_handler_t* self);
|
||||||
} cef_browser_process_handler_t;
|
} cef_browser_process_handler_t;
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=1bb026d01d1d4bb38ceb4c54f6bcf70300bf5201$
|
// $hash=46bc048bec64590735298a95633167d66e445844$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_CALLBACK_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_CALLBACK_CAPI_H_
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=93f1c39c102dc97d6ad8d236a90a2e0e88f10fb7$
|
// $hash=09bd4140605645c9dfbd81e7e22d029d0bb50129$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_CLIENT_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_CLIENT_CAPI_H_
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=ec05ae57537091e3543c4b31d72d2d84d44df876$
|
// $hash=9c7d613d1256bd6353f5102ece5a04e572f20627$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_COMMAND_HANDLER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_COMMAND_HANDLER_CAPI_H_
|
||||||
@@ -64,13 +64,51 @@ typedef struct _cef_command_handler_t {
|
|||||||
/// intended command target. Return true (1) if the command was handled or
|
/// intended command target. Return true (1) if the command was handled or
|
||||||
/// false (0) for the default implementation. For context menu commands this
|
/// false (0) for the default implementation. For context menu commands this
|
||||||
/// will be called after cef_context_menu_handler_t::OnContextMenuCommand.
|
/// will be called after cef_context_menu_handler_t::OnContextMenuCommand.
|
||||||
/// Only used with the Chrome runtime.
|
/// Only used with Chrome style.
|
||||||
///
|
///
|
||||||
int(CEF_CALLBACK* on_chrome_command)(
|
int(CEF_CALLBACK* on_chrome_command)(
|
||||||
struct _cef_command_handler_t* self,
|
struct _cef_command_handler_t* self,
|
||||||
struct _cef_browser_t* browser,
|
struct _cef_browser_t* browser,
|
||||||
int command_id,
|
int command_id,
|
||||||
cef_window_open_disposition_t disposition);
|
cef_window_open_disposition_t disposition);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Called to check if a Chrome app menu item should be visible. Values for
|
||||||
|
/// |command_id| can be found in the cef_command_ids.h file. Only called for
|
||||||
|
/// menu items that would be visible by default. Only used with Chrome style.
|
||||||
|
///
|
||||||
|
int(CEF_CALLBACK* is_chrome_app_menu_item_visible)(
|
||||||
|
struct _cef_command_handler_t* self,
|
||||||
|
struct _cef_browser_t* browser,
|
||||||
|
int command_id);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Called to check if a Chrome app menu item should be enabled. Values for
|
||||||
|
/// |command_id| can be found in the cef_command_ids.h file. Only called for
|
||||||
|
/// menu items that would be enabled by default. Only used with Chrome style.
|
||||||
|
///
|
||||||
|
int(CEF_CALLBACK* is_chrome_app_menu_item_enabled)(
|
||||||
|
struct _cef_command_handler_t* self,
|
||||||
|
struct _cef_browser_t* browser,
|
||||||
|
int command_id);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Called during browser creation to check if a Chrome page action icon
|
||||||
|
/// should be visible. Only called for icons that would be visible by default.
|
||||||
|
/// Only used with Chrome style.
|
||||||
|
///
|
||||||
|
int(CEF_CALLBACK* is_chrome_page_action_icon_visible)(
|
||||||
|
struct _cef_command_handler_t* self,
|
||||||
|
cef_chrome_page_action_icon_type_t icon_type);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Called during browser creation to check if a Chrome toolbar button should
|
||||||
|
/// be visible. Only called for buttons that would be visible by default. Only
|
||||||
|
/// used with Chrome style.
|
||||||
|
///
|
||||||
|
int(CEF_CALLBACK* is_chrome_toolbar_button_visible)(
|
||||||
|
struct _cef_command_handler_t* self,
|
||||||
|
cef_chrome_toolbar_button_type_t button_type);
|
||||||
} cef_command_handler_t;
|
} cef_command_handler_t;
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=f535e9560b9fde9b53fc4d8383905105ed029ea4$
|
// $hash=fce786b3f054d6581438e2906b77e573c797372a$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_COMMAND_LINE_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_COMMAND_LINE_CAPI_H_
|
||||||
@@ -159,14 +159,14 @@ typedef struct _cef_command_line_t {
|
|||||||
cef_string_map_t switches);
|
cef_string_map_t switches);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Add a switch to the end of the command line. If the switch has no value
|
/// Add a switch to the end of the command line.
|
||||||
/// pass an NULL value string.
|
|
||||||
///
|
///
|
||||||
void(CEF_CALLBACK* append_switch)(struct _cef_command_line_t* self,
|
void(CEF_CALLBACK* append_switch)(struct _cef_command_line_t* self,
|
||||||
const cef_string_t* name);
|
const cef_string_t* name);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// 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. If
|
||||||
|
/// the switch has no value pass an NULL value string.
|
||||||
///
|
///
|
||||||
void(CEF_CALLBACK* append_switch_with_value)(struct _cef_command_line_t* self,
|
void(CEF_CALLBACK* append_switch_with_value)(struct _cef_command_line_t* self,
|
||||||
const cef_string_t* name,
|
const cef_string_t* name,
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=0ae549ed35e30afcbb01961fe55455beaadcd7f9$
|
// $hash=3ae7dbb24ec7a95a2f4d4e390c9b6622221c2f42$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_CONTEXT_MENU_HANDLER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_CONTEXT_MENU_HANDLER_CAPI_H_
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=37b5e115ff7abd1df1b9913404b69505fb9fef29$
|
// $hash=76ba2e59636aa71c8c6286093198a1e64d012c62$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_COOKIE_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_COOKIE_CAPI_H_
|
||||||
@@ -126,8 +126,8 @@ typedef struct _cef_cookie_manager_t {
|
|||||||
/// cef_settings_t.cache_path if specified or in memory otherwise. If |callback|
|
/// cef_settings_t.cache_path if specified or in memory otherwise. If |callback|
|
||||||
/// is non-NULL it will be executed asnychronously on the UI thread after the
|
/// is non-NULL it will be executed asnychronously on the UI thread after the
|
||||||
/// manager's storage has been initialized. Using this function is equivalent to
|
/// manager's storage has been initialized. Using this function is equivalent to
|
||||||
/// calling cef_request_context_t::cef_request_context_get_global_context()->Get
|
/// calling cef_request_context_t::cef_request_context_get_global_context()-
|
||||||
/// DefaultCookieManager().
|
/// >GetDefaultCookieManager().
|
||||||
///
|
///
|
||||||
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);
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=1ce19c3213f033ca9059da738102b9b4292d4a06$
|
// $hash=46a6432f66cce88d8597c3d070681b09a712dc54$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_CRASH_UTIL_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_CRASH_UTIL_CAPI_H_
|
||||||
@@ -90,7 +90,7 @@ extern "C" {
|
|||||||
/// If "AppName" is set on Windows then crash report information (metrics,
|
/// If "AppName" is set on Windows then crash report information (metrics,
|
||||||
/// database and dumps) will be stored locally on disk under the
|
/// database and dumps) will be stored locally on disk under the
|
||||||
/// "C:\Users\[CurrentUser]\AppData\Local\[AppName]\User Data" folder. On other
|
/// "C:\Users\[CurrentUser]\AppData\Local\[AppName]\User Data" folder. On other
|
||||||
/// platforms the cef_settings_t.user_data_path value will be used.
|
/// platforms the cef_settings_t.root_cache_path value will be used.
|
||||||
///
|
///
|
||||||
/// If "ExternalHandler" is set on Windows then the specified exe will be
|
/// If "ExternalHandler" is set on Windows then the specified exe will be
|
||||||
/// launched as the crashpad-handler instead of re-launching the main process
|
/// launched as the crashpad-handler instead of re-launching the main process
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=076a01db2fc4241efeb46c5f247a9737fd828f9b$
|
// $hash=dd94c50619e92bf5bed4fe61479813ee559f779d$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_DEVTOOLS_MESSAGE_OBSERVER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_DEVTOOLS_MESSAGE_OBSERVER_CAPI_H_
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=3a1a3ac84690c6090d356ddec3ddb49b934fe28c$
|
// $hash=bf7208a86ee17f63fd7163cef8c3a13373a1f1c8$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_DIALOG_HANDLER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_DIALOG_HANDLER_CAPI_H_
|
||||||
@@ -86,13 +86,20 @@ typedef struct _cef_dialog_handler_t {
|
|||||||
/// to show the default title ("Open" or "Save" depending on the mode).
|
/// to show the default title ("Open" or "Save" depending on the mode).
|
||||||
/// |default_file_path| is the path with optional directory and/or file name
|
/// |default_file_path| is the path with optional directory and/or file name
|
||||||
/// component that should be initially selected in the dialog.
|
/// component that should be initially selected in the dialog.
|
||||||
/// |accept_filters| are used to restrict the selectable file types and may
|
/// |accept_filters| are used to restrict the selectable file types and may be
|
||||||
/// any combination of (a) valid lower-cased MIME types (e.g. "text/*" or
|
/// any combination of valid lower-cased MIME types (e.g. "text/*" or
|
||||||
/// "image/*"), (b) individual file extensions (e.g. ".txt" or ".png"), or (c)
|
/// "image/*") and individual file extensions (e.g. ".txt" or ".png").
|
||||||
/// combined description and file extension delimited using "|" and ";" (e.g.
|
/// |accept_extensions| provides the semicolon-delimited expansion of MIME
|
||||||
/// "Image Types|.png;.gif;.jpg"). To display a custom dialog return true (1)
|
/// types to file extensions (if known, or NULL string otherwise).
|
||||||
/// and execute |callback| either inline or at a later time. To display the
|
/// |accept_descriptions| provides the descriptions for MIME types (if known,
|
||||||
/// default dialog return false (0).
|
/// or NULL string otherwise). For example, the "image/*" mime type might have
|
||||||
|
/// extensions ".png;.jpg;.bmp;..." and description "Image Files".
|
||||||
|
/// |accept_filters|, |accept_extensions| and |accept_descriptions| will all
|
||||||
|
/// be the same size. To display a custom dialog return true (1) and execute
|
||||||
|
/// |callback| either inline or at a later time. To display the default dialog
|
||||||
|
/// return false (0). If this function returns false (0) it may be called an
|
||||||
|
/// additional time for the same dialog (both before and after MIME type
|
||||||
|
/// expansion).
|
||||||
///
|
///
|
||||||
int(CEF_CALLBACK* on_file_dialog)(
|
int(CEF_CALLBACK* on_file_dialog)(
|
||||||
struct _cef_dialog_handler_t* self,
|
struct _cef_dialog_handler_t* self,
|
||||||
@@ -101,6 +108,8 @@ typedef struct _cef_dialog_handler_t {
|
|||||||
const cef_string_t* title,
|
const cef_string_t* title,
|
||||||
const cef_string_t* default_file_path,
|
const cef_string_t* default_file_path,
|
||||||
cef_string_list_t accept_filters,
|
cef_string_list_t accept_filters,
|
||||||
|
cef_string_list_t accept_extensions,
|
||||||
|
cef_string_list_t accept_descriptions,
|
||||||
struct _cef_file_dialog_callback_t* callback);
|
struct _cef_file_dialog_callback_t* callback);
|
||||||
} cef_dialog_handler_t;
|
} cef_dialog_handler_t;
|
||||||
|
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=976a61df924efbcb0c53afeb75265e5e9e80c2de$
|
// $hash=b42d9e5a03f6ef5444e8037b8dc4de08ee6b0834$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_DISPLAY_HANDLER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_DISPLAY_HANDLER_CAPI_H_
|
||||||
@@ -84,8 +84,12 @@ typedef struct _cef_display_handler_t {
|
|||||||
/// Called when web content in the page has toggled fullscreen mode. If
|
/// Called when web content in the page has toggled fullscreen mode. If
|
||||||
/// |fullscreen| is true (1) the content will automatically be sized to fill
|
/// |fullscreen| is true (1) the content will automatically be sized to fill
|
||||||
/// the browser content area. If |fullscreen| is false (0) the content will
|
/// the browser content area. If |fullscreen| is false (0) the content will
|
||||||
/// automatically return to its original size and position. The client is
|
/// automatically return to its original size and position. With Alloy style
|
||||||
/// responsible for resizing the browser if desired.
|
/// the client is responsible for triggering the fullscreen transition (for
|
||||||
|
/// example, by calling cef_window_t::SetFullscreen when using Views). With
|
||||||
|
/// Chrome style the fullscreen transition will be triggered automatically.
|
||||||
|
/// The cef_window_delegate_t::OnWindowFullscreenTransition function will be
|
||||||
|
/// called during the fullscreen transition for notification purposes.
|
||||||
///
|
///
|
||||||
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,
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=47d8c186f687b65c8e7f394b97d72530e67593cd$
|
// $hash=a4d2f79163205ed4367916546240a6aedc2165f9$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_DOM_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_DOM_CAPI_H_
|
||||||
@@ -209,8 +209,7 @@ typedef struct _cef_domnode_t {
|
|||||||
///
|
///
|
||||||
/// Returns the type of this form control element node.
|
/// Returns the type of this form control element node.
|
||||||
///
|
///
|
||||||
// The resulting string must be freed by calling cef_string_userfree_free().
|
cef_dom_form_control_type_t(CEF_CALLBACK* get_form_control_element_type)(
|
||||||
cef_string_userfree_t(CEF_CALLBACK* get_form_control_element_type)(
|
|
||||||
struct _cef_domnode_t* self);
|
struct _cef_domnode_t* self);
|
||||||
|
|
||||||
///
|
///
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=aff139899b4b8b769fd0e506d8a46e434f924eee$
|
// $hash=7ecfb07a95315ff81937e9f68d419122fc88f1b7$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_DOWNLOAD_HANDLER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_DOWNLOAD_HANDLER_CAPI_H_
|
||||||
@@ -117,12 +117,13 @@ typedef struct _cef_download_handler_t {
|
|||||||
|
|
||||||
///
|
///
|
||||||
/// Called before a download begins. |suggested_name| is the suggested name
|
/// Called before a download begins. |suggested_name| is the suggested name
|
||||||
/// for the download file. By default the download will be canceled. Execute
|
/// for the download file. Return true (1) and execute |callback| either
|
||||||
/// |callback| either asynchronously or in this function to continue the
|
/// asynchronously or in this function to continue or cancel the download.
|
||||||
/// download if desired. Do not keep a reference to |download_item| outside of
|
/// Return false (0) to proceed with default handling (cancel with Alloy
|
||||||
/// this function.
|
/// style, download shelf with Chrome style). Do not keep a reference to
|
||||||
|
/// |download_item| outside of this function.
|
||||||
///
|
///
|
||||||
void(CEF_CALLBACK* on_before_download)(
|
int(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,
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=a218058d7ceb842c9ea0cf0c252f9787de6562e7$
|
// $hash=9af8ade3addfd112db41792c4e80682a8143e8c4$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_DOWNLOAD_ITEM_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_DOWNLOAD_ITEM_CAPI_H_
|
||||||
@@ -72,14 +72,25 @@ typedef struct _cef_download_item_t {
|
|||||||
int(CEF_CALLBACK* is_complete)(struct _cef_download_item_t* self);
|
int(CEF_CALLBACK* is_complete)(struct _cef_download_item_t* self);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Returns true (1) if the download has been canceled or interrupted.
|
/// Returns true (1) if the download has been canceled.
|
||||||
///
|
///
|
||||||
int(CEF_CALLBACK* is_canceled)(struct _cef_download_item_t* self);
|
int(CEF_CALLBACK* is_canceled)(struct _cef_download_item_t* self);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Returns true (1) if the download has been interrupted.
|
||||||
|
///
|
||||||
|
int(CEF_CALLBACK* is_interrupted)(struct _cef_download_item_t* self);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Returns the most recent interrupt reason.
|
||||||
|
///
|
||||||
|
cef_download_interrupt_reason_t(CEF_CALLBACK* get_interrupt_reason)(
|
||||||
|
struct _cef_download_item_t* self);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Returns a simple speed estimate in bytes/s.
|
/// Returns a simple speed estimate in bytes/s.
|
||||||
///
|
///
|
||||||
int64(CEF_CALLBACK* get_current_speed)(struct _cef_download_item_t* self);
|
int64_t(CEF_CALLBACK* get_current_speed)(struct _cef_download_item_t* self);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Returns the rough percent complete or -1 if the receive total size is
|
/// Returns the rough percent complete or -1 if the receive total size is
|
||||||
@@ -90,12 +101,12 @@ typedef struct _cef_download_item_t {
|
|||||||
///
|
///
|
||||||
/// Returns the total number of bytes.
|
/// Returns the total number of bytes.
|
||||||
///
|
///
|
||||||
int64(CEF_CALLBACK* get_total_bytes)(struct _cef_download_item_t* self);
|
int64_t(CEF_CALLBACK* get_total_bytes)(struct _cef_download_item_t* self);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Returns the number of received bytes.
|
/// Returns the number of received bytes.
|
||||||
///
|
///
|
||||||
int64(CEF_CALLBACK* get_received_bytes)(struct _cef_download_item_t* self);
|
int64_t(CEF_CALLBACK* get_received_bytes)(struct _cef_download_item_t* self);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Returns the time that the download started.
|
/// Returns the time that the download started.
|
||||||
@@ -118,7 +129,7 @@ typedef struct _cef_download_item_t {
|
|||||||
///
|
///
|
||||||
/// Returns the unique identifier for this download.
|
/// Returns the unique identifier for this download.
|
||||||
///
|
///
|
||||||
uint32(CEF_CALLBACK* get_id)(struct _cef_download_item_t* self);
|
uint32_t(CEF_CALLBACK* get_id)(struct _cef_download_item_t* self);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Returns the URL.
|
/// Returns the URL.
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=9e8375de3d30eb7e4f67488da3568d19848eb038$
|
// $hash=a096775255ddc4d7616095e48e7370bd87bf4bb5$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_DRAG_DATA_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_DRAG_DATA_CAPI_H_
|
||||||
@@ -149,6 +149,13 @@ typedef struct _cef_drag_data_t {
|
|||||||
int(CEF_CALLBACK* get_file_names)(struct _cef_drag_data_t* self,
|
int(CEF_CALLBACK* get_file_names)(struct _cef_drag_data_t* self,
|
||||||
cef_string_list_t names);
|
cef_string_list_t names);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Retrieve the list of file paths that are being dragged into the browser
|
||||||
|
/// window.
|
||||||
|
///
|
||||||
|
int(CEF_CALLBACK* get_file_paths)(struct _cef_drag_data_t* self,
|
||||||
|
cef_string_list_t paths);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Set the link URL that is being dragged.
|
/// Set the link URL that is being dragged.
|
||||||
///
|
///
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=ec450acb2c3cc4d0e69b7da725387d5c1049773b$
|
// $hash=0723a2a59d46e465ac94f198351dc871f0b35b96$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_DRAG_HANDLER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_DRAG_HANDLER_CAPI_H_
|
||||||
|
@@ -1,130 +0,0 @@
|
|||||||
// Copyright (c) 2022 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=b16b1c47d26e911d360159e5535743622a411c31$
|
|
||||||
//
|
|
||||||
|
|
||||||
#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_context_t::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_context_t::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_context_t::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_handler_t::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,212 +0,0 @@
|
|||||||
// Copyright (c) 2022 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=ba961ade334c82e53213e7e8ac848adc2a7b533a$
|
|
||||||
//
|
|
||||||
|
|
||||||
#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_handler_t::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_context_t::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_context_t::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_context_t::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_context_t 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) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=3e2e068a2be0a3b12653eea65a4bbe1c9cdb8c7f$
|
// $hash=e10581d1f6aeb104646ae106aaa5fb36016643dd$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_FILE_UTIL_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_FILE_UTIL_CAPI_H_
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=30e86c9dd440616305f94747b313eb526c4323c7$
|
// $hash=da0a9242b309fbd70d19949fb1c5b4ec4475ef94$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_FIND_HANDLER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_FIND_HANDLER_CAPI_H_
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=907b9628ac4b7ab4603dc6e20b7e8675a51987ba$
|
// $hash=6eefc2c650908461fb7536dd3314c77a3f89dceb$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_FOCUS_HANDLER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_FOCUS_HANDLER_CAPI_H_
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=48bc345bb0971e3fcaaf839e9e4419b2aec0e33b$
|
// $hash=8f347a95168778ec0e686cdef93be3bc517e2f68$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_FRAME_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_FRAME_CAPI_H_
|
||||||
@@ -178,10 +178,12 @@ typedef struct _cef_frame_t {
|
|||||||
cef_string_userfree_t(CEF_CALLBACK* get_name)(struct _cef_frame_t* self);
|
cef_string_userfree_t(CEF_CALLBACK* get_name)(struct _cef_frame_t* self);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Returns the globally unique identifier for this frame or < 0 if the
|
/// Returns the globally unique identifier for this frame or NULL if the
|
||||||
/// underlying frame does not yet exist.
|
/// underlying frame does not yet exist.
|
||||||
///
|
///
|
||||||
int64(CEF_CALLBACK* get_identifier)(struct _cef_frame_t* self);
|
// The resulting string must be freed by calling cef_string_userfree_free().
|
||||||
|
cef_string_userfree_t(CEF_CALLBACK* get_identifier)(
|
||||||
|
struct _cef_frame_t* self);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Returns the parent of this frame or NULL if this is the main (top-level)
|
/// Returns the parent of this frame or NULL if this is the main (top-level)
|
||||||
@@ -216,24 +218,16 @@ typedef struct _cef_frame_t {
|
|||||||
|
|
||||||
///
|
///
|
||||||
/// Create a new URL request that will be treated as originating from this
|
/// Create a new URL request that will be treated as originating from this
|
||||||
/// frame and the associated browser. This request may be intercepted by the
|
/// frame and the associated browser. Use cef_urlrequest_t::Create instead if
|
||||||
/// client via cef_resource_request_handler_t or cef_scheme_handler_factory_t.
|
/// you do not want the request to have this association, in which case it may
|
||||||
/// Use cef_urlrequest_t::Create instead if you do not want the request to
|
/// be handled differently (see documentation on that function). A request
|
||||||
/// have this association, in which case it may be handled differently (see
|
/// created with this function may only originate from the browser process,
|
||||||
/// documentation on that function). Requests may originate from both the
|
/// and will behave as follows:
|
||||||
/// browser process and the render process.
|
/// - It may be intercepted by the client via CefResourceRequestHandler or
|
||||||
///
|
/// CefSchemeHandlerFactory.
|
||||||
/// For requests originating from the browser process:
|
|
||||||
/// - POST data may only contain a single element of type PDE_TYPE_FILE or
|
/// - POST data may only contain a single element of type PDE_TYPE_FILE or
|
||||||
/// PDE_TYPE_BYTES.
|
/// PDE_TYPE_BYTES.
|
||||||
///
|
///
|
||||||
/// For requests originating from the render process:
|
|
||||||
/// - POST data may only contain a single element of type PDE_TYPE_BYTES.
|
|
||||||
/// - If the response contains Content-Disposition or Mime-Type header
|
|
||||||
/// values that would not normally be rendered then the response may
|
|
||||||
/// receive special handling inside the browser (for example, via the
|
|
||||||
/// file download code path instead of the URL request code path).
|
|
||||||
///
|
|
||||||
/// The |request| object will be marked as read-only after calling this
|
/// The |request| object will be marked as read-only after calling this
|
||||||
/// function.
|
/// function.
|
||||||
///
|
///
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=3d97135fef535cc94aca6cf1afa4a9461c388b4f$
|
// $hash=fc6fbee765ce2b649f5293c8c4b076d36014e4aa$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_FRAME_HANDLER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_FRAME_HANDLER_CAPI_H_
|
||||||
@@ -53,48 +53,41 @@ extern "C" {
|
|||||||
/// The order of callbacks is:
|
/// The order of callbacks is:
|
||||||
///
|
///
|
||||||
/// (1) During initial cef_browser_host_t creation and navigation of the main
|
/// (1) During initial cef_browser_host_t creation and navigation of the main
|
||||||
/// frame: - cef_frame_handler_t::OnFrameCreated => The initial main frame
|
/// frame:
|
||||||
/// object has been
|
/// - cef_frame_handler_t::OnFrameCreated => The initial main frame object has
|
||||||
/// created. Any commands will be queued until the frame is attached.
|
/// been created. Any commands will be queued until the frame is attached.
|
||||||
/// - cef_frame_handler_t::OnMainFrameChanged => The initial main frame object
|
/// - cef_frame_handler_t::OnMainFrameChanged => The initial main frame object
|
||||||
/// has
|
/// has been assigned to the browser.
|
||||||
/// been assigned to the browser.
|
|
||||||
/// - cef_life_span_handler_t::OnAfterCreated => The browser is now valid and
|
/// - cef_life_span_handler_t::OnAfterCreated => The browser is now valid and
|
||||||
/// can be
|
/// can be used.
|
||||||
/// used.
|
|
||||||
/// - cef_frame_handler_t::OnFrameAttached => The initial main frame object is
|
/// - cef_frame_handler_t::OnFrameAttached => The initial main frame object is
|
||||||
/// now
|
/// now connected to its peer in the renderer process. Commands can be routed.
|
||||||
/// connected to its peer in the renderer process. Commands can be routed.
|
|
||||||
///
|
///
|
||||||
/// (2) During further cef_browser_host_t navigation/loading of the main frame
|
/// (2) During further cef_browser_host_t navigation/loading of the main frame
|
||||||
/// and/or sub-frames:
|
/// and/or sub-frames:
|
||||||
/// - cef_frame_handler_t::OnFrameCreated => A new main frame or sub-frame
|
/// - cef_frame_handler_t::OnFrameCreated => A new main frame or sub-frame
|
||||||
/// object
|
/// object has been created. Any commands will be queued until the frame is
|
||||||
/// has been created. Any commands will be queued until the frame is attached.
|
/// attached.
|
||||||
/// - cef_frame_handler_t::OnFrameAttached => A new main frame or sub-frame
|
/// - cef_frame_handler_t::OnFrameAttached => A new main frame or sub-frame
|
||||||
/// object
|
/// object is now connected to its peer in the renderer process. Commands can
|
||||||
/// is now connected to its peer in the renderer process. Commands can be
|
/// be routed.
|
||||||
/// routed.
|
|
||||||
/// - cef_frame_handler_t::OnFrameDetached => An existing main frame or sub-
|
/// - cef_frame_handler_t::OnFrameDetached => An existing main frame or sub-
|
||||||
/// frame
|
/// frame object has lost its connection to the renderer process. If multiple
|
||||||
/// object has lost its connection to the renderer process. If multiple
|
|
||||||
/// objects are detached at the same time then notifications will be sent for
|
/// objects are detached at the same time then notifications will be sent for
|
||||||
/// any sub-frame objects before the main frame object. Commands can no longer
|
/// any sub-frame objects before the main frame object. Commands can no longer
|
||||||
/// be routed and will be discarded.
|
/// be routed and will be discarded.
|
||||||
/// - cef_frame_handler_t::OnMainFrameChanged => A new main frame object has
|
/// - cef_frame_handler_t::OnMainFrameChanged => A new main frame object has
|
||||||
/// been
|
/// been assigned to the browser. This will only occur with cross-origin
|
||||||
/// assigned to the browser. This will only occur with cross-origin navigation
|
/// navigation or re-navigation after renderer process termination (due to
|
||||||
/// or re-navigation after renderer process termination (due to crashes, etc).
|
/// crashes, etc).
|
||||||
///
|
///
|
||||||
/// (3) During final cef_browser_host_t destruction of the main frame: -
|
/// (3) During final cef_browser_host_t destruction of the main frame:
|
||||||
/// cef_frame_handler_t::OnFrameDetached => Any sub-frame objects have lost
|
/// - cef_frame_handler_t::OnFrameDetached => Any sub-frame objects have lost
|
||||||
/// their
|
/// their connection to the renderer process. Commands can no longer be routed
|
||||||
/// connection to the renderer process. Commands can no longer be routed and
|
/// and will be discarded.
|
||||||
/// will be discarded.
|
|
||||||
/// - cef_life_span_handler_t::OnBeforeClose => The browser has been destroyed.
|
/// - cef_life_span_handler_t::OnBeforeClose => The browser has been destroyed.
|
||||||
/// - cef_frame_handler_t::OnFrameDetached => The main frame object have lost
|
/// - cef_frame_handler_t::OnFrameDetached => The main frame object have lost
|
||||||
/// its
|
/// its connection to the renderer process. Notifications will be sent for any
|
||||||
/// connection to the renderer process. Notifications will be sent for any
|
|
||||||
/// sub-frame objects before the main frame object. Commands can no longer be
|
/// sub-frame objects before the main frame object. Commands can no longer be
|
||||||
/// routed and will be discarded.
|
/// routed and will be discarded.
|
||||||
/// - cef_frame_handler_t::OnMainFrameChanged => The final main frame object has
|
/// - cef_frame_handler_t::OnMainFrameChanged => The final main frame object has
|
||||||
@@ -111,7 +104,7 @@ extern "C" {
|
|||||||
/// will then be discarded after the real cross-origin sub-frame is created in
|
/// will then be discarded after the real cross-origin sub-frame is created in
|
||||||
/// the new/target renderer process. The client will receive cross-origin
|
/// the new/target renderer process. The client will receive cross-origin
|
||||||
/// navigation callbacks (2) for the transition from the temporary sub-frame to
|
/// navigation callbacks (2) for the transition from the temporary sub-frame to
|
||||||
/// the real sub-frame. The temporary sub-frame will not recieve or execute
|
/// the real sub-frame. The temporary sub-frame will not receive or execute
|
||||||
/// commands during this transitional period (any sent commands will be
|
/// commands during this transitional period (any sent commands will be
|
||||||
/// discarded).
|
/// discarded).
|
||||||
///
|
///
|
||||||
@@ -119,7 +112,7 @@ extern "C" {
|
|||||||
/// browser, a temporary main frame object for the popup will first be created
|
/// browser, a temporary main frame object for the popup will first be created
|
||||||
/// in the parent's renderer process. That temporary main frame will then be
|
/// in the parent's renderer process. That temporary main frame will then be
|
||||||
/// discarded after the real cross-origin main frame is created in the
|
/// discarded after the real cross-origin main frame is created in the
|
||||||
/// new/target renderer process. The client will recieve creation and initial
|
/// new/target renderer process. The client will receive creation and initial
|
||||||
/// navigation callbacks (1) for the temporary main frame, followed by cross-
|
/// navigation callbacks (1) for the temporary main frame, followed by cross-
|
||||||
/// origin navigation callbacks (2) for the transition from the temporary main
|
/// origin navigation callbacks (2) for the transition from the temporary main
|
||||||
/// frame to the real main frame. The temporary main frame may receive and
|
/// frame to the real main frame. The temporary main frame may receive and
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=14f7f979f668fdae0f080daa39f3c1b2e92162f9$
|
// $hash=990e80ab5ae04298e6b70cbc0a67115825563251$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_I18N_UTIL_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_I18N_UTIL_CAPI_H_
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=f679dc1ec87e99bed6843d4f4dbbe04585a827bd$
|
// $hash=7512ccf755017d5b1866b753890b498e8163006d$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_IMAGE_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_IMAGE_CAPI_H_
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=523a692475e912e4ecad89842596c3d6eac6f4aa$
|
// $hash=c6810367ba3a17824247dcb17f87040cd021c295$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_JSDIALOG_HANDLER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_JSDIALOG_HANDLER_CAPI_H_
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=01d7f86c1304efe8dc8758624b74bafccf159e96$
|
// $hash=0bfe161c51cc6378b2e8e2e2b2c017b750b46864$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_KEYBOARD_HANDLER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_KEYBOARD_HANDLER_CAPI_H_
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=44555ceece9989dabfa57a520168fa874dcfe2df$
|
// $hash=5232dd6bf16af9b6d195a47bb41de0dfb880a65e$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_LIFE_SPAN_HANDLER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_LIFE_SPAN_HANDLER_CAPI_H_
|
||||||
@@ -100,6 +100,34 @@ typedef struct _cef_life_span_handler_t {
|
|||||||
struct _cef_dictionary_value_t** extra_info,
|
struct _cef_dictionary_value_t** extra_info,
|
||||||
int* no_javascript_access);
|
int* no_javascript_access);
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Called on the UI thread before a new DevTools popup browser is created.
|
||||||
|
/// The |browser| value represents the source of the popup request. Optionally
|
||||||
|
/// modify |windowInfo|, |client|, |settings| and |extra_info| values. The
|
||||||
|
/// |client|, |settings| and |extra_info| values will default to the source
|
||||||
|
/// browser's values. Any modifications to |windowInfo| will be ignored if the
|
||||||
|
/// parent browser is Views-hosted (wrapped in a cef_browser_view_t).
|
||||||
|
///
|
||||||
|
/// The |extra_info| parameter provides an opportunity to specify extra
|
||||||
|
/// information specific to the created popup browser that will be passed to
|
||||||
|
/// cef_render_process_handler_t::on_browser_created() in the render process.
|
||||||
|
/// The existing |extra_info| object, if any, will be read-only but may be
|
||||||
|
/// replaced with a new object.
|
||||||
|
///
|
||||||
|
/// Views-hosted source browsers will create Views-hosted DevTools popups
|
||||||
|
/// unless |use_default_window| is set to to true (1). DevTools popups can be
|
||||||
|
/// blocked by returning true (1) from cef_command_handler_t::OnChromeCommand
|
||||||
|
/// for IDC_DEV_TOOLS. Only used with Chrome style.
|
||||||
|
///
|
||||||
|
void(CEF_CALLBACK* on_before_dev_tools_popup)(
|
||||||
|
struct _cef_life_span_handler_t* self,
|
||||||
|
struct _cef_browser_t* browser,
|
||||||
|
struct _cef_window_info_t* windowInfo,
|
||||||
|
struct _cef_client_t** client,
|
||||||
|
struct _cef_browser_settings_t* settings,
|
||||||
|
struct _cef_dictionary_value_t** extra_info,
|
||||||
|
int* use_default_window);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Called after a new browser is created. It is now safe to begin performing
|
/// Called after a new browser is created. It is now safe to begin performing
|
||||||
/// actions with |browser|. cef_frame_handler_t callbacks related to initial
|
/// actions with |browser|. cef_frame_handler_t callbacks related to initial
|
||||||
@@ -110,7 +138,7 @@ typedef struct _cef_life_span_handler_t {
|
|||||||
struct _cef_browser_t* browser);
|
struct _cef_browser_t* browser);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Called when a browser has recieved a request to close. This may result
|
/// Called when a browser has received a request to close. This may result
|
||||||
/// directly from a call to cef_browser_host_t::*close_browser() or indirectly
|
/// directly from a call to cef_browser_host_t::*close_browser() or indirectly
|
||||||
/// if the browser is parented to a top-level window created by CEF and the
|
/// if the browser is parented to a top-level window created by CEF and the
|
||||||
/// user attempts to close that window (by clicking the 'X', for example). The
|
/// user attempts to close that window (by clicking the 'X', for example). The
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=2713381c9969d7039e6c1a1ed2527e5aeb5425ce$
|
// $hash=eb842e65cd2e7c4a8a6baa2813b57ac0d3977261$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_LOAD_HANDLER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_LOAD_HANDLER_CAPI_H_
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=77920892e7d9e8b98106e0bc8dfcf4b4c52a24e6$
|
// $hash=8eec1100e8470cbe3ebc54d5962416d2fa4d57fb$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_MEDIA_ROUTER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_MEDIA_ROUTER_CAPI_H_
|
||||||
@@ -114,8 +114,8 @@ typedef struct _cef_media_router_t {
|
|||||||
/// Returns the MediaRouter object associated with the global request context.
|
/// Returns the MediaRouter object associated with the global request context.
|
||||||
/// If |callback| is non-NULL it will be executed asnychronously on the UI
|
/// If |callback| is non-NULL it will be executed asnychronously on the UI
|
||||||
/// thread after the manager's storage has been initialized. Equivalent to
|
/// thread after the manager's storage has been initialized. Equivalent to
|
||||||
/// calling cef_request_context_t::cef_request_context_get_global_context()->get
|
/// calling cef_request_context_t::cef_request_context_get_global_context()-
|
||||||
/// _media_router().
|
/// >get_media_router().
|
||||||
///
|
///
|
||||||
CEF_EXPORT cef_media_router_t* cef_media_router_get_global(
|
CEF_EXPORT cef_media_router_t* cef_media_router_get_global(
|
||||||
struct _cef_completion_callback_t* callback);
|
struct _cef_completion_callback_t* callback);
|
||||||
@@ -156,7 +156,7 @@ typedef struct _cef_media_observer_t {
|
|||||||
cef_media_route_connection_state_t state);
|
cef_media_route_connection_state_t state);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// A message was recieved over |route|. |message| is only valid for the scope
|
/// A message was received over |route|. |message| is only valid for the scope
|
||||||
/// of this callback and should be copied if necessary.
|
/// of this callback and should be copied if necessary.
|
||||||
///
|
///
|
||||||
void(CEF_CALLBACK* on_route_message_received)(
|
void(CEF_CALLBACK* on_route_message_received)(
|
||||||
@@ -257,13 +257,6 @@ typedef struct _cef_media_sink_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_name)(struct _cef_media_sink_t* self);
|
cef_string_userfree_t(CEF_CALLBACK* get_name)(struct _cef_media_sink_t* self);
|
||||||
|
|
||||||
///
|
|
||||||
/// Returns the description of this sink.
|
|
||||||
///
|
|
||||||
// The resulting string must be freed by calling cef_string_userfree_free().
|
|
||||||
cef_string_userfree_t(CEF_CALLBACK* get_description)(
|
|
||||||
struct _cef_media_sink_t* self);
|
|
||||||
|
|
||||||
///
|
///
|
||||||
/// Returns the icon type for this sink.
|
/// Returns the icon type for this sink.
|
||||||
///
|
///
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=4bf9250599e3ba26e7f74ec22338548492202625$
|
// $hash=5dae0b1a1271e79a5fd9b2c6e71e7a719a450161$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_MENU_MODEL_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_MENU_MODEL_CAPI_H_
|
||||||
@@ -473,14 +473,15 @@ typedef struct _cef_menu_model_t {
|
|||||||
///
|
///
|
||||||
/// Sets the font list for the specified |command_id|. If |font_list| is NULL
|
/// 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
|
/// 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
|
/// "<FONT_FAMILY_LIST>,[STYLES] <SIZE>", where:
|
||||||
/// comma-separated list of font family names, - STYLES is an optional space-
|
/// - FONT_FAMILY_LIST is a comma-separated list of font family names,
|
||||||
/// separated list of style names
|
/// - STYLES is an optional space-separated list of style names (case-
|
||||||
/// (case-sensitive "Bold" and "Italic" are supported), and
|
/// sensitive "Bold" and "Italic" are supported), and
|
||||||
/// - SIZE is an integer font size in pixels with the suffix "px".
|
/// - SIZE is an integer font size in pixels with the suffix "px".
|
||||||
///
|
///
|
||||||
/// Here are examples of valid font description strings: - "Arial, Helvetica,
|
/// Here are examples of valid font description strings:
|
||||||
/// Bold Italic 14px" - "Arial, 14px"
|
/// - "Arial, Helvetica, Bold Italic 14px"
|
||||||
|
/// - "Arial, 14px"
|
||||||
///
|
///
|
||||||
int(CEF_CALLBACK* set_font_list)(struct _cef_menu_model_t* self,
|
int(CEF_CALLBACK* set_font_list)(struct _cef_menu_model_t* self,
|
||||||
int command_id,
|
int command_id,
|
||||||
@@ -488,16 +489,15 @@ typedef struct _cef_menu_model_t {
|
|||||||
|
|
||||||
///
|
///
|
||||||
/// Sets the font list for the specified |index|. Specify an |index| value of
|
/// 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
|
/// - 1 to set the default font. If |font_list| is NULL the system font will
|
||||||
/// used. Returns true (1) on success. The format is
|
/// - FONT_FAMILY_LIST is a comma-separated list of font family names,
|
||||||
/// "<FONT_FAMILY_LIST>,[STYLES] <SIZE>", where: - FONT_FAMILY_LIST is a
|
/// - STYLES is an optional space-separated list of style names (case-
|
||||||
/// comma-separated list of font family names, - STYLES is an optional space-
|
/// sensitive "Bold" and "Italic" are supported), and
|
||||||
/// 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".
|
/// - SIZE is an integer font size in pixels with the suffix "px".
|
||||||
///
|
///
|
||||||
/// Here are examples of valid font description strings: - "Arial, Helvetica,
|
/// Here are examples of valid font description strings:
|
||||||
/// Bold Italic 14px" - "Arial, 14px"
|
/// - "Arial, Helvetica, Bold Italic 14px"
|
||||||
|
/// - "Arial, 14px"
|
||||||
///
|
///
|
||||||
int(CEF_CALLBACK* set_font_list_at)(struct _cef_menu_model_t* self,
|
int(CEF_CALLBACK* set_font_list_at)(struct _cef_menu_model_t* self,
|
||||||
int index,
|
int index,
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=8254165498a527d40517c1bc8ec413ad7a0ed259$
|
// $hash=01bdeaf96ea01591689b52b0955504644d6614b8$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_MENU_MODEL_DELEGATE_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_MENU_MODEL_DELEGATE_CAPI_H_
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=2822d96d72b7df816c0fefb4ce1cbba18add50ac$
|
// $hash=dbdac05f2ebd8e8a357eacfe5095676a5bd5b1ac$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_NAVIGATION_ENTRY_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_NAVIGATION_ENTRY_CAPI_H_
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=a40860835e6e693ed2f85eab5fa7990b7f2c7bbe$
|
// $hash=f146fd9172033e77e90994841df9fa55ff71aa4b$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_ORIGIN_WHITELIST_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_ORIGIN_WHITELIST_CAPI_H_
|
||||||
@@ -70,7 +70,7 @@ extern "C" {
|
|||||||
/// qualified |source_origin| URL (like http://www.example.com) will be allowed
|
/// qualified |source_origin| URL (like http://www.example.com) will be allowed
|
||||||
/// access to all resources hosted on the specified |target_protocol| and
|
/// access to all resources hosted on the specified |target_protocol| and
|
||||||
/// |target_domain|. If |target_domain| is non-NULL and
|
/// |target_domain|. If |target_domain| is non-NULL and
|
||||||
/// |allow_target_subdomains| if false (0) only exact domain matches will be
|
/// |allow_target_subdomains| is false (0) only exact domain matches will be
|
||||||
/// allowed. If |target_domain| contains a top- level domain component (like
|
/// allowed. If |target_domain| contains a top- level domain component (like
|
||||||
/// "example.com") and |allow_target_subdomains| is true (1) sub-domain matches
|
/// "example.com") and |allow_target_subdomains| is true (1) sub-domain matches
|
||||||
/// will be allowed. If |target_domain| is NULL and |allow_target_subdomains| if
|
/// will be allowed. If |target_domain| is NULL and |allow_target_subdomains| if
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
// Copyright (c) 2022 Marshall A. Greenblatt. All rights reserved.
|
// Copyright (c) 2024 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,7 +33,7 @@
|
|||||||
// 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=a6cb0abd77320cfd9ddfa3f16ca0a6ff3987521a$
|
// $hash=8accded29b97df1549e86e58d8976fe0f800359a$
|
||||||
//
|
//
|
||||||
|
|
||||||
#ifndef CEF_INCLUDE_CAPI_CEF_PARSER_CAPI_H_
|
#ifndef CEF_INCLUDE_CAPI_CEF_PARSER_CAPI_H_
|
||||||
@@ -46,6 +46,14 @@
|
|||||||
extern "C" {
|
extern "C" {
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
///
|
||||||
|
/// Combines specified |base_url| and |relative_url| into |resolved_url|.
|
||||||
|
/// Returns false (0) if one of the URLs is NULL or invalid.
|
||||||
|
///
|
||||||
|
CEF_EXPORT int cef_resolve_url(const cef_string_t* base_url,
|
||||||
|
const cef_string_t* relative_url,
|
||||||
|
cef_string_t* resolved_url);
|
||||||
|
|
||||||
///
|
///
|
||||||
/// 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.
|
||||||
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user