X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpackage.h;h=eb61f06b760e1fc21a4c62a3a34fda194837573e;hb=c75c89d2425ab0c69e94d45a5d956286838bbc67;hp=e63fd77ff09fd26d50ba670e1c33a129a0ff12ab;hpb=43bd25ffcb0b4f7882773f4676b209a99cb73c04;p=builder.git diff --git a/source/package.h b/source/package.h index e63fd77..eb61f06 100644 --- a/source/package.h +++ b/source/package.h @@ -3,14 +3,13 @@ #include #include -#include +#include #include "buildinfo.h" +#include "config.h" class Builder; class Package; -typedef std::list PackageList; - /** A package is a distributable piece of software. Package information may be obtained in several ways: Build files of source packages, pkg-config for binary @@ -19,25 +18,26 @@ packages and the builderrc file for binary packages with no pkg-config support. class Package { public: - class Loader: public Msp::DataFile::Loader + class Loader: public Msp::DataFile::ObjectLoader { public: Loader(Package &); - Package &get_object() { return pkg; } - protected: - Package &pkg; - + private: + void if_arch(const std::string &); void require(const std::string &); }; + typedef std::list Requirements; + protected: Builder &builder; std::string name; - PackageList requires; + Requirements requires; BuildInfo export_binfo; - bool conf_done; + bool prepared; + std::list problems; bool use_pkgconfig; @@ -45,23 +45,28 @@ protected: public: virtual ~Package() { } - const std::string &get_name() const { return name; } Builder &get_builder() const { return builder; } - const PackageList &get_requires() const { return requires; } + const std::string &get_name() const { return name; } + const Requirements &get_required_packages() const { return requires; } - const BuildInfo &get_exported_binfo() const { return export_binfo; } + const BuildInfo &get_exported_build_info() const { return export_binfo; } /// Indicates whether or not this package supports pkg-config - bool get_use_pkgconfig() const { return use_pkgconfig; } + bool uses_pkgconfig() const { return use_pkgconfig; } - /** Processes configuration options that were most likely obtained from the - command line. */ - void configure(const StringMap &, unsigned); + /** Prepares the package for building. Recursively prepares all required + packages, populates build info and creates targets. */ + void prepare(); - bool is_configured() const { return conf_done; } protected: - virtual void do_configure(const StringMap &, unsigned) { } - virtual void create_build_info() { } + virtual void do_prepare() { } + +public: + bool is_prepared() const { return prepared; } + + const std::list &get_problems() const { return problems; } + + virtual void save_caches() { } }; #endif