X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Finstall.cpp;h=ca32348f324e02d289159d0030037ab0edb84b31;hb=b5ad62c2c4c7eeadd881e3f157bde96e4dd2cc0e;hp=658a6fb84a0bc5bd867f8311168406008dc25189;hpb=921fc49488a68442fb8794e1a0284a3bf1e7b91b;p=builder.git diff --git a/source/install.cpp b/source/install.cpp index 658a6fb..ca32348 100644 --- a/source/install.cpp +++ b/source/install.cpp @@ -1,15 +1,18 @@ #include #include "builder.h" #include "copy.h" +#include "executable.h" #include "header.h" #include "install.h" #include "package.h" +#include "pkgconfig.h" +#include "staticlibrary.h" using namespace std; using namespace Msp; -Install::Install(Builder &b, const Package &p, Target &tgt, const string &n): - Target(b, &p, n) +Install::Install(Builder &b, const Package &p, Target &tgt): + Target(b, &p, generate_target_name(tgt)) { buildable=true; add_depend(&tgt); @@ -33,3 +36,32 @@ Action *Install::build() { return Target::build(new Copy(builder, *package, depends.front()->get_name(), name)); } + +string Install::generate_target_name(const Target &tgt) +{ + Path::Path base=tgt.get_package()->get_prefix(); + string tgtname=tgt.get_name().substr(tgt.get_name().rfind('/')+1); + + string mid; + if(const Header *hdr=dynamic_cast(&tgt)) + mid="include/"+hdr->get_component()->get_install_headers(); + else if(const Executable *exe=dynamic_cast(&tgt)) + { + const Component &comp=exe->get_component(); + if(comp.get_type()==Component::LIBRARY) + mid="lib"; + else if(comp.get_type()==Component::PROGRAM) + mid="bin"; + else if(comp.get_type()==Component::MODULE) + mid="lib/"+tgt.get_package()->get_name(); + } + else if(dynamic_cast(&tgt)) + mid="lib"; + else if(dynamic_cast(&tgt)) + mid="lib/pkgconfig"; + + if(mid.empty()) + throw InvalidParameterValue("Don't know where to install "+tgtname); + + return (base/mid/tgtname).str(); +}