1 #include <msp/io/print.h>
2 #include <msp/strings/utils.h>
3 #include "binarypackage.h"
9 BinaryPackage::BinaryPackage(Builder &b, const string &n):
12 use_pkgconfig = false;
15 void BinaryPackage::do_prepare()
17 bool has_relative_paths = false;
18 for(BuildInfo::PathList::const_iterator i=export_binfo.libpath.begin(); (!has_relative_paths && i!=export_binfo.libpath.end()); ++i)
19 has_relative_paths = !i->is_absolute();
23 /* If we have any relative paths that need resolving, or we have no paths at
24 all and are not using pkg-config, look for files in prefix */
25 if(has_relative_paths || (!use_pkgconfig && export_binfo.libpath.empty()))
26 bases.push_back(builder.get_prefix());
28 // Always look in system locations
29 bases.push_back(FS::Path());
32 for(list<FS::Path>::const_iterator i=bases.begin(); i!=bases.end(); ++i)
35 system = prefix.empty();
39 const Architecture &arch = builder.get_current_arch();
41 prefix /= arch.get_cross_prefix();
44 BuildInfo::PathList libpath = export_binfo.libpath;
45 if(!system && libpath.empty())
46 libpath.push_back("lib");
47 for(BuildInfo::PathList::iterator j=libpath.begin(); j!=libpath.end(); ++j)
50 bool all_found = true;
51 for(BuildInfo::WordList::const_iterator j=export_binfo.libs.begin(); j!=export_binfo.libs.end(); ++j)
52 all_found &= (builder.get_vfs().find_library(*j, libpath, export_binfo.libmode, system)!=0);
57 builder.get_logger().log("configure", format("%s found in %s", name, ((system && use_pkgconfig) ? "system" : base_path.str())));
64 builder.problem(name, "Cannot locate files");
68 /* Add default entries to paths if they're empty and the package was found
69 in a non-system location */
70 if(!system && export_binfo.incpath.empty())
71 export_binfo.incpath.push_back(base_path/"include");
72 if(!system && export_binfo.libpath.empty())
73 export_binfo.libpath.push_back(base_path/"lib");
75 for(BuildInfo::PathList::iterator i=export_binfo.incpath.begin(); i!=export_binfo.incpath.end(); ++i)
77 for(BuildInfo::PathList::iterator i=export_binfo.libpath.begin(); i!=export_binfo.libpath.end(); ++i)
81 BinaryPackage *BinaryPackage::from_flags(Builder &builder, const string &name, const vector<string> &flags)
83 BinaryPackage *pkg = new BinaryPackage(builder, name);
84 pkg->use_pkgconfig = true;
85 BuildInfo &binfo = pkg->export_binfo;
87 for(vector<string>::const_iterator i=flags.begin(); i!=flags.end(); ++i)
89 if(!i->compare(0, 2, "-I"))
90 binfo.incpath.push_back(i->substr(2));
91 else if(!i->compare(0, 2, "-D"))
93 string::size_type equals = i->find('=');
94 if(equals!=string::npos)
95 binfo.defines[i->substr(2, equals-2)] = i->substr(equals+1);
97 binfo.defines[i->substr(2)] = string();
99 else if(!i->compare(0, 2, "-L"))
100 binfo.libpath.push_back(i->substr(2));
101 else if(!i->compare(0, 2, "-l"))
102 binfo.libs.push_back(i->substr(2));
103 else if(*i=="-pthread")
104 binfo.threads = true;
111 BinaryPackage::Loader::Loader(BinaryPackage &p):
112 DataFile::DerivedObjectLoader<BinaryPackage, Package>(p)
114 add("build_info", &Loader::build_info);
117 void BinaryPackage::Loader::build_info()
119 load_sub(obj.export_binfo);