X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Ftarget.h;h=04a360dab57394ec23c305b69825a80135edcee9;hb=f5d3127099bc41f986094eb98732849ee9bfb748;hp=e4fb1f7f6f85ab1c11ab96fa954c983c7b98d9aa;hpb=445edbc3c42bbd7880cc414cf153ddfd196bfc1c;p=builder.git diff --git a/source/target.h b/source/target.h index e4fb1f7..04a360d 100644 --- a/source/target.h +++ b/source/target.h @@ -1,7 +1,15 @@ +/* $Id$ + +This file is part of builder +Copyright © 2006-2007 Mikko Rasa, Mikkosoft Productions +Distributed under the LGPL +*/ + #ifndef TARGET_H_ #define TARGET_H_ #include +#include #include #include @@ -30,13 +38,18 @@ public: const Package *get_package() const { return package; } bool get_depends_ready() const { return deps_ready; } void add_depend(Target *); - virtual void find_depends() { deps_ready=true; } virtual void prepare(); + /** + Finds dependencies for the target. When all dependencies have been found, + the function should set deps_ready to true. + */ + virtual void find_depends() { deps_ready=true; } + /** Creates and returns an Action suitable for building this target. */ - virtual Action *build()=0; + Action *build(); void reset_count() { counted=false; } virtual unsigned count_rebuild(); @@ -63,8 +76,10 @@ protected: Target(Builder &, const Package *, const std::string &); void mark_rebuild(const std::string &); virtual void check_rebuild(); - Action *build(Action *); + virtual Action *create_action() =0; virtual void build_done(); }; +typedef std::map TargetMap; + #endif