]> git.tdb.fi Git - builder.git/blobdiff - source/tool.cpp
Make targets depend on their tools
[builder.git] / source / tool.cpp
index e1858493add33c2624f78cd0585235d7603c03a1..a2c61bf1f24ffa9cd48f4add29e0501c64f47343 100644 (file)
@@ -5,12 +5,18 @@ using namespace std;
 
 Tool::Tool(Builder &b, const string &t):
        builder(b),
-       tag(t)
+       tag(t),
+       executable(0)
 { }
 
-bool Tool::accepts_suffix(const string &suffix) const
+bool Tool::accepts_suffix(const string &suffix, bool aux) const
 {
-       return find(input_suffixes.begin(), input_suffixes.end(), suffix)!=input_suffixes.end();
+       if(find(input_suffixes.begin(), input_suffixes.end(), suffix)!=input_suffixes.end())
+               return true;
+       else if(aux)
+               return find(aux_suffixes.begin(), aux_suffixes.end(), suffix)!=aux_suffixes.end();
+       else
+               return false;
 }
 
 Target *Tool::create_target(Target &source, const string &arg) const
@@ -19,3 +25,9 @@ Target *Tool::create_target(Target &source, const string &arg) const
        sources.push_back(&source);
        return create_target(sources, arg);
 }
+
+
+SubTool::SubTool(Tool &p):
+       Tool(p),
+       parent(p)
+{ }