X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fobjectfile.h;h=2e9b6e1a4333074e71c18fe1502ab49661a68c13;hb=b067981c0da0c1a4616ed175d0ce8ac5564cbdbf;hp=d270529b73cdefac2ca56a5be84f40a3669f7891;hpb=4dc31cca056ea293d320928f61fef0558089d32d;p=builder.git diff --git a/source/objectfile.h b/source/objectfile.h index d270529..2e9b6e1 100644 --- a/source/objectfile.h +++ b/source/objectfile.h @@ -1,21 +1,35 @@ #ifndef OBJECTFILE_H_ #define OBJECTFILE_H_ -#include "target.h" +#include "filetarget.h" -class Component; class SourceFile; -class ObjectFile: public Target +/** +Object files are compiled from source files. +*/ +class ObjectFile: public FileTarget { +private: + SourceFile &source; + public: ObjectFile(Builder &, const Component &, SourceFile &); - const char *get_type() const { return "ObjectFile"; } - void find_depends() { } private: - const Component ∁ - - static std::string generate_target_name(const Component &, const std::string &); + static Msp::FS::Path generate_target_path(const Component &, const std::string &); + +public: + virtual const char *get_type() const { return "ObjectFile"; } + 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: + /** Recursively looks for header targets and adds them as dependencies. */ + void find_depends(FileTarget *); }; #endif