X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fcopy.cpp;h=2d2a7ca9c023c557954e05924d9181f4280dae97;hb=HEAD;hp=8ea7f3537ab32d8e84aa2a3dd2731cf32ed1df1f;hpb=f56fa0c68e0eddf1f01c9584b8761431d29e8fa1;p=builder.git diff --git a/source/copy.cpp b/source/copy.cpp deleted file mode 100644 index 8ea7f35..0000000 --- a/source/copy.cpp +++ /dev/null @@ -1,87 +0,0 @@ -#include -#include -#include -#include -#include -#include -#include -#include "builder.h" -#include "copy.h" -#include "package.h" - -using namespace std; -using namespace Msp; - -Copy::Copy(Builder &b, const Package &pkg, const FS::Path &s, const FS::Path &d, const FS::Path &l): - InternalAction(b), - src(s), - dest(d), - link(l) -{ - announce(pkg.get_name(), "COPY", dest.str()); - if(builder.get_verbose()>=2) - IO::print("%s -> %s\n", s, d); - - if(!builder.get_dry_run()) - worker = new Worker(*this); -} - - -Copy::Worker::Worker(Copy &c): - copy(c) -{ - launch(); -} - -void Copy::Worker::main() -{ - FS::mkpath(FS::dirname(copy.dest), 0755); - - // Remove old file. Not doing this would cause Bad Stuff when installing libraries. - if(FS::exists(copy.dest)) - { - try - { - unlink(copy.dest); - } - catch(const exception &e) - { - IO::print(IO::cerr, "%s\n", e.what()); - done = error = true; - return; - } - } - - try - { - IO::File in(copy.src.str()); - IO::File out(copy.dest.str(), IO::M_WRITE); - - // Actual transfer loop - char buf[16384]; - while(!in.eof()) - { - unsigned len = in.read(buf, sizeof(buf)); - out.write(buf, len); - } - } - catch(const exception &e) - { - IO::print(IO::cerr, "%s\n", e.what()); - done = error = true; - return; - } - - // Preserve file permissions - struct stat st; - if(stat(copy.src.str().c_str(), &st)==0) - chmod(copy.dest.str().c_str(), st.st_mode&0777); - - if(!copy.link.empty()) - { - FS::Path relpath = FS::relative(copy.dest, FS::dirname(copy.link)); - symlink(relpath.str().c_str(), copy.link.str().c_str()); - } - - done = true; -}