]> git.tdb.fi Git - builder.git/blobdiff - source/target.h
Builder can build itself now.
[builder.git] / source / target.h
index 21135b03970aa96a7b0641e096b4cba6b513860a..371445bc5007ebc4e7c3d4af6c525c7c79bd2231 100644 (file)
@@ -5,20 +5,9 @@
 #include <string>
 #include <msp/time/timestamp.h>
 
+class Action;
 class Builder;
 class Package;
-class Target;
-
-class TargetRef
-{
-public:
-       TargetRef(Builder &b, const std::string &n): builder(b), name(n) { }
-       Target *get_target();
-private:
-       Builder &builder;
-       std::string name;
-       Target *target;
-};
 
 class Target
 {
@@ -27,9 +16,14 @@ public:
        Target *get_buildable_target();
        bool   get_rebuild() const { return rebuild; }
        const std::string &get_rebuild_reason() const { return rebuild_reason; }
-       virtual void find_depends()=0;
-       void   add_depend(Target *);
+       const Msp::Time::TimeStamp &get_mtime() const { return mtime; }
+       const Msp::Time::TimeStamp &get_virtual_mtime() const { return vmtime; }
        virtual const char *get_type() const=0;
+       const std::list<Target *> &get_depends() const { return depends; }
+       void   add_depend(Target *);
+       virtual void find_depends()=0;
+       virtual void prepare();
+       virtual Action *build()=0;
        virtual ~Target() { }
 protected:
        Builder     &builder;
@@ -39,12 +33,17 @@ protected:
        bool        rebuild;
        std::string rebuild_reason;
        Msp::Time::TimeStamp mtime;
+       Msp::Time::TimeStamp vmtime;
        std::list<Target *> depends;
        std::list<Target *> rdepends;
-       bool        ready_for_build;
+       bool        prepared;
+       bool        buildable;
 
        Target(Builder &, const Package *, const std::string &);
        void mark_rebuild(const std::string &);
+       virtual void check_rebuild();
+       Action *build(Action *);
+       virtual void build_done();
 };
 
 #endif