using namespace Msp;
SharedLibrary::SharedLibrary(Builder &b, const Msp::FS::Path &p):
- Binary(b, p)
+ Binary(b, p),
+ import_lib(0)
{
libname = FS::basepart(FS::basename(path));
if(!libname.compare(0, 3, "lib"))
SharedLibrary::SharedLibrary(Builder &b, const Component &c, const list<ObjectFile *> &objs):
Binary(b, c, generate_filename(c), objs),
- libname(c.get_name())
+ libname(c.get_name()),
+ import_lib(0)
{
- install_location = "lib";
+ if(builder.get_current_arch().get_system()=="windows")
+ install_location = "bin";
+ else
+ install_location = "lib";
if(component->get_type()==Component::MODULE)
install_location /= package->get_name();
- const string &version = component->get_package().get_version();
+ const string &version = component->get_package().get_interface_version();
if(!version.empty())
{
- string::size_type i = 0;
- for(unsigned dots=0; i<version.size(); ++i)
- if(version[i]=='.' && ++dots>=2)
- break;
-
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.substr(0, i)));
+ soname = pattern.apply(format("%s-%s", component->get_name(), version));
+ else if(arch.get_system()=="darwin")
+ {
+ string filename = pattern.apply(component->get_name());
+ string base = FS::basepart(filename);
+ string ext = FS::extpart(filename);
+ soname = format("%s.%s%s", base, version, ext);
+ }
else
- soname = format("%s.%s", pattern.apply(component->get_name()), version.substr(0, i));
+ soname = format("%s.%s", pattern.apply(component->get_name()), version);
install_filename = soname;
}
return arch.get_shared_library_patterns().front().apply(comp.get_name());
}
}
+
+void SharedLibrary::set_import_library(ImportLibrary *imp)
+{
+ import_lib = imp;
+}