X-Git-Url: https://git.saurik.com/apt.git/blobdiff_plain/98136088cd0f111938b9a896395cae36d972d019..995a4bf6d770a5cc824c38388909f23fcca558c3:/methods/copy.cc diff --git a/methods/copy.cc b/methods/copy.cc index 5570f31c8..373ad3604 100644 --- a/methods/copy.cc +++ b/methods/copy.cc @@ -27,25 +27,18 @@ class CopyMethod : public pkgAcqMethod { - virtual bool Fetch(FetchItem *Itm); - void CalculateHashes(FetchResult &Res); + 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(FetchResult &Res) +void CopyMethod::CalculateHashes(FetchItem const * const Itm, FetchResult &Res) { - // For gzip indexes we need to look inside the gzip for the hash - // We can not use the extension here as its not used in partial - // on a IMS hit - FileFd::OpenMode OpenMode = FileFd::ReadOnly; - if (_config->FindB("Acquire::GzipIndexes", false) == true) - OpenMode = FileFd::ReadOnlyGzip; - - Hashes Hash; - FileFd Fd(Res.Filename, OpenMode); + Hashes Hash(Itm->ExpectedHashes); + FileFd Fd(Res.Filename, FileFd::ReadOnly); Hash.AddFD(Fd); Res.TakeHashes(Hash); } @@ -55,8 +48,8 @@ void CopyMethod::CalculateHashes(FetchResult &Res) /* */ bool CopyMethod::Fetch(FetchItem *Itm) { - URI Get = Itm->Uri; - std::string File = Get.Path; + // this ensures that relative paths work in copy + std::string const File = Itm->Uri.substr(Itm->Uri.find(':')+1); // Stat the file and send a start message struct stat Buf; @@ -68,13 +61,13 @@ bool CopyMethod::Fetch(FetchItem *Itm) Res.Size = Buf.st_size; Res.Filename = Itm->DestFile; Res.LastModified = Buf.st_mtime; - Res.IMSHit = false; + Res.IMSHit = false; URIStart(Res); - + // just calc the hashes if the source and destination are identical - if (File == Itm->DestFile) + if (File == Itm->DestFile || Itm->DestFile == "/dev/null") { - CalculateHashes(Res); + CalculateHashes(Itm, Res); URIDone(Res); return true; } @@ -107,7 +100,7 @@ bool CopyMethod::Fetch(FetchItem *Itm) if (utimes(Res.Filename.c_str(), times) != 0) return _error->Errno("utimes",_("Failed to set modification time")); - CalculateHashes(Res); + CalculateHashes(Itm, Res); URIDone(Res); return true; @@ -119,5 +112,6 @@ int main() setlocale(LC_ALL, ""); CopyMethod Mth; + return Mth.Run(); }