X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Fcopy.cpp;h=53118de754963dc04095c11be4107a49c0ca9ab2;hb=8a98d59b2b4954f51eb3f649d3675af976154de6;hp=010d54113d74a859e9eb6e8416ca0e11e501790b;hpb=5006279d7b92e578ecfa8a04186f675c6b9f1eea;p=builder.git diff --git a/source/copy.cpp b/source/copy.cpp index 010d541..53118de 100644 --- a/source/copy.cpp +++ b/source/copy.cpp @@ -1,11 +1,7 @@ -/* $Id$ - -This file is part of builder -Copyright © 2006-2009 Mikko Rasa, Mikkosoft Productions -Distributed under the LGPL -*/ - -#include +#ifndef _WIN32 +#include +#include +#endif #include #include #include @@ -13,73 +9,79 @@ Distributed under the LGPL #include #include "builder.h" #include "copy.h" -#include "package.h" +#include "installedfile.h" using namespace std; using namespace Msp; -Copy::Copy(Builder &b, const Package &pkg, const FS::Path &s, const FS::Path &d): - InternalAction(b), - src(s), - dest(d) -{ - announce(pkg.get_name(), "COPY", dest[-1]); - if(builder.get_verbose()>=2) - IO::print("%s -> %s\n", s, d); +Copy::Copy(Builder &b): + Tool(b, "CP") +{ } - if(!builder.get_dry_run()) - worker=new Worker(*this); +Target *Copy::create_target(const list &sources, const string &arg) +{ + FileTarget &file_tgt = dynamic_cast(*sources.front()); + InstalledFile *inst = new InstalledFile(builder, *file_tgt.get_package(), file_tgt, arg); + inst->set_tool(*this); + return inst; } - -Copy::Worker::Worker(Copy &c): - copy(c) +Task *Copy::run(const Target &target) const { - launch(); + const InstalledFile &install = dynamic_cast(target); + Worker *worker = new Worker(install); + InternalTask *task = new InternalTask(worker); + task->add_file(install.get_path()); + task->set_unlink(); + return task; } + +Copy::Worker::Worker(const InstalledFile &t): + target(t) +{ } + 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; - } - } + const FileTarget &source = target.get_source(); + const FS::Path &src_path = source.get_path(); + const FS::Path &dst_path = target.get_path(); try { - IO::File in(copy.src.str()); - IO::File out(copy.dest.str(), IO::M_WRITE); + IO::File in(src_path.str()); + IO::File out(dst_path.str(), IO::M_WRITE); // Actual transfer loop char buf[16384]; while(!in.eof()) { - unsigned len=in.read(buf, sizeof(buf)); + unsigned len = in.read(buf, sizeof(buf)); out.write(buf, len); } } - catch(const Exception &e) + catch(const exception &e) { IO::print(IO::cerr, "%s\n", e.what()); - done=error=true; + status = Task::ERROR; return; } +#ifndef _WIN32 // Preserve file permissions - struct stat st=FS::stat(copy.src); - chmod(copy.dest.str().c_str(), st.st_mode&0777); + struct stat st; + if(stat(src_path.str().c_str(), &st)==0) + chmod(dst_path.str().c_str(), st.st_mode&0777); + + const FS::Path &link = target.get_symlink(); + if(!link.empty()) + { + FS::Path relpath = FS::relative(dst_path, FS::dirname(link)); + if(FS::exists(link)) + FS::unlink(link); + symlink(relpath.str().c_str(), link.str().c_str()); + } +#endif - done=true; + status = Task::SUCCESS; }