X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fbuilder.h;h=44bf878b4efa1e1b24d4793b669a1b08e5b342dc;hb=0c83b922e56976a30506d9f8d43c9dcd38d573b5;hp=a4fc14b5d8b8343c99ca7fbacb0db7faafe7a73b;hpb=409a427f912f9c203b102beed0816b53b250931f;p=builder.git diff --git a/source/builder.h b/source/builder.h index a4fc14b..44bf878 100644 --- a/source/builder.h +++ b/source/builder.h @@ -1,10 +1,3 @@ -/* $Id$ - -This file is part of builder -Copyright © 2006-2010 Mikko Rasa, Mikkosoft Productions -Distributed under the LGPL -*/ - #ifndef BUILDER_H_ #define BUILDER_H_ @@ -59,6 +52,10 @@ private: void option(const std::string &, const std::string &); }; +public: + typedef std::map TargetMap; + +private: typedef std::list PackageList; typedef std::map PackageMap; typedef std::map ProfileTemplateMap; @@ -74,6 +71,7 @@ private: bool no_externals; TargetMap targets; + TargetMap targets_by_path; TargetList new_tgts; TargetMap includes; TargetMap libraries; @@ -124,6 +122,8 @@ public: /** Looks up a target by name. Returns 0 if no such target exists. */ Target *get_target(const std::string &) const; + FileTarget *get_target_by_path(const Msp::FS::Path &) const; + const TargetMap &get_targets() const { return targets; } /** Tries to locate a header based on location of including file and include @@ -148,8 +148,8 @@ public: /** Adds a target to both the target map and the new target queue. Called from Target constructor. */ - void add_target(FileTarget *); - void add_target(VirtualTarget *); + void add_target(Target *); + void register_path(const Msp::FS::Path &, FileTarget *); void problem(const std::string &, const std::string &);