X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fsourcepackage.h;h=9327f17c4eccc619cfa9e1b2dd5226d93c8ed701;hb=3f541fceb5aeb5d685ceb2363ebbca1cb1c3eb84;hp=cd576fef26a03cd8c9f4463668e1984670441109;hpb=5c25b76c7263b2a8ac01c863e438592c6287758a;p=builder.git diff --git a/source/sourcepackage.h b/source/sourcepackage.h index cd576fe..9327f17 100644 --- a/source/sourcepackage.h +++ b/source/sourcepackage.h @@ -12,6 +12,7 @@ #include "package.h" class Builder; +class BuildType; class bad_expansion: public std::runtime_error { @@ -29,11 +30,14 @@ public: class Loader: public Msp::DataFile::DerivedObjectLoader { private: + const Config::InputOptions *options; std::map install_map; public: Loader(SourcePackage &); + Loader(SourcePackage &, const Config::InputOptions &); private: + void init(const Config::InputOptions *); virtual void finish(); void feature(const std::string &, const std::string &); template @@ -41,6 +45,8 @@ public: void condition(const std::string &); void build_info(); void headers(const std::string &); + void if_arch(const std::string &); + void if_feature(const std::string &); void tarball(const std::string &); void tar_file(const std::string &); }; @@ -50,9 +56,9 @@ private: std::string description; Msp::FS::Path source; + const BuildType *build_type; FeatureList features; BuildInfo build_info; - ConditionList conditions; ComponentList components; Config config; mutable DependencyCache deps_cache; @@ -66,10 +72,10 @@ public: Msp::FS::Path get_out_dir() const; const ComponentList &get_components() const { return components; } const Config &get_config() const { return config; } + void set_build_type(const BuildType &); const BuildInfo &get_build_info() const { return build_info; } Builder &get_builder() const { return builder; } - LibMode get_library_mode() const; DependencyCache &get_deps_cache() const { return deps_cache; } std::string expand_string(const std::string &) const; private: