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())
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()