X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fcopy.h;h=dedd0f57a0e3aa41607d67b0f6d16c10c6fa799a;hb=6382743d26f8d5bb10a53cb907659bee6614b549;hp=4e232166c0883c1e18575b6a731872c3dead685f;hpb=74266a6e650f019063cdcd1c9a7bd26d8f99041b;p=builder.git diff --git a/source/copy.h b/source/copy.h index 4e23216..dedd0f5 100644 --- a/source/copy.h +++ b/source/copy.h @@ -2,41 +2,37 @@ #define COPY_H_ #include -#include -#include "action.h" +#include +#include "internaltask.h" +#include "tool.h" -class Package; +class InstalledFile; /** -Copies a file to another place. Used by the Install target. +Copies a file to another place. Used by the InstalledFile target. */ -class Copy: public Action +class Copy: public Tool { -public: - Copy(Builder &, const Package &, const Msp::Path::Path &, const Msp::Path::Path &); - int check(); - ~Copy(); private: /** A worker thread that actually does the data transfer. */ - class Worker: public Msp::Thread + 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