X-Git-Url: https://git.saurik.com/apt.git/blobdiff_plain/93bf083d699c60f1ac40297bfa6783fb0cb800d8..2a49601f69e08f06fb2727d869d420daacdd09d5:/methods/copy.cc diff --git a/methods/copy.cc b/methods/copy.cc index e63801f38..e81d0022b 100644 --- a/methods/copy.cc +++ b/methods/copy.cc @@ -1,6 +1,6 @@ // -*- mode: cpp; mode: fold -*- // Description /*{{{*/ -// $Id: copy.cc,v 1.4 1998/10/30 07:53:51 jgg Exp $ +// $Id: copy.cc,v 1.7.2.1 2004/01/16 18:58:50 mdz Exp $ /* ###################################################################### Copy URI - This method takes a uri like a file: uri and copies it @@ -9,18 +9,23 @@ ##################################################################### */ /*}}}*/ // Include Files /*{{{*/ +#include + #include +#include #include #include +#include #include #include #include +#include /*}}}*/ class CopyMethod : public pkgAcqMethod { - virtual bool Fetch(string Message,URI Get); + virtual bool Fetch(FetchItem *Itm); public: @@ -30,48 +35,59 @@ class CopyMethod : public pkgAcqMethod // CopyMethod::Fetch - Fetch a file /*{{{*/ // --------------------------------------------------------------------- /* */ -bool CopyMethod::Fetch(string Message,URI Get) +bool CopyMethod::Fetch(FetchItem *Itm) { - string File = Get.Path; + URI Get = Itm->Uri; + std::string File = Get.Path; + + // Stat the file and send a start message + struct stat Buf; + if (stat(File.c_str(),&Buf) != 0) + return _error->Errno("stat",_("Failed to stat")); + // Forumulate a result and send a start message + FetchResult Res; + Res.Size = Buf.st_size; + Res.Filename = Itm->DestFile; + Res.LastModified = Buf.st_mtime; + Res.IMSHit = false; + URIStart(Res); + // See if the file exists FileFd From(File,FileFd::ReadOnly); - FileFd To(DestFile,FileFd::WriteEmpty); + FileFd To(Itm->DestFile,FileFd::WriteAtomic); To.EraseOnFailure(); if (_error->PendingError() == true) + { + To.OpFail(); return false; + } // Copy the file if (CopyFile(From,To) == false) + { + To.OpFail(); return false; + } From.Close(); To.Close(); // Transfer the modification times - struct stat Buf; - if (stat(File.c_str(),&Buf) != 0) - { - To.OpFail(); - return _error->Errno("stat","Failed to stat"); - } - struct utimbuf TimeBuf; TimeBuf.actime = Buf.st_atime; TimeBuf.modtime = Buf.st_mtime; - if (utime(DestFile.c_str(),&TimeBuf) != 0) + if (utime(Itm->DestFile.c_str(),&TimeBuf) != 0) { To.OpFail(); - return _error->Errno("utime","Failed to set modification time"); + return _error->Errno("utime",_("Failed to set modification time")); } - // Forumulate a result - FetchResult Res; - Res.Size = Buf.st_size; - Res.Filename = DestFile; - Res.LastModified = Buf.st_mtime; - Res.IMSHit = false; - + Hashes Hash; + FileFd Fd(Res.Filename, FileFd::ReadOnly); + Hash.AddFD(Fd); + Res.TakeHashes(Hash); + URIDone(Res); return true; } @@ -79,6 +95,8 @@ bool CopyMethod::Fetch(string Message,URI Get) int main() { + setlocale(LC_ALL, ""); + CopyMethod Mth; return Mth.Run(); }