]> git.tdb.fi Git - builder.git/blobdiff - source/copy.cpp
Add missing includes
[builder.git] / source / copy.cpp
index c9cb3112ac25465d81ddf3a098eacbb5e46003ed..8d18ec8001279403bc827926da8203e507671f28 100644 (file)
@@ -1,5 +1,6 @@
 #include <errno.h>
 #include <fstream>
+#include <iostream>
 #include <msp/path/utils.h>
 #include "builder.h"
 #include "copy.h"
@@ -12,27 +13,40 @@ Copy::Copy(Builder &b, const Package &pkg, const Path::Path &s, const Path::Path
        Action(b),
        src(s),
        dest(d),
-       worker(*this)
+       worker(0)
 {
-       announce(pkg.get_name(), "INST", dest[-1]);
+       announce(pkg.get_name(), "COPY", dest[-1]);
        if(builder.get_verbose()>=2)
                cout<<s<<" -> "<<d<<'\n';
+       
+       if(!builder.get_dry_run())
+               worker=new Worker(*this);
 }
 
 int Copy::check()
 {
-       if(worker.get_done())
+       if(!worker)
+               return 0;
+       
+       if(worker->get_done())
        {
                signal_done.emit();
-               worker.join();
-               return worker.get_error()?1:0;
+               worker->join();
+               return worker->get_error()?1:0;
        }
+       
        return -1;
 }
 
+Copy::~Copy()
+{
+       delete worker;
+}
+
 void Copy::Worker::main()
 {
-       Path::mkpath(copy.src.subpath(0, copy.src.size()-1), 0755);
+       Path::mkpath(copy.dest.subpath(0, copy.dest.size()-1), 0755);
+       
        if(unlink(copy.dest.str().c_str())<0 && errno!=ENOENT)
        {
                int err=errno;