2 #include <msp/fs/utils.h>
3 #include <msp/strings/format.h>
6 #include "datacollection.h"
9 #include "datatransform.h"
10 #include "externaltask.h"
11 #include "sourcepackage.h"
16 DataTool::DataTool(Builder &b):
19 input_suffixes.push_back(".mdt");
22 Target *DataTool::create_source(const Component &comp, const FS::Path &path) const
24 return new DataTransform(builder, comp, path);
27 Target *DataTool::create_target(const list<Target *> &sources, const string &arg)
32 throw invalid_argument("DataTool::create_target");
33 DataTransform &source = dynamic_cast<DataTransform &>(*sources.front());
34 DataCollection *coll = new DataCollection(builder, *source.get_component(), source);
35 coll->set_tool(*this);
40 list<FileTarget *> files;
41 for(list<Target *>::const_iterator i=sources.begin(); i!=sources.end(); ++i)
42 files.push_back(&dynamic_cast<FileTarget &>(**i));
43 DataPack *pack = new DataPack(builder, *files.front()->get_component(), files);
44 pack->set_tool(*this);
48 throw invalid_argument("DataTool::create_target");
51 void DataTool::do_prepare()
53 executable = builder.get_vfs().find_binary("mspdatatool");
55 builder.problem(string(), format("Can't find executable mspdatatool for tool %s", tag));
58 Task *DataTool::run(const Target &tgt) const
60 const Component &comp = *tgt.get_component();
61 FS::Path work_dir = comp.get_package().get_source_directory();
64 argv.push_back(executable->get_path().str());
67 argv.push_back(FS::relative(dynamic_cast<const FileTarget &>(tgt).get_path(), work_dir).str());
69 const BuildInfo &binfo = comp.get_build_info();
79 if(const DataCollection *coll = dynamic_cast<const DataCollection *>(&tgt))
82 argv.push_back(FS::relative(coll->get_source().get_path(), work_dir).str());
84 else if(const DataPack *pack = dynamic_cast<const DataPack *>(&tgt))
87 const DataPack::FileList &files = pack->get_files();
88 for(DataPack::FileList::const_iterator i=files.begin(); i!=files.end(); ++i)
89 argv.push_back(FS::relative((*i)->get_path(), work_dir).str());
92 return new ExternalTask(argv, work_dir);