- Executable(b, c, objs),
- libname(c.get_name())
-{ }
+ Binary(b, c, generate_filename(c), objs),
+ libname(c.get_name()),
+ soname(create_soname(c))
+{
+ install_location = "lib";
+ if(component->get_type()==Component::MODULE)
+ {
+ install_location += '/';
+ install_location += package->get_name();
+ }
+}
+
+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());
+ }
+}
+
+string SharedLibrary::create_soname(const Component &c)
+{
+ const string &ver = c.get_package().get_version();
+ if(ver.empty())
+ return string();
+
+ unsigned dots = 0;
+ unsigned i = 0;
+ for(; i<ver.size(); ++i)
+ if(ver[i]=='.')
+ {
+ ++dots;
+ if(dots>=2)
+ break;
+ }