]> git.tdb.fi Git - builder.git/blobdiff - source/tool.cpp
Move the bpk files into a subdirectory and install them
[builder.git] / source / tool.cpp
index 65a45041286e6a054649461bd65770cccc614d69..3aa2db3c713716ba7d90bcafa715afe368a37302 100644 (file)
@@ -23,6 +23,17 @@ Tool::Tool(Builder &b, const Architecture &a, const string &t):
        prepared(false)
 { }
 
+void Tool::set_command(const string &cmd, bool cross)
+{
+       if(cmd.empty())
+               throw invalid_argument("Tool::set_command");
+
+       if(cross && architecture->is_cross() && !FS::Path(cmd).is_absolute())
+               command = format("%s-%s", architecture->get_cross_prefix(), cmd);
+       else
+               command = cmd;
+}
+
 bool Tool::accepts_suffix(const string &suffix, bool aux) const
 {
        if(find(input_suffixes.begin(), input_suffixes.end(), suffix)!=input_suffixes.end())
@@ -47,16 +58,12 @@ void Tool::prepare()
 
        prepared = true;
        do_prepare();
-}
-
-void Tool::set_executable(const string &command, bool cross)
-{
-       if(cross && architecture->is_cross())
-               return set_executable(format("%s-%s", architecture->get_cross_prefix(), command), false);
-
-       executable = builder.get_vfs().find_binary(command);
-       if(!executable)
-               builder.problem(string(), format("Can't find executable %s for tool %s", command, tag));
+       if(!executable && !command.empty())
+       {
+               executable = builder.get_vfs().find_binary(command);
+               if(!executable)
+                       problems.push_back(format("Can't find executable %s", command));
+       }
 }