]> git.tdb.fi Git - builder.git/blobdiff - source/builder.h
Refactor code to get rid of class PackageRef
[builder.git] / source / builder.h
index 21973eb1fe407585d6db8cee6f73859b586ca7e3..6da42a1a90e94c55ca080157c3ae6fcdba1a31d2 100644 (file)
@@ -1,3 +1,10 @@
+/* $Id$
+
+This file is part of builder
+Copyright © 2006-2007 Mikko Rasa, Mikkosoft Productions
+Distributed under the LGPL
+*/
+
 #ifndef BUILDER_H_
 #define BUILDER_H_
 
@@ -5,7 +12,7 @@
 #include <map>
 #include <string>
 #include <msp/core/application.h>
-#include <msp/parser/loader.h>
+#include <msp/datafile/loader.h>
 #include <msp/path/path.h>
 #include "config.h"
 #include "misc.h"
@@ -14,6 +21,7 @@
 class Analyzer;
 class Config;
 class Package;
+class SourcePackage;
 
 /**
 The main application class.  Controls and owns everything.  Rules the world.
@@ -26,8 +34,9 @@ public:
        bool     get_dry_run() const   { return dry_run; }
        bool     get_build_all() const { return build_all; }
        Package  *get_package(const std::string &);
-       Package  *get_default_package() const { return default_pkg; }
+       SourcePackage *get_default_package() const { return default_pkg; }
        Target   *get_target(const std::string &) const;
+       const TargetMap &get_targets() const { return targets; }
        Target   *get_header(const std::string &, const std::string &, const std::string &, const StringList &);
        Target   *get_library(const std::string &, const std::string &, const StringList &, LibMode);
        const Msp::Path::Path &get_cwd() const { return cwd; }
@@ -40,7 +49,7 @@ public:
 
        static void usage(const char *, const char *, bool);
 private:
-       class Loader: public Msp::Parser::Loader
+       class Loader: public Msp::DataFile::Loader
        {
        public:
                Loader(Builder &, const Msp::Path::Path &);
@@ -48,12 +57,24 @@ private:
                Builder         &bld;
                Msp::Path::Path src;
 
+               void architecture(const std::string &, const std::string &);
+               void binpkg(const std::string &);
+               void profile(const std::string &);
                void package(const std::string &);
        };
 
+       class ProfileLoader: public Msp::DataFile::Loader
+       {
+       public:
+               ProfileLoader(StringMap &);
+       private:
+               StringMap &profile;
+
+               void option(const std::string &, const std::string &);
+       };
+
        typedef std::list<Package *>               PackageList;
        typedef std::map<std::string, Package *>   PackageMap;
-       typedef std::map<std::string, Target *>    TargetMap;
        typedef std::map<std::string, StringMap>   ToolMap;
        typedef std::map<std::string, StringMap>   ProfileTemplateMap;
 
@@ -62,8 +83,7 @@ private:
        Msp::Path::Path cwd;
 
        PackageMap   packages;
-       PackageList  new_pkgs;
-       Package      *default_pkg;
+       SourcePackage *default_pkg;
 
        TargetMap    targets;
        TargetList   new_tgts;