const vector<string> &args=getopt.get_args();
for(vector<string>::const_iterator i=args.begin(); i!=args.end(); ++i)
{
- unsigned equal=i->find('=');
+ string::size_type equal=i->find('=');
if(equal!=string::npos)
cmdline_options.insert(StringMap::value_type(i->substr(0, equal), i->substr(equal+1)));
else
native_arch->set_tool("AR", "ar");
load_build_file((FS::get_sys_data_dir(argv[0], "builder")/"builderrc").str());
- load_build_file((FS::get_home_dir()/".builderrc").str());
+ load_build_file((FS::get_user_data_dir("builder")/"rc").str());
if(arch.empty())
current_arch=native_arch;
if(dynamic_cast<SourcePackage *>(*i))
IO::print("*");
unsigned count=0;
- unsigned ood_count=0;
+ unsigned to_be_built=0;
for(TargetMap::iterator j=targets.begin(); j!=targets.end(); ++j)
if(j->second->get_package()==*i)
{
++count;
if(j->second->get_rebuild())
- ++ood_count;
+ ++to_be_built;
}
if(count)
{
IO::print(" (%d targets", count);
- if(ood_count)
- IO::print(", %d out-of-date", ood_count);
+ if(to_be_built)
+ IO::print(", %d to be built", to_be_built);
IO::print(")");
}
IO::print("\n");
IO::print(IO::cerr, "The following problems were detected:\n");
for(ProblemList::iterator i=problems.begin(); i!=problems.end(); ++i)
IO::print(IO::cerr, " %s: %s\n", i->package, i->descr);
- IO::print(IO::cerr, "Please fix them and try again.\n");
+ if(!analyzer)
+ IO::print(IO::cerr, "Please fix them and try again.\n");
return 1;
}
StringList argv;
argv.push_back(current_arch->get_tool("CXX"));
argv.push_back("--version");
- cxx_ver=Regex("[0-9]\\.[0-9.]+").match(run_command(argv))[0].str;
- while(!cxx_ver.empty() && !FS::is_dir(FS::Path("/usr/include/c++")/cxx_ver))
+ if(RegMatch m=Regex("[0-9]\\.[0-9.]+").match(run_command(argv)))
{
- unsigned dot=cxx_ver.rfind('.');
- if(dot==string::npos)
- break;
- cxx_ver.erase(dot);
+ cxx_ver=m[0].str;
+ while(!cxx_ver.empty() && !FS::is_dir(FS::Path("/usr/include/c++")/cxx_ver))
+ {
+ string::size_type dot=cxx_ver.rfind('.');
+ if(dot==string::npos)
+ break;
+ cxx_ver.erase(dot);
+ }
+ if(verbose>=5)
+ IO::print("C++ version is %s\n", cxx_ver);
}
- if(verbose>=5)
- IO::print("C++ version is %s\n", cxx_ver);
+ else
+ cxx_ver="-";
}
string fn=include.substr(1);
syspath.push_back("/usr/include");
else
syspath.push_back("/usr/"+current_arch->get_prefix()+"/include");
- syspath.push_back((FS::Path("/usr/include/c++/")/cxx_ver).str());
+ if(cxx_ver!="-")
+ syspath.push_back((FS::Path("/usr/include/c++/")/cxx_ver).str());
Target *tgt=0;
if(include[0]=='\"')
IO::print(IO::cerr, "Usage: %s\n", usagemsg);
else
{
+ IO::print(IO::cerr, "Builder 1.0\n\n");
IO::print(IO::cerr, "Usage: %s [options] [<target> ...]\n\n", argv0);
IO::print(IO::cerr, "Options:\n");
IO::print(IO::cerr, helpmsg);
cmdline->add_depend(tgt);
}
- /* If world is to be built, prepare cmdline. If not, add cmdline to world
- and prepare world. I don't really like this, but it keeps the graph
- acyclic.
-
- XXX Could we skip preparing targets we are not interested in? */
- if(build_world)
- cmdline->prepare();
- else
- {
- world->add_depend(cmdline);
- world->prepare();
- }
+ cmdline->prepare();
for(PackageMap::iterator i=packages.begin(); i!=packages.end(); ++i)
if(SourcePackage *spkg=dynamic_cast<SourcePackage *>(i->second))
return 0;
}
-Target *Builder::get_header(const Msp::FS::Path &fn)
+Target *Builder::get_header(const FS::Path &fn)
{
Target *tgt=get_target(fn.str());
if(tgt) return tgt;
{
Target *cmdline=get_target("cmdline");
- unsigned total=cmdline->count_rebuild();
+ unsigned total=0;
+ for(map<string, Target *>::const_iterator i=targets.begin(); i!=targets.end(); ++i)
+ if(i->second->is_buildable() && i->second->get_rebuild())
+ ++total;
+
if(!total)
{
IO::print("Already up to date\n");
Target *tgt=queue.front();
queue.erase(queue.begin());
- if(tgt->get_buildable() && (tgt->get_package()==main_pkg || clean>=2))
+ if(tgt->is_buildable() && (tgt->get_package()==main_pkg || clean>=2))
clean_tgts.insert(tgt);
const TargetList &deps=tgt->get_depends();