• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright (c) 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 
5 #include <algorithm>
6 #include <iostream>
7 
8 #include "tools/gn/args.h"
9 #include "tools/gn/commands.h"
10 #include "tools/gn/err.h"
11 #include "tools/gn/file_template.h"
12 #include "tools/gn/functions.h"
13 #include "tools/gn/input_conversion.h"
14 #include "tools/gn/pattern.h"
15 #include "tools/gn/setup.h"
16 #include "tools/gn/standard_out.h"
17 #include "tools/gn/variables.h"
18 
19 namespace commands {
20 
21 namespace {
22 
PrintToplevelHelp()23 void PrintToplevelHelp() {
24   OutputString("Commands (type \"gn help <command>\" for more details):\n");
25 
26   const commands::CommandInfoMap& command_map = commands::GetCommands();
27   for (commands::CommandInfoMap::const_iterator i = command_map.begin();
28        i != command_map.end(); ++i)
29     PrintShortHelp(i->second.help_short);
30 
31   OutputString(
32       "\n"
33       "  When run with no arguments \"gn gen\" is assumed.\n"
34       "\n"
35       "Common switches:\n");
36   PrintShortHelp(
37       "--args: Specifies build args overrides. See \"gn help buildargs\".");
38   PrintShortHelp(
39       "--no-exec: Skips exec_script calls (for performance testing).");
40   PrintShortHelp(
41       "-q: Quiet mode, don't print anything on success.");
42   PrintShortHelp(
43       "--output: Directory for build output (relative to source root).");
44   PrintShortHelp(
45       "--root: Specifies source root (overrides .gn file).");
46   PrintShortHelp(
47       "--secondary: Specifies secondary source root (overrides .gn file).");
48   PrintShortHelp(
49       "--time: Outputs a summary of how long everything took.");
50   PrintShortHelp(
51       "--tracelog: Writes a Chrome-compatible trace log to the given file.");
52   PrintShortHelp(
53       "-v: Verbose mode, print lots of logging.");
54   PrintShortHelp(
55       "--version: Print the GN binary's version and exit.");
56 
57   // Functions.
58   OutputString("\nBuildfile functions (type \"gn help <function>\" for more "
59                "details):\n");
60   const functions::FunctionInfoMap& function_map = functions::GetFunctions();
61   std::vector<std::string> sorted_functions;
62   for (functions::FunctionInfoMap::const_iterator i = function_map.begin();
63        i != function_map.end(); ++i)
64     sorted_functions.push_back(i->first.as_string());
65   std::sort(sorted_functions.begin(), sorted_functions.end());
66   for (size_t i = 0; i < sorted_functions.size(); i++)
67     OutputString("  " + sorted_functions[i] + "\n", DECORATION_YELLOW);
68 
69   // Built-in variables.
70   OutputString("\nBuilt-in predefined variables (type \"gn help <variable>\" "
71                "for more details):\n");
72   const variables::VariableInfoMap& builtin_vars =
73       variables::GetBuiltinVariables();
74   for (variables::VariableInfoMap::const_iterator i = builtin_vars.begin();
75        i != builtin_vars.end(); ++i)
76     PrintShortHelp(i->second.help_short);
77 
78   // Target variables.
79   OutputString("\nVariables you set in targets (type \"gn help <variable>\" "
80                "for more details):\n");
81   const variables::VariableInfoMap& target_vars =
82       variables::GetTargetVariables();
83   for (variables::VariableInfoMap::const_iterator i = target_vars.begin();
84        i != target_vars.end(); ++i)
85     PrintShortHelp(i->second.help_short);
86 
87   OutputString("\nOther help topics:\n");
88   PrintShortHelp("buildargs: How build arguments work.");
89   PrintShortHelp("dotfile: Info about the toplevel .gn file.");
90   PrintShortHelp(
91       "input_conversion: Processing input from exec_script and read_file.");
92   PrintShortHelp("patterns: How to use patterns.");
93   PrintShortHelp("source_expansion: Map sources to outputs for scripts.");
94 }
95 
96 }  // namespace
97 
98 const char kHelp[] = "help";
99 const char kHelp_HelpShort[] =
100     "help: Does what you think.";
101 const char kHelp_Help[] =
102     "gn help <anything>\n"
103     "  Yo dawg, I heard you like help on your help so I put help on the help\n"
104     "  in the help.\n";
105 
RunHelp(const std::vector<std::string> & args)106 int RunHelp(const std::vector<std::string>& args) {
107   if (args.size() == 0) {
108     PrintToplevelHelp();
109     return 0;
110   }
111 
112   // Check commands.
113   const commands::CommandInfoMap& command_map = commands::GetCommands();
114   commands::CommandInfoMap::const_iterator found_command =
115       command_map.find(args[0]);
116   if (found_command != command_map.end()) {
117     PrintLongHelp(found_command->second.help);
118     return 0;
119   }
120 
121   // Check functions.
122   const functions::FunctionInfoMap& function_map = functions::GetFunctions();
123   functions::FunctionInfoMap::const_iterator found_function =
124       function_map.find(args[0]);
125   if (found_function != function_map.end()) {
126     PrintLongHelp(found_function->second.help);
127     return 0;
128   }
129 
130   // Builtin variables.
131   const variables::VariableInfoMap& builtin_vars =
132       variables::GetBuiltinVariables();
133   variables::VariableInfoMap::const_iterator found_builtin_var =
134       builtin_vars.find(args[0]);
135   if (found_builtin_var != builtin_vars.end()) {
136     PrintLongHelp(found_builtin_var->second.help);
137     return 0;
138   }
139 
140   // Target variables.
141   const variables::VariableInfoMap& target_vars =
142       variables::GetTargetVariables();
143   variables::VariableInfoMap::const_iterator found_target_var =
144       target_vars.find(args[0]);
145   if (found_target_var != target_vars.end()) {
146     PrintLongHelp(found_target_var->second.help);
147     return 0;
148   }
149 
150   // Random other topics.
151   if (args[0] == "buildargs") {
152     PrintLongHelp(kBuildArgs_Help);
153     return 0;
154   }
155   if (args[0] == "dotfile") {
156     PrintLongHelp(kDotfile_Help);
157     return 0;
158   }
159   if (args[0] == "input_conversion") {
160     PrintLongHelp(kInputConversion_Help);
161     return 0;
162   }
163   if (args[0] == "patterns") {
164     PrintLongHelp(kPattern_Help);
165     return 0;
166   }
167   if (args[0] == "source_expansion") {
168     PrintLongHelp(kSourceExpansion_Help);
169     return 0;
170   }
171 
172   // No help on this.
173   Err(Location(), "No help on \"" + args[0] + "\".").PrintToStdout();
174   RunHelp(std::vector<std::string>());
175   return 1;
176 }
177 
178 }  // namespace commands
179