]> git.tdb.fi Git - builder.git/blobdiff - source/package.h
Better encapsulation of config inside Package
[builder.git] / source / package.h
index 743a962f52e2750c429c6bd93299208729dde8e0..96fb6760beefe1cec0dabca79c5d2ac5c5ce378a 100644 (file)
 #include "packageref.h"
 
 class Builder;
+class Package;
 
+typedef std::list<Package *> 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).
+*/
 class Package
 {
 public:
+       enum InstallFlags
+       {
+               INCLUDE=1,
+               BIN=2,
+               LIB=4,
+               DATA=8
+       };
+
+       /// Loads a package from a file.
        class Loader: public Msp::Parser::Loader
        {
        public:
                Loader(Package &);
                Package &get_object() { return pkg; }
-               ~Loader();
        private:
                Package &pkg;
                
@@ -33,7 +50,12 @@ public:
        Package(Builder &, const std::string &, const Msp::Path::Path &);
        void                set_path(const Msp::Path::Path &);
        const std::string   &get_name() const           { return name; }
+       const std::string   &get_version() const        { return version; }
+       const std::string   &get_description() const    { return description; }
        const Msp::Path::Path &get_source() const       { return source; }
+       Msp::Path::Path     get_temp_dir() const;
+       Msp::Path::Path     get_out_dir() const;
+       Msp::Path::Path     get_prefix() const          { return config.get_option("prefix").value; }
        const ComponentList &get_components() const     { return components; }
        bool                get_buildable() const       { return buildable; }
        const Config        &get_config() const         { return config; }
@@ -42,20 +64,15 @@ public:
        const BuildInfo     &get_exported_binfo() const { return export_binfo; }
        Builder             &get_builder() const        { return builder; }
        bool                get_need_path() const       { return need_path; }
+       unsigned            get_install_flags();
+       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;
        void                resolve_refs();
-       void                create_build_info();
-       void                process_options(const RawOptionMap &);
+       void                configure(const RawOptionMap &, unsigned);
 
        static Package *create(Builder &, const std::string &);
 private:
-       enum InstallFlags
-       {
-               INCLUDE=1,
-               BIN=2,
-               LIB=4,
-               DATA=8
-       };
-       
        Builder       &builder;
        
        std::string   name;
@@ -65,18 +82,20 @@ private:
        bool          buildable;
        Msp::Path::Path source;
        PkgRefList    requires;
+       PackageList   all_reqs;
        BuildInfo     build_info;
        BuildInfo     export_binfo;
        ComponentList components;
        Config        config;
-       bool          build_info_ready;
+       bool          conf_done;
 
+       bool          use_pkgconfig;
        bool          need_path;
        Msp::Path::Path path;
 
        Package(Builder &, const std::string &, const std::vector<std::string> &);
-       void    init_buildable();
-       unsigned get_install_flags();
+       void     init_config();
+       void     create_build_info();
 };
 
 #endif