X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fpackage.h;h=3d980f26ab19d501adf1486df69a25a6962a8943;hb=74266a6e650f019063cdcd1c9a7bd26d8f99041b;hp=eee157234f6df23b6ec4acbc912bd4bc22e53dee;hpb=683301f94f4a3c5b7e2a7f21087f4185b07c4858;p=builder.git diff --git a/source/package.h b/source/package.h index eee1572..3d980f2 100644 --- a/source/package.h +++ b/source/package.h @@ -7,26 +7,20 @@ #include "buildinfo.h" #include "component.h" #include "config.h" +#include "packageref.h" class Builder; -class Package; - -class PackageRef -{ -public: - PackageRef(Builder &, const std::string &); - const std::string &get_name() const { return name; } - Package *get_package() const { return package; } - Package *resolve(); -private: - Builder &builder; - std::string name; - Package *package; -}; +/** +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). +*/ class Package { public: + /// Loads a package from a file. class Loader: public Msp::Parser::Loader { public: @@ -44,15 +38,17 @@ public: }; Package(Builder &, const std::string &, const Msp::Path::Path &); - Package(Builder &, const std::string &, const std::vector &); - const std::string &get_name() const { return name; } - const Msp::Path::Path &get_source() const { return source; } - const ComponentList &get_components() const { return components; } - bool get_buildable() const { return buildable; } - const Config &get_config() const { return config; } - const std::list &get_requires() const { return requires; } - const BuildInfo &get_build_info() const { return build_info; } + void set_path(const Msp::Path::Path &); + const std::string &get_name() const { return name; } + const Msp::Path::Path &get_source() const { return source; } + const ComponentList &get_components() const { return components; } + bool get_buildable() const { return buildable; } + const Config &get_config() const { return config; } + const PkgRefList &get_requires() const { return requires; } + const BuildInfo &get_build_info() const { return build_info; } const BuildInfo &get_exported_binfo() const { return export_binfo; } + Builder &get_builder() const { return builder; } + bool get_need_path() const { return need_path; } void resolve_refs(); void create_build_info(); void process_options(const RawOptionMap &); @@ -68,19 +64,25 @@ private: }; Builder &builder; + std::string name; std::string version; std::string description; - std::list requires; + + bool buildable; + Msp::Path::Path source; + PkgRefList requires; BuildInfo build_info; BuildInfo export_binfo; - Msp::Path::Path source; - bool buildable; ComponentList components; Config config; bool build_info_ready; - void init_buildable(); + bool need_path; + Msp::Path::Path path; + + Package(Builder &, const std::string &, const std::vector &); + void init_buildable(); unsigned get_install_flags(); };