X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fsourcepackage.h;h=66296001e44229265753f3c52056cef6a2652b02;hb=35f2979869bff43706f3163ec0979c7084aaa3c4;hp=1333bdb5ca536a75946a5a4108e4d6acf0fe9c8a;hpb=6140518acb736f9020005245686bfbc5fca2d329;p=builder.git diff --git a/source/sourcepackage.h b/source/sourcepackage.h index 1333bdb..6629600 100644 --- a/source/sourcepackage.h +++ b/source/sourcepackage.h @@ -14,13 +14,7 @@ class Builder; class BuildType; class FileTarget; - -class bad_expansion: public std::runtime_error -{ -public: - bad_expansion(const std::string &w): std::runtime_error(w) { } - virtual ~bad_expansion() throw() { } -}; +class TarballComponent; /** A package that can be built by Builder. @@ -40,8 +34,10 @@ public: void init(const Config::InputOptions *); virtual void finish(); void feature(const std::string &, const std::string &); - template + template void component(const std::string &); + template + void component_arg(const std::string &); void build_info(); void generate(const std::string &); void if_feature(const std::string &); @@ -51,7 +47,7 @@ public: void version(const std::string &); }; - typedef std::list ComponentList; + typedef std::list ComponentList; private: typedef std::list FeatureList; @@ -67,12 +63,13 @@ private: FeatureList features; BuildInfo build_info; ComponentList components; - Component *source_tarball; + TarballComponent *source_tarball; Config config; mutable Cache cache; public: SourcePackage(Builder &, const std::string &, const Msp::FS::Path &); + ~SourcePackage(); const std::string &get_version() const { return version; } const std::string &get_interface_version() const { return interface_version; } @@ -84,9 +81,9 @@ public: Msp::FS::Path get_output_directory() const; const Toolchain &get_toolchain() const { return local_tools; } - const ComponentList &get_components() const { return components; } + const Component &get_component(const std::string &) const; const Config &get_config() const { return config; } - bool match_feature(const std::string &) const; + bool match_feature(const std::string &, const std::string *) const; void set_build_type(const BuildType &); const BuildInfo &get_build_info() const { return build_info; } private: