move tools into a flag
authorEvan Martin <martine@danga.com>
Fri, 28 Jan 2011 17:50:58 +0000 (09:50 -0800)
committerEvan Martin <martine@danga.com>
Fri, 28 Jan 2011 17:50:58 +0000 (09:50 -0800)
build.ninja
src/browse.py
src/ninja.cc

index 2ab221181f6dafe8b52103e4c8d895ff15b8c05b..a4442646e7515a002484257bf020e9f3f174a382 100644 (file)
@@ -59,7 +59,7 @@ build ninja_test: link $builddir/build_test.o $builddir/build_log_test.o \
 
 # Generate a graph using the -g flag.
 rule gendot
-  command = ./ninja -g all > $out
+  command = ./ninja -t graph all > $out
 rule gengraph
   command = dot -Tpng $in > $out
 
index d326af3d6657d28e6475f3262017513bc10259d1..dd7b5dc414af19eda601d5bca554b5d5897d5c03 100755 (executable)
@@ -83,7 +83,8 @@ tt {
     print '</td></tr></table>'
 
 def ninja_dump(target):
-    proc = subprocess.Popen(['./ninja', '-q', target], stdout=subprocess.PIPE)
+    proc = subprocess.Popen(['./ninja', '-t', 'query', target],
+                            stdout=subprocess.PIPE)
     return proc.communicate()[0]
 
 class RequestHandler(BaseHTTPServer.BaseHTTPRequestHandler):
index dc878d0784464a2738ec487417d8ef3973cb722a..6100357977ff52beb196d42028ba9a4665eb9706 100644 (file)
@@ -31,12 +31,14 @@ void usage() {
 "usage: ninja [options] target\n"
 "\n"
 "options:\n"
-"  -g       output graphviz dot file for targets and exit\n"
 "  -i FILE  specify input build file [default=build.ninja]\n"
 "  -n       dry run (don't run commands but pretend they succeeded)\n"
 "  -v       show all command lines\n"
-"  -q       show inputs/outputs of target (query mode)\n"
-"  -b       browse dependency graph of target in a web browser\n"
+"\n"
+"  -t TOOL  run a subtool.  tools are:\n"
+"             browse  browse dependency graph in a web browser\n"
+"             graph   output graphviz dot file for targets\n"
+"             query   show inputs/outputs for a path\n"
           );
 }
 
@@ -110,16 +112,11 @@ int CmdBrowse(State* state, int argc, char* argv[]) {
 int main(int argc, char** argv) {
   BuildConfig config;
   const char* input_file = "build.ninja";
-  bool graph = false;
-  bool query = false;
-  bool browse = false;
+  string tool;
 
   int opt;
-  while ((opt = getopt_long(argc, argv, "bghi:nvq", options, NULL)) != -1) {
+  while ((opt = getopt_long(argc, argv, "hi:nt:v", options, NULL)) != -1) {
     switch (opt) {
-      case 'g':
-        graph = true;
-        break;
       case 'i':
         input_file = optarg;
         break;
@@ -129,11 +126,8 @@ int main(int argc, char** argv) {
       case 'v':
         config.verbosity = BuildConfig::VERBOSE;
         break;
-      case 'q':
-        query = true;
-        break;
-      case 'b':
-        browse = true;
+      case 't':
+        tool = optarg;
         break;
       case 'h':
       default:
@@ -164,12 +158,15 @@ int main(int argc, char** argv) {
     return 1;
   }
 
-  if (graph)
-    return CmdGraph(&state, argc, argv);
-  if (query)
-    return CmdQuery(&state, argc, argv);
-  if (browse)
-    return CmdBrowse(&state, argc, argv);
+  if (!tool.empty()) {
+    if (tool == "graph")
+      return CmdGraph(&state, argc, argv);
+    if (tool == "query")
+      return CmdQuery(&state, argc, argv);
+    if (tool == "browse")
+      return CmdBrowse(&state, argc, argv);
+    fprintf(stderr, "unknown tool '%s'\n", tool.c_str());
+  }
 
   BuildLog build_log;
   build_log.SetConfig(&config);