X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fobjectfile.h;h=48e4482d7ab4a153f251724d02f4f855c01c218c;hb=0f7867524bf87a389ff5d4f9d3290d68a254b693;hp=8b58e7a1ae93f14ecd6b4702c47c3b3af785ec19;hpb=43bd25ffcb0b4f7882773f4676b209a99cb73c04;p=builder.git diff --git a/source/objectfile.h b/source/objectfile.h index 8b58e7a..48e4482 100644 --- a/source/objectfile.h +++ b/source/objectfile.h @@ -3,7 +3,6 @@ #include "filetarget.h" -class Component; class SourceFile; /** @@ -12,31 +11,27 @@ Object files are compiled from source files. class ObjectFile: public FileTarget { private: - const Component ∁ SourceFile &source; - TargetList new_deps; - + bool used_in_shlib; + public: ObjectFile(Builder &, const Component &, SourceFile &); +private: + static Msp::FS::Path generate_target_path(const Component &, const Msp::FS::Path &); + +public: virtual const char *get_type() const { return "ObjectFile"; } - const Component &get_component() const { return comp; } 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(); + void set_used_in_shared_library(bool); + bool is_used_in_shared_library() const { return used_in_shlib; } -private: - /** Recursively looks for header targets and adds them as dependencies. */ - void find_depends(Target *); + virtual void collect_build_info(BuildInfo &) const; - /** Adds a target to the dependency list as well as the new dependencies - list. */ - void add_depend(Target *); - virtual Action *create_action(); +private: + virtual void find_dependencies(); - static Msp::FS::Path generate_target_path(const Component &, const std::string &); + void find_dependencies(FileTarget *); }; #endif