X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fsourcepackage.h;h=e5f6d9d460433a718bf2eca654ff11a92b9e244c;hb=30b1243ff16b908ae18b4ab9d70f772c9196b949;hp=8ba3eb3c899fa4febd920ba9b18bcc2e6920e535;hpb=75ac80cb255e4def7ee685ce9c46db7c2f6625aa;p=builder.git diff --git a/source/sourcepackage.h b/source/sourcepackage.h index 8ba3eb3..e5f6d9d 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 { @@ -26,22 +27,13 @@ A package that can be built by Builder. class SourcePackage: public Package { public: - enum InstallFlags - { - INCLUDE = 1, - BIN = 2, - LIB = 4, - DATA = 8 - }; - - class Loader: public Package::Loader + class Loader: public Msp::DataFile::DerivedObjectLoader { private: std::map install_map; public: - Loader(Package &); - SourcePackage &get_object() { return static_cast(pkg); } + Loader(SourcePackage &); private: virtual void finish(); void feature(const std::string &, const std::string &); @@ -59,6 +51,7 @@ private: std::string description; Msp::FS::Path source; + const BuildType *build_type; FeatureList features; BuildInfo build_info; ConditionList conditions; @@ -68,7 +61,6 @@ private: public: SourcePackage(Builder &, const std::string &, const Msp::FS::Path &); - const std::string &get_name() const { return name; } const std::string &get_version() const { return version; } const std::string &get_description() const { return description; } const Msp::FS::Path &get_source() const { return source; } @@ -76,14 +68,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; } - const BuildInfo &get_exported_binfo() const { return export_binfo; } Builder &get_builder() const { return builder; } - /** Returns a bitmask indicating which kinds of things the components of - this package install. */ - unsigned get_install_flags(); - LibMode get_library_mode() const; DependencyCache &get_deps_cache() const { return deps_cache; } std::string expand_string(const std::string &) const; @@ -98,6 +86,8 @@ private: virtual void create_build_info(); virtual void create_targets(); + + virtual void save_caches(); }; #endif