-
Notifications
You must be signed in to change notification settings - Fork 29
/
.gn
122 lines (115 loc) · 5.28 KB
/
.gn
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
# This file is used by the GN meta build system to find the root of the source
# tree and to set startup options. For documentation on the values set in this
# file, run "gn help dotfile" at the command line.
# We need to allow the chromium GN files to use their normal path naming
# convention, therefore we map the actual path to new paths, with all vivaldi
# files having the prefix //vivaldi/ while chromium is using // as the prefix.
# The out directories are in the vivaldi folder and thus we have to override
# the path replacement to chromium for them
set_path_map([
# Prefix, actual path
# Most specific prefixes first
[
"//vivaldi",
"//",
],
[
"//out",
"//out",
],
[
"//",
"//chromium",
],
])
# We mainly use the chromium setup, no need to duplicate the system
import("//chromium/.gn")
buildconfig = "//vivaldi/gn/config/BUILDCONFIG.gn"
# We normally build the component build
# The autobuilders builds statically linked builds
default_args.is_component_build = true
# Static feature overrides, don't change
# Features we either always want enable or don't want at all
# Cannot depend on platform settings
default_args.enable_remoting = false
default_args.enable_nacl = false
default_args.enable_ipc_fuzzer = false
default_args.angle_enable_commit_id = false
default_args.devtools_skip_typecheck = false
default_args.use_dummy_lastchange = false
# We don't need the Chrome field trials
default_args.disable_fieldtrial_testing_config = true
# These are the targets to check headers for by default. The files in targets
# matching these patterns (see "gn help label_pattern" for format) will have
# their includes checked for proper dependencies when you run either
# "gn check" or "gn gen --check".
no_check_targets += []
# These are the list of GN files that run exec_script. This whitelist exists
# to force additional review for new uses of exec_script, which is strongly
# discouraged.
#
# GYPI_TO_GN
#
# Most of these entries are for gypi_to_gn calls. We should not be adding new
# calls to this script in the build (see //build/gypi_to_gn.py for detailed
# advice). The only time you should be editing this list for gypi_to_gn
# purposes is when moving an existing call to a different place.
#
# PLEASE READ
#
# You should almost never need to add new exec_script calls. exec_script is
# slow, especially on Windows, and can cause confusing effects. Although
# individually each call isn't slow or necessarily very confusing, at the scale
# of our repo things get out of hand quickly. By strongly pushing back on all
# additions, we keep the build fast and clean. If you think you need to add a
# new call, please consider:
#
# - Do not use a script to check for the existance of a file or directory to
# enable a different mode. Instead, use GN build args to enable or disable
# functionality and set options. An example is checking for a file in the
# src-internal repo to see if the corresponding src-internal feature should
# be enabled. There are several things that can go wrong with this:
#
# - It's mysterious what causes some things to happen. Although in many cases
# such behavior can be conveniently automatic, GN optimizes for explicit
# and obvious behavior so people can more easily diagnose problems.
#
# - The user can't enable a mode for one build and not another. With GN build
# args, the user can choose the exact configuration of multiple builds
# using one checkout. But implicitly basing flags on the state of the
# checkout, this functionality is broken.
#
# - It's easy to get stale files. If for example the user edits the gclient
# to stop checking out src-internal (or any other optional thing), it's
# easy to end up with stale files still mysteriously triggering build
# conditions that are no longer appropriate (yes, this happens in real
# life).
#
# - Do not use a script to iterate files in a directory (glob):
#
# - This has the same "stale file" problem as the above discussion. Various
# operations can leave untracked files in the source tree which can cause
# surprising effects.
#
# - It becomes impossible to use "git grep" to find where a certain file is
# referenced. This operation is very common and people really do get
# confused when things aren't listed.
#
# - It's easy to screw up. One common case is a build-time script that packs
# up a directory. The author notices that the script isn't re-run when the
# directory is updated, so adds a glob so all the files are listed as
# inputs. This seems to work great... until a file is deleted. When a
# file is deleted, all the inputs the glob lists will still be up to date
# and no command-lines will have been changed. The action will not be
# re-run and the build will be broken. It is possible to get this correct
# using glob, and it's possible to mess it up without glob, but globs make
# this situation much easier to create. if the build always lists the
# files and passes them to a script, it will always be correct.
exec_script_whitelist += [
"//vivaldi/app/BUILD.gn",
"//vivaldi/gn/config/product.gni",
"//vivaldi/gn/config/stored_version.gni",
"//vivaldi/gn/config/version.gni",
"//vivaldi/app/resources/untranslated.gni",
"//vivaldi/vivapp/BUILD.gn",
]