X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fconfig.h;h=d7f7351f00d4420eb324cb492abbf388b2732645;hb=43bd25ffcb0b4f7882773f4676b209a99cb73c04;hp=1b78e3a4e4d2e8a1168be85f6ec0f78187d60202;hpb=59ac0a44d6edf179c01604c6ced744873213f855;p=builder.git diff --git a/source/config.h b/source/config.h index 1b78e3a..d7f7351 100644 --- a/source/config.h +++ b/source/config.h @@ -3,13 +3,21 @@ #include #include -#include "option.h" +#include +#include +#include +#include "misc.h" -typedef std::map RawOptionMap; +class SourcePackage; +/** +Manages configuration for a package. A configuration may have an arbitary +amount of options, as well as a modification time (mtime). +*/ class Config { public: + /** A single configuration option. */ struct Option { std::string name; @@ -19,15 +27,62 @@ public: Option(const std::string &, const std::string &, const std::string &); }; + typedef std::map OptionMap; +private: + class Loader: public Msp::DataFile::Loader + { + private: + Config &conf; + + public: + Loader(Config &); + private: + void option(const std::string &, const std::string &); + }; + + SourcePackage &package; + OptionMap options; + Msp::Time::TimeStamp mtime; + bool freeze_mtime; + +public: + Config(SourcePackage &); + + /** Adds a configuration option with name, default value and description. */ void add_option(const std::string &, const std::string &, const std::string &); + + /** Gets a configuration option by name. */ const Option &get_option(const std::string &) const; + + const OptionMap &get_options() const { return options; } + const Msp::Time::TimeStamp &get_mtime() const { return mtime; } + + /** Checks whether an option exists. */ bool is_option(const std::string &) const; - bool process(const RawOptionMap &); - void load(const std::string &); + + /** Selects the last profile used. If the profile cache file is not + present, the default profile is assumed. */ + void select_last_profile(); + + /** Selects a profile. The profile cache file is updated, unless doing a + dry run. */ + void select_profile(const std::string &); + + /** Processes options from the given raw option map. Nonexistent options + are ignored. If any options were changed, the mtime of the configuration is + updated to the current time. Return value indicates whether any options + were changed. */ + bool update(const StringMap &); + + /** Expands any variable references in options. */ + void finish(); + + void save() const; private: - OptionMap options; + bool set_option(const std::string &, const std::string &); + void load(); }; #endif