X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fbinarypackage.cpp;h=381e792681abfbee7e78163753e397c6f5a68d5a;hb=23477a725988c3c896c2853c2417054c1310dabc;hp=bc3e5c929ec41af7d6a5b515f2ac2a17501c50b1;hpb=45c778b1976de1a3093e0c6fb5e2a94c42073dcb;p=builder.git diff --git a/source/binarypackage.cpp b/source/binarypackage.cpp index bc3e5c9..381e792 100644 --- a/source/binarypackage.cpp +++ b/source/binarypackage.cpp @@ -7,37 +7,28 @@ using namespace std; using namespace Msp; BinaryPackage::BinaryPackage(Builder &b, const string &n): - Package(b, n), - need_path(false) + Package(b, n) { use_pkgconfig = false; } -void BinaryPackage::set_path(const FS::Path &p) -{ - path = builder.get_cwd()/p; -} - void BinaryPackage::create_build_info() { - for(StringList::iterator i=export_binfo.incpath.begin(); i!=export_binfo.incpath.end(); ++i) - if((*i)[0]=='@') - *i = (path/i->substr(1)).str(); + for(BuildInfo::PathList::iterator i=export_binfo.incpath.begin(); i!=export_binfo.incpath.end(); ++i) + if((*i)[0]=="@") + *i = builder.get_prefix()/i->subpath(1); - for(StringList::iterator i=export_binfo.libpath.begin(); i!=export_binfo.libpath.end(); ++i) - if((*i)[0]=='@') - *i = (path/i->substr(1)).str(); + for(BuildInfo::PathList::iterator i=export_binfo.libpath.begin(); i!=export_binfo.libpath.end(); ++i) + if((*i)[0]=="@") + *i = builder.get_prefix()/i->subpath(1); } -BinaryPackage *BinaryPackage::from_pkgconfig(Builder &builder, const string &name) +BinaryPackage *BinaryPackage::from_flags(Builder &builder, const string &name, const vector &flags) { - string info = builder.run_pkgconfig(name, "flags"); - BinaryPackage *pkg = new BinaryPackage(builder, name); pkg->use_pkgconfig = true; BuildInfo &binfo = pkg->export_binfo; - vector flags = split(info); for(vector::const_iterator i=flags.begin(); i!=flags.end(); ++i) { if(!i->compare(0, 2, "-I")) @@ -63,13 +54,12 @@ BinaryPackage *BinaryPackage::from_pkgconfig(Builder &builder, const string &nam BinaryPackage::Loader::Loader(BinaryPackage &p): - Package::Loader(p) + DataFile::DerivedObjectLoader(p) { - add("need_path", &BinaryPackage::need_path); add("build_info", &Loader::build_info); } void BinaryPackage::Loader::build_info() { - load_sub(static_cast(pkg).export_binfo); + load_sub(obj.export_binfo); }