]> git.tdb.fi Git - builder.git/blobdiff - source/objectfile.h
Rework the Target class hierarchy
[builder.git] / source / objectfile.h
index 42238e14b546db0c356b3be02b9d3da6a052f4ae..7cc6f604c685ef343d744d39dfb4067cde2240a2 100644 (file)
@@ -1,7 +1,14 @@
+/* $Id$
+
+This file is part of builder
+Copyright © 2006-2009  Mikko Rasa, Mikkosoft Productions
+Distributed under the LGPL
+*/
+
 #ifndef OBJECTFILE_H_
 #define OBJECTFILE_H_
 
-#include "target.h"
+#include "filetarget.h"
 
 class Component;
 class SourceFile;
@@ -9,22 +16,34 @@ class SourceFile;
 /**
 Object files are compiled from source files.
 */
-class ObjectFile: public Target
+class ObjectFile: public FileTarget
 {
+private:
+       const Component ∁
+       SourceFile &source;
+       TargetList new_deps;
+       
 public:
        ObjectFile(Builder &, const Component &, SourceFile &);
-       const char      *get_type() const      { return "ObjectFile"; }
+       virtual const char *get_type() const { return "ObjectFile"; }
        const Component &get_component() const { return comp; }
-       void            find_depends();
-       Action          *build();
+       SourceFile &get_source() const { return source; }
+
+       /** Processes as many new dependences as possible.  Some may be created on
+       the fly and can't be processed until their own dependencies are ready.  In
+       such cases this function needs to be called again. */
+       virtual void find_depends();
+
 private:
-       const Component ∁
-       TargetList      new_deps;
-       
+       /** Recursively looks for header targets and adds them as dependencies. */
        void find_depends(Target *);
+
+       /** Adds a target to the dependency list as well as the new dependencies
+       list. */
        void add_depend(Target *);
+       virtual Action *create_action();
 
-       static std::string generate_target_name(const Component &, const std::string &);
+       static Msp::FS::Path generate_target_path(const Component &, const std::string &);
 };
 
 #endif