X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Flib%2Ffiletarget.h;h=4261cbb7e8617616e75b7240345457adef892cd4;hb=b4781796aa997368f46b87b73a907bcab955ca3d;hp=d2ed71954010be4e8824ceba73e9665dab8d583c;hpb=15d51a0d90acfa8f4a7799a6775d9e2ca74afb4a;p=builder.git diff --git a/source/lib/filetarget.h b/source/lib/filetarget.h index d2ed719..4261cbb 100644 --- a/source/lib/filetarget.h +++ b/source/lib/filetarget.h @@ -2,13 +2,14 @@ #define FILETARGET_H_ #include +#include "libbuilder_api.h" #include "target.h" /** An intermediate base class for targets that represent files. Almost all target classes are derived from this. */ -class FileTarget: public Target +class LIBBUILDER_API FileTarget: public Target { protected: Msp::FS::Path path; @@ -18,8 +19,8 @@ protected: bool nested_build_sig = false; bool arch_in_build_sig = false; - FileTarget(Builder &b, const Msp::FS::Path &a): FileTarget(b, 0, a) { } - FileTarget(Builder &b, const SourcePackage &p, const Msp::FS::Path &a): FileTarget(b, &p, a) { } + FileTarget(Builder &b, const Msp::FS::Path &a); + FileTarget(Builder &b, const SourcePackage &p, const Msp::FS::Path &a); private: FileTarget(Builder &, const SourcePackage *, const Msp::FS::Path &); void stat(); @@ -36,7 +37,11 @@ public: /// Changes the mtime of the target to the current time. void touch(); + FileTarget *get_real_target() override { return this; } + protected: + Target *resolve_transitive_dependency(Target &, Target &) const override; + void check_rebuild() override; virtual std::string create_build_signature() const;