X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Ffiletarget.h;h=aff1fb7a4081cad3bddb098281389bbe63d9861f;hb=d1f9551e05c9d341149eb490e05b1465d3d6b711;hp=52551e4ed90de64540c3bbc1f5084cf9a40513e5;hpb=43bd25ffcb0b4f7882773f4676b209a99cb73c04;p=builder.git diff --git a/source/filetarget.h b/source/filetarget.h index 52551e4..aff1fb7 100644 --- a/source/filetarget.h +++ b/source/filetarget.h @@ -13,21 +13,42 @@ 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: + FileTarget(Builder &, const SourcePackage *, const Msp::FS::Path &); + void stat(); + static std::string generate_name(Builder &, const SourcePackage *, const Msp::FS::Path &); - FileTarget(Builder &, const Package *, const Msp::FS::Path &); public: const Msp::FS::Path &get_path() const { return path; } const Msp::Time::TimeStamp &get_mtime() const { return mtime; } unsigned get_size() const { return size; } - /** - Changes the mtime of the target to the current time. - */ + 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. 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: + void clean() override; }; #endif