X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpackage.h;h=5c80779aa67d94aeb60ee0d8383ef993afd1bc22;hb=1324d8e99c6fa3fa11db1a90fb0b9fc23c490247;hp=4620cf475f51d3d99b5d251b274a760a92a4fb97;hpb=1968c546cfb30214e8dc5afc722bec14aa8373f5;p=builder.git diff --git a/source/package.h b/source/package.h index 4620cf4..5c80779 100644 --- a/source/package.h +++ b/source/package.h @@ -1,17 +1,11 @@ -/* $Id$ - -This file is part of builder -Copyright © 2006-2007 Mikko Rasa, Mikkosoft Productions -Distributed under the LGPL -*/ - #ifndef PACKAGE_H_ #define PACKAGE_H_ #include #include -#include +#include #include "buildinfo.h" +#include "config.h" class Builder; class Package; @@ -26,42 +20,50 @@ 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 require(const std::string &); }; - const std::string &get_name() const { return name; } - Builder &get_builder() const { return builder; } - const PackageList &get_requires() const { return requires; } - PackageList collect_requires(); - const BuildInfo &get_exported_binfo() const { return export_binfo; } +protected: + Builder &builder; + + std::string name; - /// Indicates whether or not this package supports pkg-config - bool get_use_pkgconfig() const { return use_pkgconfig; } + PackageList requires; + BuildInfo export_binfo; + bool prepared; - void configure(const StringMap &, unsigned); + bool use_pkgconfig; + + Package(Builder &, const std::string &); +public: virtual ~Package() { } -protected: - Builder &builder; - std::string name; + const std::string &get_name() const { return name; } + Builder &get_builder() const { return builder; } + const PackageList &get_required_packages() const { return requires; } - PackageList requires; - BuildInfo export_binfo; - bool conf_done; + const BuildInfo &get_exported_build_info() const { return export_binfo; } - bool use_pkgconfig; + /// Indicates whether or not this package supports pkg-config + bool get_use_pkgconfig() const { return use_pkgconfig; } - Package(Builder &, const std::string &); - virtual void do_configure(const StringMap &, unsigned) { } + /** 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() { } + +public: + virtual void save_caches() { } }; #endif