void Config::select_last_profile()
{
- try
+ FS::Path profile_cache_fn = package.get_source()/".profile";
+ if(FS::exists(profile_cache_fn))
{
- IO::BufferedFile in((package.get_source()/".profile").str());
+ IO::BufferedFile in(profile_cache_fn.str());
string profile;
in.getline(profile);
set_option("profile", profile);
}
- catch(const IO::file_not_found &)
- { }
freeze_mtime = true;
package.get_builder().apply_profile_template(*this, get_option("profile").value);
{
FS::Path fn = package.get_source()/(".options."+get_option("profile").value);
- try
+ FS::Stat stat = FS::stat(fn);
+ if(stat)
{
IO::BufferedFile in(fn.str());
- mtime = FS::stat(fn).get_modify_time();
+ mtime = stat.get_modify_time();
DataFile::Parser parser(in, fn.str());
Loader loader(*this);
loader.load(parser);
}
- catch(const IO::file_not_found &)
- { }
}
Config::Loader::Loader(Config &c):
- conf(c)
+ DataFile::ObjectLoader<Config>(c)
{
add("option", &Loader::option);
}
void Config::Loader::option(const string &n, const string &v)
{
- conf.set_option(n, v);
+ obj.set_option(n, v);
}