X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fcopy.h;h=dedd0f57a0e3aa41607d67b0f6d16c10c6fa799a;hb=bc85cc286c8a3f1055f1979a7ff8697cf1b61912;hp=018b3de8e6cac0b0df823403353a13568a40284b;hpb=f1c967215e6b08095bdf07518472beca3067ec37;p=builder.git diff --git a/source/copy.h b/source/copy.h index 018b3de..dedd0f5 100644 --- a/source/copy.h +++ b/source/copy.h @@ -2,35 +2,37 @@ #define COPY_H_ #include -#include -#include "action.h" +#include +#include "internaltask.h" +#include "tool.h" -class Package; +class InstalledFile; -class Copy: public Action +/** +Copies a file to another place. Used by the InstalledFile target. +*/ +class Copy: public Tool { -public: - Copy(Builder &, const Package &, const Msp::Path::Path &, const Msp::Path::Path &); - int check(); - ~Copy(); private: - class Worker: public Msp::Thread + /** + A worker thread that actually does the data transfer. + */ + class Worker: public InternalTask::Worker { - public: - Worker(Copy &i): copy(i), done(false), error(false) { launch(); } - bool get_done() const { return done; } - bool get_error() const { return error; } private: - Copy © - bool done; - bool error; + const InstalledFile ⌖ - void main(); + public: + Worker(const InstalledFile &); + private: + virtual void main(); }; - Msp::Path::Path src; - Msp::Path::Path dest; - Worker *worker; +public: + Copy(Builder &); + + virtual Target *create_target(const std::list &, const std::string &); + virtual Task *run(const Target &) const; }; #endif