[go: nahoru, domu]

blob: 6f0ce7f9e7375cd0c60d09e13e0113a81b8d2d0a [file] [log] [blame]
brettw2bafab42014-11-27 18:36:171# This file is used by the GN meta build system to find the root of the source
2# tree and to set startup options. For documentation on the values set in this
3# file, run "gn help dotfile" at the command line.
bauerb@chromium.org96ea63d2013-07-30 10:17:074
dpranke1cfa5312016-11-22 03:07:475import("//build/dotfile_settings.gni")
Jamie Madill7ec071b2018-02-06 20:16:386import("//third_party/angle/dotfile_settings.gni")
dpranke1cfa5312016-11-22 03:07:477
bauerb@chromium.org96ea63d2013-07-30 10:17:078# The location of the build configuration file.
9buildconfig = "//build/config/BUILDCONFIG.gn"
10
brettw04a0e482017-01-25 21:29:5911# These arguments override the default values for items in a declare_args
12# block. "gn args" in turn can override these.
13#
14# In general the value for a build arg in the declare_args block should be the
15# default. In some cases, a DEPS-ed in project will want different defaults for
16# being built as part of Chrome vs. being built standalone. In this case, the
17# Chrome defaults should go here. There should be no overrides here for
18# values declared in the main Chrome repository.
brettwd8a46d92017-02-08 06:03:4519#
20# Important note for defining defaults: This file is executed before the
21# BUILDCONFIG.gn file. That file sets up the global variables like "is_ios".
22# This means that the default_args can not depend on the platform,
23# architecture, or other build parameters. If you really need that, the other
24# repo should define a flag that toggles on a behavior that implements the
25# additional logic required by Chrome to set the variables.
brettw04a0e482017-01-25 21:29:5926default_args = {
Sylvain Defresne994145512017-06-06 11:27:0227 # TODO(brettw) bug 684096: Chrome on iOS does not build v8, so "gn gen" prints
28 # a warning that "Build argument has no effect". When adding a v8 variable, it
29 # also needs to be defined to src/ios/BUILD.gn (respectively removed from both
30 # location when it is removed).
31
Adam Riced91b1db2019-10-02 06:22:1832 v8_extra_library_files = []
Adam Ricebf8191d02018-04-02 11:34:2833 v8_experimental_extra_library_files = []
brettw04a0e482017-01-25 21:29:5934 v8_enable_gdbjit = false
35 v8_imminent_deprecation_warnings = false
Jochen Eisinger8be7d37b2017-06-02 08:37:5636
37 # TODO(jochen): Remove this. http://crbug.com/v8/5830,
38 # http://crbug.com/728583.
39 v8_check_microtasks_scopes_consistency = false
Niels Möller0a5db002017-10-17 13:22:1640
41 # Don't include webrtc's builtin task queue implementation.
42 rtc_link_task_queue_impl = false
Karl Wibergf3b599b2017-11-05 21:35:0043
44 # Don't include the iLBC audio codec.
45 # TODO(bugs.webrtc.org/8396): Once WebRTC gets rid of its internal
46 # deps on codecs, we can remove this.
47 rtc_include_ilbc = false
Robert Sesek9c29eaa2017-12-11 19:47:1348
49 # Changes some setup for the Crashpad build to set them to build against
50 # Chromium's zlib, base, etc.
Scott Grahamec25b512017-12-20 05:40:4051 crashpad_dependencies = "chromium"
Jamie Madill178f84e2020-12-18 00:47:5852
53 # Override ANGLE's Vulkan dependencies.
54 angle_vulkan_headers_dir = "//third_party/vulkan-deps/vulkan-headers/src"
55 angle_vulkan_loader_dir = "//third_party/vulkan-deps/vulkan-loader/src"
56 angle_vulkan_tools_dir = "//third_party/vulkan-deps/vulkan-tools/src"
57 angle_vulkan_validation_layers_dir =
58 "//third_party/vulkan-deps/vulkan-validation-layers/src"
brettw04a0e482017-01-25 21:29:5959}
60
Erik Staab8a1acf42020-07-08 19:16:4561# These are the targets to skip header checking by default. The files in targets
62# matching these patterns (see "gn help label_pattern" for format) will not have
brettw2bafab42014-11-27 18:36:1763# their includes checked for proper dependencies when you run either
64# "gn check" or "gn gen --check".
Erik Staab8a1acf42020-07-08 19:16:4565no_check_targets = [
66 # //chrome/*, https://crbug.com/949535
yoshiki iguchi6ca084b2021-03-02 05:06:3667 "//chrome/browser/media/router/discovery:*", # 4 errors
Erik Staab8a1acf42020-07-08 19:16:4568 "//chrome/browser/safe_browsing/android:*", # 3 errors
Erik Staab8a1acf42020-07-08 19:16:4569 "//chrome/browser/safety_check/android:*", # 3 errors
Erik Staab8a1acf42020-07-08 19:16:4570 "//chrome/browser/storage_access_api:*", # 2 errors
Erik Staab8a1acf42020-07-08 19:16:4571 "//chrome/browser/touch_to_fill/android:*", # 8 errors
Erik Staab8a1acf42020-07-08 19:16:4572 "//chrome/test:*", # 2682 errors
Erik Staab8a1acf42020-07-08 19:16:4573 "//extensions/browser/api/declarative_net_request:*", # 18 errors
74 "//extensions/browser/api/declarative_webrequest:*", # 29 errors
Erik Staab8a1acf42020-07-08 19:16:4575 "//extensions/browser/api/web_request:*", # 37 errors
Erik Staab8a1acf42020-07-08 19:16:4576 "//extensions/browser/api:*", # 7 errors
Erik Staab8a1acf42020-07-08 19:16:4577 "//extensions/browser:*", # 20 errors
78 "//extensions:*", # 75 errors
79 "//headless:*", # 167 errors
Erik Staab8a1acf42020-07-08 19:16:4580 "//native_client/src/trusted/service_runtime:*", # 2 errors
Erik Staab8a1acf42020-07-08 19:16:4581 "//ppapi/cpp/private:*", # 1 error
82 "//ppapi/host:*", # 1 error
83 "//ppapi/native_client/src/untrusted/pnacl_irt_shim:*", # 197 errors
84 "//ppapi/proxy:*", # 31 errors
Erik Staab8a1acf42020-07-08 19:16:4585 "//ppapi/thunk:*", # 1071 errors
86 "//ppapi:*", # 3 errors
Erik Staab8a1acf42020-07-08 19:16:4587 "//remoting/codec:*", # 32 errors
Erik Staab8a1acf42020-07-08 19:16:4588 "//remoting/host/file_transfer:*", # 43 errors
Erik Staab8a1acf42020-07-08 19:16:4589 "//remoting/host/installer/mac:*", # 1 error
90 "//remoting/host/it2me:*", # 18 errors
Erik Staab8a1acf42020-07-08 19:16:4591 "//remoting/host/mac:*", # 49 errors
Erik Staab8a1acf42020-07-08 19:16:4592 "//remoting/host/security_key:*", # 68 errors
93 "//remoting/host/setup:*", # 9 errors
Kunihiko Sakamoto05a541192021-02-08 06:34:4494 "//remoting/host/win:*", # 43 errors
Hiroki Nakagawa95f5c0612021-03-09 05:27:2995 "//remoting/host:*", # 164 errors
Erik Staab8a1acf42020-07-08 19:16:4596 "//remoting/ios/app/settings:*", # 6 errors
97 "//remoting/ios/app:*", # 9 errors
98 "//remoting/ios/audio:*", # 5 errors
99 "//remoting/ios/domain:*", # 2 errors
100 "//remoting/ios/facade:*", # 8 errors
101 "//remoting/ios/persistence:*", # 10 errors
102 "//remoting/ios/session:*", # 7 errors
103 "//remoting/ios:*", # 2 errors
Muyao Xu798e6e22021-03-01 19:01:02104 "//remoting/protocol:*", # 3 errors
105 "//remoting/test:*", # 2 error
Erik Staab8a1acf42020-07-08 19:16:45106 "//sandbox/win:*", # 7 errors
Daniel Bratell5c1bccba2019-04-23 17:37:02107
Erik Staab8a1acf42020-07-08 19:16:45108 "//third_party/icu/*",
109 "//third_party/libvpx:*", # 164 errors
110 "//third_party/libwebp:*", # 80 errors, https://crbug.com/800762
Devlin Cronin8f5ee7792018-08-21 18:32:34111
Erik Staab8a1acf42020-07-08 19:16:45112 # //v8/*, https://crbug.com/v8/7330
113 "//v8/src/inspector:*", # 20 errors
114 "//v8/test/cctest:*", # 26 errors
115 "//v8/test/unittests:*", # 11 errors
116 "//v8/test/wasm-api-tests:*", # 13 errors
117 "//v8/third_party/inspector_protocol:*", # 2 errors
118 "//v8/tools/debug_helper:*", # 9 errors
119 "//v8/tools/v8windbg:*", # 2 errors
120 "//v8:*", # 1871 errors
brettwe75311d2015-02-17 23:56:46121]
brettwed99f7b2015-04-07 00:22:50122
123# These are the list of GN files that run exec_script. This whitelist exists
124# to force additional review for new uses of exec_script, which is strongly
brettwd385ecf2016-04-19 22:53:23125# discouraged.
126#
brettwd385ecf2016-04-19 22:53:23127# PLEASE READ
128#
129# You should almost never need to add new exec_script calls. exec_script is
130# slow, especially on Windows, and can cause confusing effects. Although
131# individually each call isn't slow or necessarily very confusing, at the scale
132# of our repo things get out of hand quickly. By strongly pushing back on all
133# additions, we keep the build fast and clean. If you think you need to add a
134# new call, please consider:
135#
Wei-Yin Chen (陳威尹)fec2ace2018-08-10 23:31:24136# - Do not use a script to check for the existence of a file or directory to
brettwd385ecf2016-04-19 22:53:23137# enable a different mode. Instead, use GN build args to enable or disable
138# functionality and set options. An example is checking for a file in the
139# src-internal repo to see if the corresponding src-internal feature should
140# be enabled. There are several things that can go wrong with this:
141#
142# - It's mysterious what causes some things to happen. Although in many cases
143# such behavior can be conveniently automatic, GN optimizes for explicit
144# and obvious behavior so people can more easily diagnose problems.
145#
146# - The user can't enable a mode for one build and not another. With GN build
147# args, the user can choose the exact configuration of multiple builds
148# using one checkout. But implicitly basing flags on the state of the
149# checkout, this functionality is broken.
150#
151# - It's easy to get stale files. If for example the user edits the gclient
152# to stop checking out src-internal (or any other optional thing), it's
153# easy to end up with stale files still mysteriously triggering build
154# conditions that are no longer appropriate (yes, this happens in real
155# life).
156#
157# - Do not use a script to iterate files in a directory (glob):
158#
159# - This has the same "stale file" problem as the above discussion. Various
160# operations can leave untracked files in the source tree which can cause
161# surprising effects.
162#
163# - It becomes impossible to use "git grep" to find where a certain file is
164# referenced. This operation is very common and people really do get
165# confused when things aren't listed.
166#
167# - It's easy to screw up. One common case is a build-time script that packs
168# up a directory. The author notices that the script isn't re-run when the
169# directory is updated, so adds a glob so all the files are listed as
170# inputs. This seems to work great... until a file is deleted. When a
thakis3e861de2016-06-14 14:24:01171# file is deleted, all the inputs the glob lists will still be up to date
brettwd385ecf2016-04-19 22:53:23172# and no command-lines will have been changed. The action will not be
173# re-run and the build will be broken. It is possible to get this correct
174# using glob, and it's possible to mess it up without glob, but globs make
175# this situation much easier to create. if the build always lists the
176# files and passes them to a script, it will always be correct.
dgn470951712015-04-07 10:37:47177
dpranke1cfa5312016-11-22 03:07:47178exec_script_whitelist =
Jamie Madill7ec071b2018-02-06 20:16:38179 build_dotfile_settings.exec_script_whitelist +
180 angle_dotfile_settings.exec_script_whitelist +
181 [
dpranke1cfa5312016-11-22 03:07:47182 # Whitelist entries for //build should go into
183 # //build/dotfile_settings.gni instead, so that they can be shared
184 # with other repos. The entries in this list should be only for files
185 # in the Chromium repo outside of //build.
dpranke1cfa5312016-11-22 03:07:47186 "//build_overrides/build.gni",
dgn470951712015-04-07 10:37:47187
Peter Kotwiczf4f4cd62019-06-11 19:57:38188 "//chrome/android/webapk/shell_apk/prepare_upload_dir/BUILD.gn",
189
dpranke1cfa5312016-11-22 03:07:47190 # TODO(dgn): Layer violation but breaks the build otherwise, see
191 # https://crbug.com/474506.
192 "//clank/java/BUILD.gn",
193 "//clank/native/BUILD.gn",
brettw46134cb2016-09-02 23:53:18194
Nico Weber097f64c2018-10-23 17:48:02195 "//google_apis/BUILD.gn",
196 "//printing/BUILD.gn",
197
dpranke1cfa5312016-11-22 03:07:47198 "//remoting/host/installer/linux/BUILD.gn",
199 "//remoting/remoting_version.gni",
200 "//remoting/host/installer/win/generate_clsids.gni",
brettwde7b2652016-09-09 23:25:05201
dpranke1cfa5312016-11-22 03:07:47202 "//tools/grit/grit_rule.gni",
Andrew Grieve11c825d72020-01-03 00:51:33203 "//tools/gritsettings/BUILD.gn",
dpranke1cfa5312016-11-22 03:07:47204 ]