X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpackage.h;h=d13aa737b985a71a8a99242445bb5915472c66d3;hb=d1f9551e05c9d341149eb490e05b1465d3d6b711;hp=eb61f06b760e1fc21a4c62a3a34fda194837573e;hpb=36508cbdaa8cd45cdd5fc67eee763ad44e31a164;p=builder.git diff --git a/source/package.h b/source/package.h index eb61f06..d13aa73 100644 --- a/source/package.h +++ b/source/package.h @@ -1,10 +1,11 @@ #ifndef PACKAGE_H_ #define PACKAGE_H_ -#include #include +#include #include #include "buildinfo.h" +#include "conditionalloader.h" #include "config.h" class Builder; @@ -18,28 +19,28 @@ 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 &); private: - void if_arch(const std::string &); void require(const std::string &); }; - typedef std::list Requirements; + using Requirements = std::vector; protected: Builder &builder; std::string name; + std::string label; Requirements requires; BuildInfo export_binfo; - bool prepared; - std::list problems; + bool prepared = false; + std::vector problems; - bool use_pkgconfig; + bool use_pkgconfig = true; Package(Builder &, const std::string &); public: @@ -47,6 +48,7 @@ public: Builder &get_builder() const { return builder; } 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; } @@ -64,7 +66,7 @@ protected: public: bool is_prepared() const { return prepared; } - const std::list &get_problems() const { return problems; } + const std::vector &get_problems() const { return problems; } virtual void save_caches() { } };