diff options
author | Tony Chang <tony@chromium.org> | 2013-07-26 21:24:52 (GMT) |
---|---|---|
committer | Tony Chang <tony@chromium.org> | 2013-07-26 21:24:52 (GMT) |
commit | 66822baa2b1a58e40dc886158099f1a691b095a2 (patch) | |
tree | ce7e1e31db21fccb1a1351a249bf4a49961577e5 /src/ninja.cc | |
parent | 54b3ebd641f9d7500e9950e4c74297c00a32a6d6 (diff) | |
download | Ninja-66822baa2b1a58e40dc886158099f1a691b095a2.zip Ninja-66822baa2b1a58e40dc886158099f1a691b095a2.tar.gz Ninja-66822baa2b1a58e40dc886158099f1a691b095a2.tar.bz2 |
Fix the browse tool.
ReadFlags was altering argv in real_main causing us
to pass the wrong value into the NinjaMain constructor.
Fix this by storing the ninja command before real_main
runs.
Diffstat (limited to 'src/ninja.cc')
-rw-r--r-- | src/ninja.cc | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/src/ninja.cc b/src/ninja.cc index 80d68e7..0586bdc 100644 --- a/src/ninja.cc +++ b/src/ninja.cc @@ -1006,6 +1006,7 @@ int real_main(int argc, char** argv) { options.input_file = "build.ninja"; setvbuf(stdout, NULL, _IOLBF, BUFSIZ); + const char* ninja_command = argv[0]; int exit_code = ReadFlags(&argc, &argv, &options, &config); if (exit_code >= 0) @@ -1014,7 +1015,7 @@ int real_main(int argc, char** argv) { if (options.tool && options.tool->when == Tool::RUN_AFTER_FLAGS) { // None of the RUN_AFTER_FLAGS actually use a NinjaMain, but it's needed // by other tools. - NinjaMain ninja(argv[0], config); + NinjaMain ninja(ninja_command, config); return (ninja.*options.tool->func)(argc, argv); } @@ -1034,7 +1035,7 @@ int real_main(int argc, char** argv) { // The build can take up to 2 passes: one to rebuild the manifest, then // another to build the desired target. for (int cycle = 0; cycle < 2; ++cycle) { - NinjaMain ninja(argv[0], config); + NinjaMain ninja(ninja_command, config); RealFileReader file_reader; ManifestParser parser(&ninja.state_, &file_reader); |