X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fsourcepackage.h;h=68b89c85279e4ab9327be954b457f4f8a2742de2;hb=8f99b70eb78bdb5537afc77aa283961a2e825506;hp=97c8d61a6fb7914494c31475a8423e8954d3d66c;hpb=08015c0f27f377fcd4aa186fca5bd8cf70723a5a;p=builder.git diff --git a/source/sourcepackage.h b/source/sourcepackage.h index 97c8d61..68b89c8 100644 --- a/source/sourcepackage.h +++ b/source/sourcepackage.h @@ -6,21 +6,16 @@ #include "buildinfo.h" #include "cache.h" #include "component.h" -#include "condition.h" +#include "conditionalloader.h" #include "config.h" #include "feature.h" #include "package.h" +#include "toolchain.h" 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 SourceArchiveComponent; /** A package that can be built by Builder. @@ -28,68 +23,75 @@ 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; - std::map install_map; public: - Loader(SourcePackage &); - Loader(SourcePackage &, const Config::InputOptions &); + Loader(SourcePackage &, const Config::InputOptions *); private: - void init(const Config::InputOptions *); - virtual void finish(); + void finish() override; + void feature(const std::string &, const std::string &); - template + template void component(const std::string &); - void condition(const std::string &); + template + void component_arg(const std::string &); void build_info(); - void headers(const std::string &); - void if_feature(const std::string &); - void source_tarball(); + void generate(const std::string &); + void interface_version(const std::string &); + void source_archive(); void tarball(const std::string &); - void tar_file(const std::string &); + void version(const std::string &); }; - typedef std::list ComponentList; + typedef std::list ComponentList; private: typedef std::list FeatureList; std::string version; + std::string interface_version; std::string description; FileTarget *build_file; Msp::FS::Path source_dir; const BuildType *build_type; + Toolchain local_tools; 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; } const std::string &get_description() const { return description; } + FileTarget &get_build_file() const { return *build_file; } const Msp::FS::Path &get_source_directory() const { return source_dir; } - Msp::FS::Path get_temp_dir() const; - Msp::FS::Path get_out_dir() const; - const ComponentList &get_components() const { return components; } + Msp::FS::Path get_temp_directory() const; + Msp::FS::Path get_output_directory() const; + + const Toolchain &get_toolchain() const { return local_tools; } + 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 &); const BuildInfo &get_build_info() const { return build_info; } - Builder &get_builder() const { return builder; } +private: + void do_prepare() override; +public: Cache &get_cache() const { return cache; } private: - virtual void do_prepare(); - - virtual void save_caches(); + void save_caches() override; }; #endif