- FileTarget(b, &c.get_package(), generate_target_path(c)),
- Binary(b, c, objs),
- Library(b, &c.get_package(), path, c.get_name())
-{ }
+ 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_version();
+ if(!version.empty())
+ {
+ string::size_type i = 0;
+ for(unsigned dots=0; i<version.size(); ++i)
+ if(version[i]=='.' && ++dots>=2)
+ break;
+
+ soname = format("%s.%s", FS::basename(path), version.substr(0, i));
+ }
+}
+
+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());
+ }
+}