X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpackage.h;h=34049d0ce9129ec4de87a3f35a367e22c7d72cee;hb=e3407687a61bce56912b89818a9d9f006e9da41f;hp=5c80779aa67d94aeb60ee0d8383ef993afd1bc22;hpb=69cdee2c53972c1dd7e1b9d83ddcd8f6c3c589f7;p=builder.git diff --git a/source/package.h b/source/package.h index 5c80779..34049d0 100644 --- a/source/package.h +++ b/source/package.h @@ -5,13 +5,12 @@ #include #include #include "buildinfo.h" +#include "conditionalloader.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 @@ -20,7 +19,7 @@ packages and the builderrc file for binary packages with no pkg-config support. class Package { public: - class Loader: public Msp::DataFile::ObjectLoader + class Loader: public Msp::DataFile::ObjectLoader, public ArchitectureConditional { public: Loader(Package &); @@ -28,14 +27,18 @@ public: void require(const std::string &); }; + typedef std::list Requirements; + protected: Builder &builder; std::string name; + std::string label; - PackageList requires; + Requirements requires; BuildInfo export_binfo; bool prepared; + std::list problems; bool use_pkgconfig; @@ -43,26 +46,28 @@ protected: public: virtual ~Package() { } - const std::string &get_name() const { return name; } Builder &get_builder() const { return builder; } - const PackageList &get_required_packages() const { return requires; } + const std::string &get_name() const { return name; } + const std::string &get_label() const { return label; } + const Requirements &get_required_packages() const { return requires; } 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; } /** Prepares the package for building. Recursively prepares all required packages, populates build info and creates targets. */ void prepare(); - bool is_prepared() const { return prepared; } protected: - virtual void create_build_info() { } - - virtual void create_targets() { } + virtual void do_prepare() { } public: + bool is_prepared() const { return prepared; } + + const std::list &get_problems() const { return problems; } + virtual void save_caches() { } };