X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fsourcepackage.h;h=3d868631871591d88e2f511007c3d15c06c60202;hb=aeb23448b5035f4ceb662c487913618d0efff888;hp=94555d6e3e96dc85c3ad662f0c896a10637f3af6;hpb=50baabc242633d531d3f9542e9a64491b6e12c6c;p=builder.git diff --git a/source/sourcepackage.h b/source/sourcepackage.h index 94555d6..3d86863 100644 --- a/source/sourcepackage.h +++ b/source/sourcepackage.h @@ -6,22 +6,15 @@ #include "buildinfo.h" #include "cache.h" #include "component.h" -#include "condition.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() { } -}; - /** A package that can be built by Builder. */ @@ -32,7 +25,6 @@ public: { private: const Config::InputOptions *options; - std::map install_map; public: Loader(SourcePackage &); @@ -43,14 +35,12 @@ public: void feature(const std::string &, const std::string &); template void component(const std::string &); - void condition(const std::string &); void build_info(); - void headers(const std::string &); + void generate(const std::string &); void if_feature(const std::string &); void interface_version(const std::string &); void source_tarball(); void tarball(const std::string &); - void tar_file(const std::string &); void version(const std::string &); }; @@ -66,6 +56,7 @@ private: FileTarget *build_file; Msp::FS::Path source_dir; const BuildType *build_type; + Toolchain local_tools; FeatureList features; BuildInfo build_info; ComponentList components; @@ -79,20 +70,24 @@ public: 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_directory() const; Msp::FS::Path get_output_directory() const; + + const Toolchain &get_toolchain() const { return local_tools; } const ComponentList &get_components() const { return components; } 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; } - - Cache &get_cache() const { return cache; } private: virtual void do_prepare(); +public: + Cache &get_cache() const { return cache; } +private: virtual void save_caches(); };