diff options
author | Evan Martin <martine@danga.com> | 2011-02-06 17:12:39 (GMT) |
---|---|---|
committer | Evan Martin <martine@danga.com> | 2011-02-06 17:12:39 (GMT) |
commit | e6a3ed4c7f7e1295de185dccdd0df22d3a90af12 (patch) | |
tree | 4014ecbb7250ce3825365122347184bb04b105b5 | |
parent | 4caf59af8d2b927922c796ac6222b0dbd8bbf182 (diff) | |
download | Ninja-e6a3ed4c7f7e1295de185dccdd0df22d3a90af12.zip Ninja-e6a3ed4c7f7e1295de185dccdd0df22d3a90af12.tar.gz Ninja-e6a3ed4c7f7e1295de185dccdd0df22d3a90af12.tar.bz2 |
create builddir on start; fixes bootstrap
-rw-r--r-- | src/ninja.cc | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/src/ninja.cc b/src/ninja.cc index 39cbfed..41ee1ff 100644 --- a/src/ninja.cc +++ b/src/ninja.cc @@ -1,9 +1,12 @@ #include "ninja.h" +#include <errno.h> #include <getopt.h> #include <limits.h> #include <stdio.h> #include <string.h> +#include <sys/stat.h> +#include <sys/types.h> #include "build.h" #include "build_log.h" @@ -206,7 +209,16 @@ int main(int argc, char** argv) { const string build_dir = state.bindings_.LookupVariable("builddir"); const char* kLogPath = ".ninja_log"; - string log_path = build_dir.empty() ? kLogPath : build_dir + "/" + kLogPath; + string log_path = kLogPath; + if (!build_dir.empty()) { + if (mkdir(build_dir.c_str(), 0777) < 0 && errno != EEXIST) { + fprintf(stderr, "Error creating build directory %s: %s\n", + build_dir.c_str(), strerror(errno)); + return 1; + } + log_path = build_dir + "/" + kLogPath; + } + if (!build_log.Load(log_path.c_str(), &err)) { fprintf(stderr, "error loading build log %s: %s\n", log_path.c_str(), err.c_str()); |