X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpackage.h;h=90ee6bc510abc941262d884146c6d053db32f522;hb=8bc8db44c47cd2906c57dccbfb589e41eff7f694;hp=68e0c224c2116126d29ec620e44fe71a4bab5242;hpb=09325a99816a966bc17a0ec9a0a197efc6ce0349;p=builder.git diff --git a/source/package.h b/source/package.h index 68e0c22..90ee6bc 100644 --- a/source/package.h +++ b/source/package.h @@ -1,12 +1,22 @@ +/* $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 "component.h" +#include "condition.h" #include "config.h" +#include "dependencycache.h" +#include "feature.h" #include "packageref.h" class Builder; @@ -17,8 +27,7 @@ typedef std::list PackageList; /** A package is a distributable piece of software. They consist of one or more Components and may depend on other packages. Packages also have configuration -to determine where files are installed and which features to include (features -NYI). +to determine where files are installed and which features to include. */ class Package { @@ -32,7 +41,7 @@ public: }; /// Loads a package from a file. - class Loader: public Msp::Parser::Loader + class Loader: public Msp::DataFile::Loader { public: Loader(Package &); @@ -41,11 +50,14 @@ public: Package &pkg; void require(const std::string &); + void feature(const std::string &, const std::string &); + void condition(const std::string &); void program(const std::string &); void library(const std::string &); void module(const std::string &); void headers(const std::string &); void build_info(); + void tar_file(const std::string &); }; Package(Builder &, const std::string &, const Msp::Path::Path &); @@ -69,8 +81,10 @@ public: bool get_use_pkgconfig() const { return use_pkgconfig; } const std::string &get_arch() const { return config.get_option("arch").value; } LibMode get_library_mode() const; + const PathList &get_tar_files() const { return tar_files; } + DependencyCache &get_deps_cache() const { return deps_cache; } void resolve_refs(); - void configure(const RawOptionMap &, unsigned); + void configure(const StringMap &, unsigned); static Package *create(Builder &, const std::string &); private: @@ -84,11 +98,15 @@ private: Msp::Path::Path source; PkgRefList requires; PackageList all_reqs; + FeatureList features; BuildInfo build_info; BuildInfo export_binfo; + ConditionList conditions; ComponentList components; Config config; bool conf_done; + mutable DependencyCache deps_cache; + PathList tar_files; bool use_pkgconfig; bool need_path;