X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fvcxprojectgenerator.cpp;h=bafa8d94f42ee629d84454171be34514e4b603e5;hb=d1eb133ab529cdae131be7b150209f03189248f3;hp=93c0eb49f7a6076608dd0cde22846492b94fbe36;hpb=aa053d637e8259755af7d2e4b510a242f4d29c7b;p=builder.git diff --git a/source/vcxprojectgenerator.cpp b/source/vcxprojectgenerator.cpp index 93c0eb4..bafa8d9 100644 --- a/source/vcxprojectgenerator.cpp +++ b/source/vcxprojectgenerator.cpp @@ -5,6 +5,7 @@ #include "builder.h" #include "csourcefile.h" #include "executable.h" +#include "internaltask.h" #include "sourcepackage.h" #include "vcxprojectfile.h" #include "vcxprojectgenerator.h" @@ -12,10 +13,6 @@ using namespace std; using namespace Msp; -VcxProjectGenerator::VcxProjectGenerator(Builder &b): - Tool(b, "VCXG") -{ } - Target *VcxProjectGenerator::create_target(const vector &, const string &) { throw logic_error("Not implemented"); @@ -24,21 +21,15 @@ Target *VcxProjectGenerator::create_target(const vector &, const strin Task *VcxProjectGenerator::run(const Target &target) const { const VcxProjectFile &project = dynamic_cast(target); - Worker *worker = new Worker(project); - return new InternalTask(worker); + return new InternalTask([&project]{ return _run(project); }); } - -VcxProjectGenerator::Worker::Worker(const VcxProjectFile &t): - target(t) -{ } - -void VcxProjectGenerator::Worker::main() +bool VcxProjectGenerator::_run(const VcxProjectFile &project) { - const SourcePackage &spkg = *target.get_package(); + const SourcePackage &spkg = *project.get_package(); Builder &builder = spkg.get_builder(); - IO::BufferedFile out(target.get_path().str(), IO::M_WRITE); + IO::BufferedFile out(project.get_path().str(), IO::M_WRITE); IO::print(out, "\n"); IO::print(out, "\t\n"); @@ -57,7 +48,7 @@ void VcxProjectGenerator::Worker::main() IO::print(out, "\t\n"); IO::print(out, "\t\t15.0\n"); IO::print(out, "\t\tMakeFileProj\n"); - IO::print(out, "\t\t{%s}\n", target.get_guid()); + IO::print(out, "\t\t{%s}\n", project.get_guid()); IO::print(out, "\t\n"); IO::print(out, "\t\n"); @@ -142,5 +133,5 @@ void VcxProjectGenerator::Worker::main() IO::print(out, "\t\n"); IO::print(out, "\n"); - status = Task::SUCCESS; + return true; }