]> git.tdb.fi Git - builder.git/blobdiff - source/install.cpp
Move the logic for creating targets into the Component class
[builder.git] / source / install.cpp
index 658a6fb84a0bc5bd867f8311168406008dc25189..ca32348f324e02d289159d0030037ab0edb84b31 100644 (file)
@@ -1,15 +1,18 @@
 #include <msp/path/utils.h>
 #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<const Header *>(&tgt))
+               mid="include/"+hdr->get_component()->get_install_headers();
+       else if(const Executable *exe=dynamic_cast<const Executable *>(&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<const StaticLibrary *>(&tgt))
+               mid="lib";
+       else if(dynamic_cast<const PkgConfig *>(&tgt))
+               mid="lib/pkgconfig";
+
+       if(mid.empty())
+               throw InvalidParameterValue("Don't know where to install "+tgtname);
+
+       return (base/mid/tgtname).str();
+}