X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fsourcepackage.h;h=5a1eddde5bd1b2793cf9b8e03b90ec9544434725;hb=69cd5cc73f466181420711fb907979de58687a4c;hp=3d868631871591d88e2f511007c3d15c06c60202;hpb=aeb23448b5035f4ceb662c487913618d0efff888;p=builder.git diff --git a/source/sourcepackage.h b/source/sourcepackage.h index 3d86863..5a1eddd 100644 --- a/source/sourcepackage.h +++ b/source/sourcepackage.h @@ -6,6 +6,7 @@ #include "buildinfo.h" #include "cache.h" #include "component.h" +#include "conditionalloader.h" #include "config.h" #include "feature.h" #include "package.h" @@ -14,6 +15,7 @@ class Builder; class BuildType; class FileTarget; +class SourceArchiveComponent; /** A package that can be built by Builder. @@ -21,7 +23,7 @@ A package that can be built by Builder. class SourcePackage: public Package { public: - class Loader: public Msp::DataFile::DerivedObjectLoader + class Loader: public Msp::DataFile::DerivedObjectLoader, public FeatureConditional { private: const Config::InputOptions *options; @@ -33,18 +35,19 @@ 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 &); void interface_version(const std::string &); - void source_tarball(); + void source_archive(); void tarball(const std::string &); void version(const std::string &); }; - typedef std::list ComponentList; + typedef std::list ComponentList; private: typedef std::list FeatureList; @@ -60,12 +63,13 @@ private: FeatureList features; BuildInfo build_info; ComponentList components; - Component *source_tarball; + SourceArchiveComponent *source_archive; 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; } @@ -77,7 +81,7 @@ 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 std::string *) const; void set_build_type(const BuildType &);