X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fsourcepackage.h;h=5a1eddde5bd1b2793cf9b8e03b90ec9544434725;hb=e3407687a61bce56912b89818a9d9f006e9da41f;hp=8ba3eb3c899fa4febd920ba9b18bcc2e6920e535;hpb=75ac80cb255e4def7ee685ce9c46db7c2f6625aa;p=builder.git diff --git a/source/sourcepackage.h b/source/sourcepackage.h index 8ba3eb3..5a1eddd 100644 --- a/source/sourcepackage.h +++ b/source/sourcepackage.h @@ -4,21 +4,18 @@ #include #include #include "buildinfo.h" +#include "cache.h" #include "component.h" -#include "condition.h" +#include "conditionalloader.h" #include "config.h" -#include "dependencycache.h" #include "feature.h" #include "package.h" +#include "toolchain.h" class Builder; - -class bad_expansion: public std::runtime_error -{ -public: - bad_expansion(const std::string &w): std::runtime_error(w) { } - virtual ~bad_expansion() throw() { } -}; +class BuildType; +class FileTarget; +class SourceArchiveComponent; /** A package that can be built by Builder. @@ -26,78 +23,76 @@ 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, public FeatureConditional { private: - std::map install_map; + const Config::InputOptions *options; public: - Loader(Package &); - SourcePackage &get_object() { return static_cast(pkg); } + 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 + 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 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; + private: + typedef std::list FeatureList; + std::string version; + std::string interface_version; std::string description; - Msp::FS::Path source; + FileTarget *build_file; + Msp::FS::Path source_dir; + const BuildType *build_type; + Toolchain local_tools; FeatureList features; BuildInfo build_info; - ConditionList conditions; ComponentList components; + SourceArchiveComponent *source_archive; Config config; - mutable DependencyCache deps_cache; + mutable Cache cache; public: SourcePackage(Builder &, const std::string &, const Msp::FS::Path &); - const std::string &get_name() const { return name; } + ~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; } - const Msp::FS::Path &get_source() const { return source; } - Msp::FS::Path get_temp_dir() const; - Msp::FS::Path get_out_dir() const; - const ComponentList &get_components() const { return components; } - const Config &get_config() const { return config; } - 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(); + 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; - LibMode get_library_mode() const; - DependencyCache &get_deps_cache() const { return deps_cache; } - std::string expand_string(const std::string &) 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; } private: - virtual void do_configure(const StringMap &, unsigned); + virtual void do_prepare(); - /** Initializes configuration options. */ - void init_config(); - - /** Fills in build info based on configuration. All required packages must be - configured when this is called. */ - virtual void create_build_info(); - - virtual void create_targets(); +public: + Cache &get_cache() const { return cache; } +private: + virtual void save_caches(); }; #endif