summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorEvan Martin <martine@danga.com>2011-03-05 21:43:02 (GMT)
committerEvan Martin <martine@danga.com>2011-03-05 21:43:02 (GMT)
commit80fda9821765d2139a080a527ab66fcb9e272722 (patch)
tree978b48313aa178e28c3ff59dc777c5aca64f1e47 /src
parentad118104f0892e53a5bdabaf1ffdcd597bf1b476 (diff)
downloadNinja-80fda9821765d2139a080a527ab66fcb9e272722.zip
Ninja-80fda9821765d2139a080a527ab66fcb9e272722.tar.gz
Ninja-80fda9821765d2139a080a527ab66fcb9e272722.tar.bz2
factor browse out into its own file
Diffstat (limited to 'src')
-rw-r--r--src/browse.cc53
-rw-r--r--src/browse.h25
-rw-r--r--src/ninja.cc34
3 files changed, 81 insertions, 31 deletions
diff --git a/src/browse.cc b/src/browse.cc
new file mode 100644
index 0000000..4507e0d
--- /dev/null
+++ b/src/browse.cc
@@ -0,0 +1,53 @@
+// Copyright 2011 Google Inc. All Rights Reserved.
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+#include "browse.h"
+
+#include <stdio.h>
+
+#include "ninja.h"
+
+// Import browse.py as binary data.
+asm(
+".data\n"
+"browse_data_begin:\n"
+".incbin \"src/browse.py\"\n"
+"browse_data_end:\n"
+);
+// Declare the symbols defined above.
+extern const char browse_data_begin[];
+extern const char browse_data_end[];
+
+void RunBrowsePython(State* state, const char* ninja_command) {
+ // Create a temporary file, dump the Python code into it, and
+ // delete the file, keeping our open handle to it.
+ char tmpl[] = "browsepy-XXXXXX";
+ int fd = mkstemp(tmpl);
+ unlink(tmpl);
+ const int browse_data_len = browse_data_end - browse_data_begin;
+ int len = write(fd, browse_data_begin, browse_data_len);
+ if (len < browse_data_len) {
+ perror("write");
+ return;
+ }
+
+ // exec Python, telling it to use our script file.
+ const char* command[] = {
+ "python", "/proc/self/fd/3", ninja_command, NULL
+ };
+ execvp(command[0], (char**)command);
+
+ // If we get here, the exec failed.
+ printf("ERROR: Failed to spawn python for graph browsing, aborting.\n");
+}
diff --git a/src/browse.h b/src/browse.h
new file mode 100644
index 0000000..46249a7
--- /dev/null
+++ b/src/browse.h
@@ -0,0 +1,25 @@
+// Copyright 2011 Google Inc. All Rights Reserved.
+//
+// Licensed under the Apache License, Version 2.0 (the "License");
+// you may not use this file except in compliance with the License.
+// You may obtain a copy of the License at
+//
+// http://www.apache.org/licenses/LICENSE-2.0
+//
+// Unless required by applicable law or agreed to in writing, software
+// distributed under the License is distributed on an "AS IS" BASIS,
+// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+// See the License for the specific language governing permissions and
+// limitations under the License.
+
+#ifndef NINJA_BROWSE_H_
+#define NINJA_BROWSE_H_
+
+class State;
+
+// Run in "browse" mode, which execs a Python webserver.
+// |command| is the command used to invoke ninja.
+// This function does not return if it runs successfully.
+void RunBrowsePython(State* state, const char* ninja_command);
+
+#endif // NINJA_BROWSE_H_
diff --git a/src/ninja.cc b/src/ninja.cc
index 27def2b..8c46833 100644
--- a/src/ninja.cc
+++ b/src/ninja.cc
@@ -28,23 +28,13 @@
#include <sys/sysinfo.h>
#endif
+#include "browse.h"
#include "build.h"
#include "build_log.h"
#include "parsers.h"
#include "graphviz.h"
-// Import browse.py as binary data.
-asm(
-".data\n"
-"browse_data_begin:\n"
-".incbin \"src/browse.py\"\n"
-"browse_data_end:\n"
-);
-// Declare the symbols defined above.
-extern const char browse_data_begin[];
-extern const char browse_data_end[];
-
option options[] = {
{ "help", no_argument, NULL, 'h' },
{ }
@@ -137,26 +127,8 @@ int CmdQuery(State* state, int argc, char* argv[]) {
}
int CmdBrowse(State* state, int argc, char* argv[]) {
- // Create a temporary file, dump the Python code into it, and
- // delete the file, keeping our open handle to it.
- char tmpl[] = "browsepy-XXXXXX";
- int fd = mkstemp(tmpl);
- unlink(tmpl);
- const int browse_data_len = browse_data_end - browse_data_begin;
- int len = write(fd, browse_data_begin, browse_data_len);
- if (len < browse_data_len) {
- perror("write");
- return 1;
- }
-
- // exec Python, telling it to use our script file.
- const char* command[] = {
- "python", "/proc/self/fd/3", argv[0], NULL
- };
- execvp(command[0], (char**)command);
-
- // If we get here, the exec failed.
- printf("ERROR: Failed to spawn python for graph browsing, aborting.\n");
+ RunBrowsePython(state, argv[0]);
+ // If we get here, the browse failed.
return 1;
}