]> git.tdb.fi Git - builder.git/blobdiff - source/component.h
Migrate from msppath to mspfs
[builder.git] / source / component.h
index e1df73a5b232aefd9c554010b2767f9f7697c297..6fb231d1d247899103172aaab1720c06377cdbd8 100644 (file)
@@ -1,14 +1,21 @@
+/* $Id$
+
+This file is part of builder
+Copyright © 2006-2007 Mikko Rasa, Mikkosoft Productions
+Distributed under the LGPL
+*/
+
 #ifndef COMPONENT_H_
 #define COMPONENT_H_
 
 #include <string>
-#include <msp/parser/loader.h>
-#include <msp/path/path.h>
+#include <msp/datafile/loader.h>
+#include <msp/fs/path.h>
 #include "buildinfo.h"
 #include "misc.h"
-#include "packageref.h"
+#include "package.h"
 
-class Package;
+class SourcePackage;
 
 /**
 Components specify things to be built.  Each component may build one binary (it
@@ -20,7 +27,7 @@ class Component
 {
 public:
        /// Loads a Component from file.  Used from Package::Loader.
-       class Loader: public Msp::Parser::Loader
+       class Loader: public Msp::DataFile::Loader
        {
        public:
                Loader(Component &);
@@ -34,7 +41,7 @@ public:
                void host(const std::string &);
                void build_info();
        };
-       
+
        enum Type
        {
                PROGRAM,
@@ -43,8 +50,8 @@ public:
                HEADERS
        };
 
-       Component(Package &, Type, const std::string &);
-       const Package     &get_package() const         { return pkg; }
+       Component(SourcePackage &, Type, const std::string &);
+       const SourcePackage &get_package() const       { return pkg; }
        Type              get_type() const             { return type; }
        const std::string &get_name() const            { return name; }
        const PathList    &get_sources() const         { return sources; }
@@ -52,11 +59,12 @@ public:
        bool              get_install() const          { return install; }
        const std::string &get_install_headers() const { return install_headers; }
        bool              get_modular() const          { return modular; }
-       const PkgRefList  &get_requires() const        { return requires; }
-       void              resolve_refs();
+       const PackageList &get_requires() const        { return requires; }
+       bool              get_default() const          { return deflt; }
        void              create_build_info();
+       void              create_targets() const;
 protected:
-       Package     &pkg;
+       SourcePackage &pkg;
        Type        type;
        std::string name;
        PathList    sources;
@@ -65,7 +73,10 @@ protected:
        const Component *module_host;
        bool        modular;
        BuildInfo   build_info;
-       PkgRefList  requires;
+       PackageList requires;
+       bool        deflt;
+
+       PathList    collect_source_files() const;
 };
 typedef std::list<Component> ComponentList;