X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Finstall.cpp;h=2cdd1aa1a4a959c6f34f754a273a8b9ffbf5497b;hb=654de39b62a9a58fd8e1b5a557361d628345788b;hp=658a6fb84a0bc5bd867f8311168406008dc25189;hpb=b1a6e6dcdd7e0da272ab0ebbed4e295f83f1165a;p=builder.git diff --git a/source/install.cpp b/source/install.cpp index 658a6fb..2cdd1aa 100644 --- a/source/install.cpp +++ b/source/install.cpp @@ -1,15 +1,25 @@ +/* $Id$ + +This file is part of builder +Copyright © 2006-2007 Mikko Rasa, Mikkosoft Productions +Distributed under the LGPL +*/ + #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 SourcePackage &p, Target &tgt): + Target(b, &p, generate_target_name(tgt)) { buildable=true; add_depend(&tgt); @@ -33,3 +43,34 @@ Action *Install::build() { return Target::build(new Copy(builder, *package, depends.front()->get_name(), name)); } + +string Install::generate_target_name(const Target &tgt) +{ + const SourcePackage *spkg=dynamic_cast(tgt.get_package()); + + Path::Path base=spkg->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(); +}