Builder &builder;
const Architecture *architecture;
std::string tag;
+ std::string command;
FileTarget *executable;
SuffixList input_suffixes;
SuffixList aux_suffixes;
const std::string &get_tag() const { return tag; }
+ /** Returns the architecture this tool build for. May return null if the
+ tool is architecture-agnostic. */
+ const Architecture *get_architecture() const { return architecture; }
+
+ /** Overrides the command used by the tool. The new command should accept
+ the same command line arguments. Only works on tools that use an external
+ command. If cross is true and the architecture is not native, a cross
+ prefix is added to the command. May have no effect after prepare() has been
+ called. */
+ void set_command(const std::string &cmd, bool cross = false);
+
/** Returns a target for the tool's own executable. If the tool does not
- use an external program, returns null. */
+ use an external program, returns null. The tool must be prepared first. */
FileTarget *get_executable() const { return executable; }
/// Returns a list of suffixes that can be processed with this tool.
protected:
virtual void do_prepare() { }
- /** Locates an executable for the tool from the VFS. If it isn't found, a
- problem is reported. If cross is true and the architecture is not native,
- a cross prefix is added to the command. */
- void set_executable(const std::string &command, bool cross = false);
-
public:
const std::list<std::string> &get_problems() const { return problems; }