FileTarget(b, p, generate_target_path(b.get_prefix(), s, loc)),
source(s)
{
- add_depend(&source);
+ add_depend(source);
if(const SharedLibrary *shlib = dynamic_cast<const SharedLibrary *>(&source))
if(!shlib->get_soname().empty())
FS::Path mid;
if(!loc.empty())
mid = loc;
+ else if(const Component *comp = tgt.get_component())
+ mid = comp->get_install_map().get_install_location(tgt);
else
mid = tgt.get_install_location();
- return prefix/mid/FS::basename(tgt.get_path());
+ string fn = FS::basename(tgt.get_path());
+ if(const SharedLibrary *shlib = dynamic_cast<const SharedLibrary *>(&tgt))
+ if(!shlib->get_soname().empty())
+ fn = shlib->get_soname();
+
+ return prefix/mid/fn;
}
Target *InstalledFile::get_real_target()