X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fcomponent.h;h=2e9e534c0ca0973d2638a8902446c926bdfe0b67;hb=7606161ee4a6fd13c2f5ddca413ba3582df66f03;hp=5efed1a08ad06bd1ef4db470b3c263f4f4d53f09;hpb=e89616b514c77e189b93d5a46aa5a5a72e34c3cb;p=builder.git diff --git a/source/component.h b/source/component.h index 5efed1a..2e9e534 100644 --- a/source/component.h +++ b/source/component.h @@ -2,11 +2,10 @@ #define COMPONENT_H_ #include -#include +#include #include #include "buildinfo.h" #include "installmap.h" -#include "misc.h" #include "package.h" class SourcePackage; @@ -20,24 +19,20 @@ their own. class Component { public: - class Loader: public Msp::DataFile::Loader + class Loader: public Msp::DataFile::ObjectLoader { - private: - Component ∁ - public: Loader(Component &); - Component &get_object() { return comp; } private: void source(const std::string &); void require(const std::string &); void build_info(); void install_map(); + void use(const std::string &); }; enum Type { - HEADERS, LIBRARY, PROGRAM, MODULE, @@ -46,42 +41,53 @@ public: TARBALL }; + typedef std::list SourceList; + typedef std::list UseList; + protected: - SourcePackage &pkg; + SourcePackage &package; Type type; std::string name; - StringList sources; + SourceList sources; bool install; BuildInfo build_info; - PackageList requires; + Package::Requirements requires; + UseList uses; bool deflt; InstallMap install_map; public: Component(SourcePackage &, Type, const std::string &); - const SourcePackage &get_package() const { return pkg; } + + const SourcePackage &get_package() const { return package; } Type get_type() const { return type; } const std::string &get_name() const { return name; } - const StringList &get_sources() const { return sources; } - const BuildInfo &get_build_info() const { return build_info; } + + /** Returns a list of sources for the component. They may refer to + directories or individual files. */ + const SourceList &get_sources() const { return sources; } + +protected: + /** Returns a list of all source files for the component. */ + SourceList collect_source_files() const; + +public: bool get_install() const { return install; } - const PackageList &get_requires() const { return requires; } - bool is_default() const { return deflt; } const InstallMap &get_install_map() const { return install_map; } + const Package::Requirements &get_required_packages() const { return requires; } + const UseList &get_used_components() const { return uses; } + bool is_default() const { return deflt; } - void configure(const StringMap &, unsigned); + /** Prepares any required packages. */ + void prepare(); /** Prepares the build information for building. Pulls build info from the parent and dependency packages, and adds any component-specific flags. */ void create_build_info(); - void create_targets() const; + const BuildInfo &get_build_info() const { return build_info; } -protected: - /** Returns a list of all source files for the component. */ - PathList collect_source_files() const; + void create_targets() const; }; -typedef std::list ComponentList; - #endif