X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fconfig.h;h=1f7fa712839f5b5bdc346681e3a346c117aafba4;hb=c75c89d2425ab0c69e94d45a5d956286838bbc67;hp=355108fb2c35bcd26f5c012c107dc4d587703212;hpb=74266a6e650f019063cdcd1c9a7bd26d8f99041b;p=builder.git diff --git a/source/config.h b/source/config.h index 355108f..1f7fa71 100644 --- a/source/config.h +++ b/source/config.h @@ -3,11 +3,12 @@ #include #include -#include -#include +#include +#include #include +#include "feature.h" -typedef std::map RawOptionMap; +class SourcePackage; /** Manages configuration for a package. A configuration may have an arbitary @@ -16,41 +17,51 @@ amount of options, as well as a modification time (mtime). class Config { public: - /** - A single configuration option. - */ - struct Option + /** A single configuration option. */ + struct Option: public Feature { - std::string name; - std::string defv; - std::string descr; std::string value; - Option(const std::string &, const std::string &, const std::string &); + Option(const Feature &); }; + typedef std::map OptionMap; + typedef std::map InputOptions; - void add_option(const std::string &, const std::string &, const std::string &); - const Option &get_option(const std::string &) const; - const OptionMap &get_options() const { return options; } - const Msp::Time::TimeStamp &get_mtime() const { return mtime; } - bool is_option(const std::string &) const; - bool process(const RawOptionMap &); - void load(const Msp::Path::Path &); - void save(const Msp::Path::Path &) const; private: - class Loader: public Msp::Parser::Loader + class Loader: public Msp::DataFile::ObjectLoader { public: Loader(Config &); private: - Config &conf; - void option(const std::string &, const std::string &); }; - + + SourcePackage &package; OptionMap options; + InputOptions pending_options; Msp::Time::TimeStamp mtime; + bool changed; + +public: + Config(SourcePackage &); + + /** Adds a configuration option based on a feature. */ + const Option &add_option(const Feature &); + + bool set_option(const std::string &, const std::string &); + + /** Checks whether an option exists. */ + bool is_option(const std::string &) const; + + /** 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; } + + void load(); + void save() const; }; #endif