mirror of
https://github.com/klzgrad/naiveproxy.git
synced 2024-12-01 01:36:09 +03:00
291 lines
9.7 KiB
C++
291 lines
9.7 KiB
C++
|
// Copyright 2014 The Chromium Authors. All rights reserved.
|
||
|
// Use of this source code is governed by a BSD-style license that can be
|
||
|
// found in the LICENSE file.
|
||
|
|
||
|
#include "tools/gn/switches.h"
|
||
|
|
||
|
namespace switches {
|
||
|
|
||
|
const char kArgs[] = "args";
|
||
|
const char kArgs_HelpShort[] =
|
||
|
"--args: Specifies build arguments overrides.";
|
||
|
const char kArgs_Help[] =
|
||
|
R"(--args: Specifies build arguments overrides.
|
||
|
|
||
|
See "gn help buildargs" for an overview of how build arguments work.
|
||
|
|
||
|
Most operations take a build directory. The build arguments are taken from
|
||
|
the previous build done in that directory. If a command specifies --args, it
|
||
|
will override the previous arguments stored in the build directory, and use
|
||
|
the specified ones.
|
||
|
|
||
|
The args specified will be saved to the build directory for subsequent
|
||
|
commands. Specifying --args="" will clear all build arguments.
|
||
|
|
||
|
Formatting
|
||
|
|
||
|
The value of the switch is interpreted in GN syntax. For typical usage of
|
||
|
string arguments, you will need to be careful about escaping of quotes.
|
||
|
|
||
|
Examples
|
||
|
|
||
|
gn gen out/Default --args="foo=\"bar\""
|
||
|
|
||
|
gn gen out/Default --args='foo="bar" enable=true blah=7'
|
||
|
|
||
|
gn check out/Default --args=""
|
||
|
Clears existing build args from the directory.
|
||
|
|
||
|
gn desc out/Default --args="some_list=[1, false, \"foo\"]"
|
||
|
)";
|
||
|
|
||
|
#define COLOR_HELP_LONG \
|
||
|
"--[no]color: Forces colored output on or off.\n"\
|
||
|
"\n"\
|
||
|
" Normally GN will try to detect whether it is outputting to a terminal\n"\
|
||
|
" and will enable or disable color accordingly. Use of these switches\n"\
|
||
|
" will override the default.\n"\
|
||
|
"\n"\
|
||
|
"Examples\n"\
|
||
|
"\n"\
|
||
|
" gn gen out/Default --color\n"\
|
||
|
"\n"\
|
||
|
" gn gen out/Default --nocolor\n"
|
||
|
const char kColor[] = "color";
|
||
|
const char kColor_HelpShort[] =
|
||
|
"--color: Force colored output.";
|
||
|
const char kColor_Help[] = COLOR_HELP_LONG;
|
||
|
|
||
|
const char kDotfile[] = "dotfile";
|
||
|
const char kDotfile_HelpShort[] =
|
||
|
"--dotfile: Override the name of the \".gn\" file.";
|
||
|
const char kDotfile_Help[] =
|
||
|
R"(--dotfile: Override the name of the ".gn" file.
|
||
|
|
||
|
Normally GN loads the ".gn"file from the source root for some basic
|
||
|
configuration (see "gn help dotfile"). This flag allows you to
|
||
|
use a different file.
|
||
|
|
||
|
Note that this interacts with "--root" in a possibly incorrect way.
|
||
|
It would be nice to test the edge cases and document or fix.
|
||
|
)";
|
||
|
|
||
|
const char kFailOnUnusedArgs[] = "fail-on-unused-args";
|
||
|
const char kFailOnUnusedArgs_HelpShort[] =
|
||
|
"--fail-on-unused-args: Treat unused build args as fatal errors.";
|
||
|
const char kFailOnUnusedArgs_Help[] =
|
||
|
R"(--fail-on-unused-args: Treat unused build args as fatal errors.
|
||
|
|
||
|
If you set a value in a build's "gn args" and never use it in the build (in
|
||
|
a declare_args() block), GN will normally print an error but not fail the
|
||
|
build.
|
||
|
|
||
|
In many cases engineers would use build args to enable or disable features
|
||
|
that would sometimes get removed. It would by annoying to block work for
|
||
|
typically benign problems. In Chrome in particular, flags might be configured
|
||
|
for build bots in a separate infrastructure repository, or a declare_args
|
||
|
block might be changed in a third party repository. Treating these errors as
|
||
|
blocking forced complex multi- way patches to land what would otherwise be
|
||
|
simple changes.
|
||
|
|
||
|
In some cases, such concerns are not as important, and a mismatch in build
|
||
|
flags between the invoker of the build and the build files represents a
|
||
|
critical mismatch that should be immediately fixed. Such users can set this
|
||
|
flag to force GN to fail in that case.
|
||
|
)";
|
||
|
|
||
|
const char kMarkdown[] = "markdown";
|
||
|
const char kMarkdown_HelpShort[] =
|
||
|
"--markdown: Write help output in the Markdown format.";
|
||
|
const char kMarkdown_Help[] =
|
||
|
"--markdown: Write help output in the Markdown format.\n";
|
||
|
|
||
|
const char kNoColor[] = "nocolor";
|
||
|
const char kNoColor_HelpShort[] =
|
||
|
"--nocolor: Force non-colored output.";
|
||
|
const char kNoColor_Help[] = COLOR_HELP_LONG;
|
||
|
|
||
|
const char kScriptExecutable[] = "script-executable";
|
||
|
const char kScriptExecutable_HelpShort[] =
|
||
|
"--script-executable: Set the executable used to execute scripts.";
|
||
|
const char kScriptExecutable_Help[] =
|
||
|
R"(--script-executable: Set the executable used to execute scripts.
|
||
|
|
||
|
By default GN searches the PATH for Python to execute scripts in action
|
||
|
targets and exec_script calls. This flag allows the specification of a
|
||
|
specific Python executable or potentially a different language
|
||
|
interpreter.
|
||
|
)";
|
||
|
|
||
|
const char kQuiet[] = "q";
|
||
|
const char kQuiet_HelpShort[] =
|
||
|
"-q: Quiet mode. Don't print output on success.";
|
||
|
const char kQuiet_Help[] =
|
||
|
R"(-q: Quiet mode. Don't print output on success.
|
||
|
|
||
|
This is useful when running as a part of another script.
|
||
|
)";
|
||
|
|
||
|
const char kRoot[] = "root";
|
||
|
const char kRoot_HelpShort[] =
|
||
|
"--root: Explicitly specify source root.";
|
||
|
const char kRoot_Help[] =
|
||
|
R"(--root: Explicitly specify source root.
|
||
|
|
||
|
Normally GN will look up in the directory tree from the current directory to
|
||
|
find a ".gn" file. The source root directory specifies the meaning of "//"
|
||
|
beginning with paths, and the BUILD.gn file in that directory will be the
|
||
|
first thing loaded.
|
||
|
|
||
|
Specifying --root allows GN to do builds in a specific directory regardless
|
||
|
of the current directory.
|
||
|
|
||
|
Examples
|
||
|
|
||
|
gn gen //out/Default --root=/home/baracko/src
|
||
|
|
||
|
gn desc //out/Default --root="C:\Users\BObama\My Documents\foo"
|
||
|
)";
|
||
|
|
||
|
const char kRuntimeDepsListFile[] = "runtime-deps-list-file";
|
||
|
const char kRuntimeDepsListFile_HelpShort[] =
|
||
|
"--runtime-deps-list-file: Save runtime dependencies for targets in file.";
|
||
|
const char kRuntimeDepsListFile_Help[] =
|
||
|
R"(--runtime-deps-list-file: Save runtime dependencies for targets in file.
|
||
|
|
||
|
--runtime-deps-list-file=<filename>
|
||
|
|
||
|
Where <filename> is a text file consisting of the labels, one per line, of
|
||
|
the targets for which runtime dependencies are desired.
|
||
|
|
||
|
See "gn help runtime_deps" for a description of how runtime dependencies are
|
||
|
computed.
|
||
|
|
||
|
Runtime deps output file
|
||
|
|
||
|
For each target requested, GN will write a separate runtime dependency file.
|
||
|
The runtime dependency file will be in the output directory alongside the
|
||
|
output file of the target, with a ".runtime_deps" extension. For example, if
|
||
|
the target "//foo:bar" is listed in the input file, and that target produces
|
||
|
an output file "bar.so", GN will create a file "bar.so.runtime_deps" in the
|
||
|
build directory.
|
||
|
|
||
|
If a source set, action, copy, or group is listed, the runtime deps file will
|
||
|
correspond to the .stamp file corresponding to that target. This is probably
|
||
|
not useful; the use-case for this feature is generally executable targets.
|
||
|
|
||
|
The runtime dependency file will list one file per line, with no escaping.
|
||
|
The files will be relative to the root_build_dir. The first line of the file
|
||
|
will be the main output file of the target itself (in the above example,
|
||
|
"bar.so").
|
||
|
)";
|
||
|
|
||
|
const char kThreads[] = "threads";
|
||
|
const char kThreads_HelpShort[] =
|
||
|
"--threads: Specify number of worker threads.";
|
||
|
const char kThreads_Help[] =
|
||
|
R"(--threads: Specify number of worker threads.
|
||
|
|
||
|
GN runs many threads to load and run build files. This can make debugging
|
||
|
challenging. Or you may want to experiment with different values to see how
|
||
|
it affects performance.
|
||
|
|
||
|
The parameter is the number of worker threads. This does not count the main
|
||
|
thread (so there are always at least two).
|
||
|
|
||
|
Examples
|
||
|
|
||
|
gen gen out/Default --threads=1
|
||
|
)";
|
||
|
|
||
|
const char kTime[] = "time";
|
||
|
const char kTime_HelpShort[] =
|
||
|
"--time: Outputs a summary of how long everything took.";
|
||
|
const char kTime_Help[] =
|
||
|
R"(--time: Outputs a summary of how long everything took.
|
||
|
|
||
|
Hopefully self-explanatory.
|
||
|
|
||
|
Examples
|
||
|
|
||
|
gn gen out/Default --time
|
||
|
)";
|
||
|
|
||
|
const char kTracelog[] = "tracelog";
|
||
|
const char kTracelog_HelpShort[] =
|
||
|
"--tracelog: Writes a Chrome-compatible trace log to the given file.";
|
||
|
const char kTracelog_Help[] =
|
||
|
R"(--tracelog: Writes a Chrome-compatible trace log to the given file.
|
||
|
|
||
|
The trace log will show file loads, executions, scripts, and writes. This
|
||
|
allows performance analysis of the generation step.
|
||
|
|
||
|
To view the trace, open Chrome and navigate to "chrome://tracing/", then
|
||
|
press "Load" and specify the file you passed to this parameter.
|
||
|
|
||
|
Examples
|
||
|
|
||
|
gn gen out/Default --tracelog=mytrace.trace
|
||
|
)";
|
||
|
|
||
|
const char kVerbose[] = "v";
|
||
|
const char kVerbose_HelpShort[] =
|
||
|
"-v: Verbose logging.";
|
||
|
const char kVerbose_Help[] =
|
||
|
R"(-v: Verbose logging.
|
||
|
|
||
|
This will spew logging events to the console for debugging issues.
|
||
|
|
||
|
Good luck!
|
||
|
)";
|
||
|
|
||
|
const char kVersion[] = "version";
|
||
|
const char kVersion_HelpShort[] =
|
||
|
"--version: Prints the GN version number and exits.";
|
||
|
// It's impossible to see this since gn_main prints the version and exits
|
||
|
// immediately if this switch is used.
|
||
|
const char kVersion_Help[] = "";
|
||
|
|
||
|
const char kAllToolchains[] = "all-toolchains";
|
||
|
|
||
|
// -----------------------------------------------------------------------------
|
||
|
|
||
|
SwitchInfo::SwitchInfo()
|
||
|
: short_help(""),
|
||
|
long_help("") {
|
||
|
}
|
||
|
|
||
|
SwitchInfo::SwitchInfo(const char* short_help, const char* long_help)
|
||
|
: short_help(short_help),
|
||
|
long_help(long_help) {
|
||
|
}
|
||
|
|
||
|
#define INSERT_VARIABLE(var) \
|
||
|
info_map[k##var] = SwitchInfo(k##var##_HelpShort, k##var##_Help);
|
||
|
|
||
|
const SwitchInfoMap& GetSwitches() {
|
||
|
static SwitchInfoMap info_map;
|
||
|
if (info_map.empty()) {
|
||
|
INSERT_VARIABLE(Args)
|
||
|
INSERT_VARIABLE(Color)
|
||
|
INSERT_VARIABLE(Dotfile)
|
||
|
INSERT_VARIABLE(FailOnUnusedArgs)
|
||
|
INSERT_VARIABLE(Markdown)
|
||
|
INSERT_VARIABLE(NoColor)
|
||
|
INSERT_VARIABLE(Root)
|
||
|
INSERT_VARIABLE(Quiet)
|
||
|
INSERT_VARIABLE(RuntimeDepsListFile)
|
||
|
INSERT_VARIABLE(ScriptExecutable)
|
||
|
INSERT_VARIABLE(Threads)
|
||
|
INSERT_VARIABLE(Time)
|
||
|
INSERT_VARIABLE(Tracelog)
|
||
|
INSERT_VARIABLE(Verbose)
|
||
|
INSERT_VARIABLE(Version)
|
||
|
}
|
||
|
return info_map;
|
||
|
}
|
||
|
|
||
|
#undef INSERT_VARIABLE
|
||
|
|
||
|
} // namespace switches
|