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)
return prefix/mid/fn;
}
+void InstalledFile::set_symlink(const FS::Path &l)
+{
+ FS::Path al = FS::dirname(path)/l;
+ if(al==path)
+ throw invalid_argument("InstalledFile::set_symlink");
+ link = FS::dirname(path)/l;
+ builder.get_vfs().register_path(link, this);
+}
+
Target *InstalledFile::get_real_target()
{
return source.get_real_target();