- i->configure(opts, flag);
-}
-
-void SourcePackage::init_config()
-{
- config.add_option("profile", "default", "Configuration profile");
- config.add_option("tempdir", "temp", "Directory for storing temporary files");
- config.add_option("outdir", ".", "Directory to put build results in");
- config.add_option("optimize", "0", "Compiler optimization level");
- config.add_option("strip", "no", "Strip symbols from programs");
- config.add_option("debug", "no", "Produce debugging symbols");
- config.add_option("staticlibs", "local", "Use static libraries");
-
- for(FeatureList::iterator i=features.begin(); i!=features.end(); ++i)
- config.add_option("with_"+i->name, i->def_value, i->descr);
-
- for(PackageList::const_iterator i=requires.begin(); i!=requires.end(); ++i)
- {
- BinaryPackage *bpkg = dynamic_cast<BinaryPackage *>(*i);
- if(bpkg && bpkg->get_need_path())
- config.add_option(bpkg->get_name()+"_path", "/usr", "Path for "+bpkg->get_name());
- }
-}
-
-void SourcePackage::create_build_info()
-{
- // XXX Currently, a package-specific settings will override cmdline. This might or might not be desirable.
- const StringList &warnings = builder.get_warnings();
- build_info.warnings.insert(build_info.warnings.begin(), warnings.begin(), warnings.end());
-
- unsigned flags = get_install_flags();
-
- build_info.incpath.push_back((builder.get_prefix()/"include").str());
- build_info.libpath.push_back((builder.get_prefix()/"lib").str());
-
- if(flags&INCLUDE)
- export_binfo.incpath.push_back((builder.get_prefix()/"include").str());
- if(flags&LIB)
- export_binfo.libpath.push_back((builder.get_prefix()/"lib").str());
-
- string optimize = config.get_option("optimize").value;
- if(!optimize.empty() && optimize!="0")