]> git.tdb.fi Git - builder.git/blobdiff - source/installedfile.cpp
Refactor Binary::find_depends
[builder.git] / source / installedfile.cpp
index 15bd08b06f7b507b16109c8f08f7933306d1e092..f4b8a939832efc0aa150c5bc10196bba9c3f42c2 100644 (file)
@@ -10,7 +10,7 @@ InstalledFile::InstalledFile(Builder &b, const SourcePackage &p, FileTarget &s,
        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())
@@ -33,7 +33,12 @@ FS::Path InstalledFile::generate_target_path(const FS::Path &prefix, const FileT
        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()