]> git.tdb.fi Git - builder.git/blobdiff - source/sharedlibrary.cpp
Refactor transitive dependencies to work on all targets
[builder.git] / source / sharedlibrary.cpp
diff --git a/source/sharedlibrary.cpp b/source/sharedlibrary.cpp
deleted file mode 100644 (file)
index 56f9b32..0000000
+++ /dev/null
@@ -1,50 +0,0 @@
-#include <msp/fs/utils.h>
-#include <msp/strings/format.h>
-#include "builder.h"
-#include "component.h"
-#include "sharedlibrary.h"
-#include "sourcepackage.h"
-
-using namespace std;
-using namespace Msp;
-
-SharedLibrary::SharedLibrary(Builder &b, const Msp::FS::Path &p):
-       Binary(b, p)
-{
-       libname = FS::basepart(FS::basename(path));
-       if(!libname.compare(0, 3, "lib"))
-               libname = libname.substr(3);
-}
-
-SharedLibrary::SharedLibrary(Builder &b, const Component &c, const list<ObjectFile *> &objs):
-       Binary(b, c, generate_filename(c), objs),
-       libname(c.get_name())
-{
-       install_location = "lib";
-       if(component->get_type()==Component::MODULE)
-               install_location /= package->get_name();
-
-       const string &version = component->get_package().get_interface_version();
-       if(!version.empty())
-       {
-               const Architecture &arch = builder.get_current_arch();
-               const Pattern &pattern = arch.get_shared_library_patterns().front();
-               if(arch.get_system()=="windows")
-                       soname = pattern.apply(format("%s-%s", component->get_name(), version));
-               else
-                       soname = format("%s.%s", pattern.apply(component->get_name()), version);
-
-               install_filename = soname;
-       }
-}
-
-string SharedLibrary::generate_filename(const Component &comp)
-{
-       if(comp.get_type()==Component::MODULE)
-               return comp.get_name()+".m";
-       else
-       {
-               const Architecture &arch = comp.get_package().get_builder().get_current_arch();
-               return arch.get_shared_library_patterns().front().apply(comp.get_name());
-       }
-}