Add depfile support to build command with multiple outputs (Fixes: #61)
authorQingning Huo <qingninghuo@gmail.com>
Tue, 6 Sep 2011 19:46:32 +0000 (20:46 +0100)
committerQingning Huo <qingninghuo@gmail.com>
Tue, 6 Sep 2011 19:46:32 +0000 (20:46 +0100)
parsers.cpp: allow depfile used at build command with multiple outputs.
graph.cpp: allow depfile used at build command with multiple outputs.
parsers_test.cpp: make the test pass.

As before, the depfile itself can only mention one target, which must
be the first of a build command with multiple outpus.

[There is really no need to mention all the output in the depfile,
because all targets should depend on exactly the same files anyway,
because these targets are built by a single build command.]

src/graph.cc
src/parsers.cc
src/parsers_test.cc

index 9b5f10b4837cc16bb4800e648feae0892e274d41..82716aaeecb9a01c122c512e61d218c7c7967771 100644 (file)
@@ -150,10 +150,6 @@ bool Edge::LoadDepFile(State* state, DiskInterface* disk_interface,
   }
 
   // Check that this depfile matches our output.
-  if (outputs_.size() != 1) {
-    *err = "expected only one output";
-    return false;
-  }
   if (outputs_[0]->file_->path_ != makefile.out_) {
     *err = "expected makefile to mention '" + outputs_[0]->file_->path_ + "', "
            "got '" + makefile.out_ + "'";
index 7f587a6043f69e4f812f23337d270fce2351becb..35790b2bda75578a98537244fc23669f1c493604 100644 (file)
@@ -471,13 +471,6 @@ bool ManifestParser::ParseEdge(string* err) {
   if (!rule)
     return tokenizer_.Error("unknown build rule '" + rule_name + "'", err);
 
-  if (!rule->depfile_.empty()) {
-    if (outs.size() > 1) {
-      return tokenizer_.Error("dependency files only work with single-output "
-                           "rules", err);
-    }
-  }
-
   for (;;) {
     string in;
     if (!tokenizer_.ReadIdent(&in))
index 1ac5990498da2cbccefe44e18455baea8e0acce2..12f09b019d048269cf35929fe58cca0123363727 100644 (file)
@@ -316,11 +316,10 @@ TEST_F(ParserTest, Errors) {
     State state;
     ManifestParser parser(&state, NULL);
     string err;
-    EXPECT_FALSE(parser.Parse("rule cc\n  command = foo\n  depfile = bar\n"
+    EXPECT_TRUE(parser.Parse("rule cc\n  command = foo\n  depfile = bar\n"
                               "build a.o b.o: cc c.cc\n",
                               &err));
-    EXPECT_EQ("line 4, col 16: dependency files only work with "
-              "single-output rules", err);
+    EXPECT_EQ("", err);
   }
 
   {