using namespace Msp;
InstalledFile::InstalledFile(Builder &b, const SourcePackage &p, FileTarget &s, const std::string &loc):
- FileTarget(b, &p, generate_target_path(s, loc)),
+ FileTarget(b, &p, generate_target_path(b.get_prefix(), s, loc)),
source(s)
{
buildable = true;
mark_rebuild(source.get_name()+" needs rebuilding");
}
-FS::Path InstalledFile::generate_target_path(const FileTarget &tgt, const std::string &loc)
+FS::Path InstalledFile::generate_target_path(const FS::Path &prefix, const FileTarget &tgt, const std::string &loc)
{
- if(!tgt.get_package())
- throw invalid_argument("Can't install package-less targets");
-
- FS::Path base = tgt.get_package()->get_builder().get_prefix();
- string tgtname = FS::basename(tgt.get_path());
+ if(!tgt.is_installable() && loc.empty())
+ throw invalid_argument(tgt.get_name()+" is not installable");
string mid;
if(!loc.empty())
else
mid = tgt.get_install_location();
- if(mid.empty())
- throw invalid_argument("Don't know where to install "+tgtname);
-
- return base/mid/tgtname;
+ return prefix/mid/FS::basename(tgt.get_path());
}
private:
virtual void check_rebuild();
- static Msp::FS::Path generate_target_path(const FileTarget &i, const std::string &);
+ static Msp::FS::Path generate_target_path(const Msp::FS::Path &, const FileTarget &i, const std::string &);
};
#endif