]> git.tdb.fi Git - builder.git/blobdiff - source/installedfile.cpp
Have the linker specify symlinks for installed libraries
[builder.git] / source / installedfile.cpp
index b2487537369076f705b136a1023371f9a9cf7356..35742bb0daf8e383f90418f621b438c14eb9e223 100644 (file)
@@ -12,17 +12,6 @@ InstalledFile::InstalledFile(Builder &b, const SourcePackage &p, FileTarget &s,
        source(s)
 {
        add_dependency(source);
-
-       /* XXX Ideally, the tool should handle this (symlinks are not necessary for
-       windows dlls).  However, the tool that created the target being installed
-       knows nothing about the InstalledFile. */
-       string base_fn = FS::basename(source.get_path());
-       const string &inst_fn = source.get_install_filename();
-       if(!inst_fn.empty() && inst_fn!=base_fn)
-       {
-               link = FS::dirname(path)/base_fn;
-               builder.get_vfs().register_path(link, this);
-       }
 }
 
 FS::Path InstalledFile::generate_target_path(const FS::Path &prefix, const FileTarget &tgt, const string &loc)
@@ -45,6 +34,12 @@ FS::Path InstalledFile::generate_target_path(const FS::Path &prefix, const FileT
        return prefix/mid/fn;
 }
 
+void InstalledFile::set_symlink(const FS::Path &l)
+{
+       link = FS::dirname(path)/l;
+       builder.get_vfs().register_path(link, this);
+}
+
 Target *InstalledFile::get_real_target()
 {
        return source.get_real_target();