X-Git-Url: https://git.saurik.com/apt.git/blobdiff_plain/af9e40c9bfb353b8aea1e2621b3b5a8c1c1db4bd..8d1cb6da6e21302c654da3f09de3975af7e4a11f:/methods/copy.cc?ds=inline diff --git a/methods/copy.cc b/methods/copy.cc index 373ad3604..5e3654389 100644 --- a/methods/copy.cc +++ b/methods/copy.cc @@ -13,10 +13,10 @@ #include #include -#include #include #include #include +#include "aptmethod.h" #include #include @@ -25,23 +25,14 @@ #include /*}}}*/ -class CopyMethod : public pkgAcqMethod +class CopyMethod : public aptMethod { virtual bool Fetch(FetchItem *Itm) APT_OVERRIDE; - void CalculateHashes(FetchItem const * const Itm, FetchResult &Res); - + public: - - CopyMethod() : pkgAcqMethod("1.0",SingleInstance | SendConfig) {}; -}; -void CopyMethod::CalculateHashes(FetchItem const * const Itm, FetchResult &Res) -{ - Hashes Hash(Itm->ExpectedHashes); - FileFd Fd(Res.Filename, FileFd::ReadOnly); - Hash.AddFD(Fd); - Res.TakeHashes(Hash); -} + CopyMethod() : aptMethod("copy", "1.0",SingleInstance | SendConfig) {}; +}; // CopyMethod::Fetch - Fetch a file /*{{{*/ // --------------------------------------------------------------------- @@ -76,12 +67,7 @@ bool CopyMethod::Fetch(FetchItem *Itm) FileFd From(File,FileFd::ReadOnly); FileFd To(Itm->DestFile,FileFd::WriteAtomic); To.EraseOnFailure(); - if (_error->PendingError() == true) - { - To.OpFail(); - return false; - } - + // Copy the file if (CopyFile(From,To) == false) { @@ -101,7 +87,6 @@ bool CopyMethod::Fetch(FetchItem *Itm) return _error->Errno("utimes",_("Failed to set modification time")); CalculateHashes(Itm, Res); - URIDone(Res); return true; } @@ -109,9 +94,5 @@ bool CopyMethod::Fetch(FetchItem *Itm) int main() { - setlocale(LC_ALL, ""); - - CopyMethod Mth; - - return Mth.Run(); + return CopyMethod().Run(); }