X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Ffiletarget.h;h=aff1fb7a4081cad3bddb098281389bbe63d9861f;hb=d1f9551e05c9d341149eb490e05b1465d3d6b711;hp=2319066b05acbb6994cc2082365ad8fd06449091;hpb=8818c970f123a7fa44bf41bc60369217d083b4da;p=builder.git diff --git a/source/filetarget.h b/source/filetarget.h index 2319066..aff1fb7 100644 --- a/source/filetarget.h +++ b/source/filetarget.h @@ -13,13 +13,17 @@ class FileTarget: public Target protected: Msp::FS::Path path; Msp::Time::TimeStamp mtime; - unsigned size; + unsigned size = 0; Msp::FS::Path install_location; + std::string install_filename; + bool nested_build_sig = false; + bool arch_in_build_sig = false; FileTarget(Builder &, const Msp::FS::Path &); FileTarget(Builder &, const SourcePackage &, const Msp::FS::Path &); private: - void init(const SourcePackage *); + FileTarget(Builder &, const SourcePackage *, const Msp::FS::Path &); + void stat(); static std::string generate_name(Builder &, const SourcePackage *, const Msp::FS::Path &); public: @@ -29,17 +33,22 @@ public: bool is_installable() const { return !install_location.empty(); } const Msp::FS::Path &get_install_location() const { return install_location; } + const std::string &get_install_filename() const { return install_filename; } - /** - Changes the mtime of the target to the current time. - */ + /// Changes the mtime of the target to the current time. void touch(); protected: - virtual void check_rebuild(); + void check_rebuild() override; + + virtual std::string create_build_signature() const; + + void build(Task &) override; + + void build_finished(bool) override; public: - virtual Task *build(); + void clean() override; }; #endif