X-Git-Url: https://git.saurik.com/apt.git/blobdiff_plain/7f25bdff3a0fa55ba897964d5c82475b45f3325a..fc81e8f2deff3b86738cad78aa491b1b514b3c59:/methods/file.cc diff --git a/methods/file.cc b/methods/file.cc index f2bcf371a..9cdd5bc2d 100644 --- a/methods/file.cc +++ b/methods/file.cc @@ -1,6 +1,6 @@ // -*- mode: cpp; mode: fold -*- // Description /*{{{*/ -// $Id: file.cc,v 1.7 1999/01/18 06:20:08 jgg Exp $ +// $Id: file.cc,v 1.9.2.1 2004/01/16 18:58:50 mdz Exp $ /* ###################################################################### File URI method for APT @@ -15,9 +15,12 @@ // Include Files /*{{{*/ #include #include +#include +#include #include #include +#include /*}}}*/ class FileMethod : public pkgAcqMethod @@ -38,7 +41,7 @@ bool FileMethod::Fetch(FetchItem *Itm) string File = Get.Path; FetchResult Res; if (Get.Host.empty() == false) - return _error->Error("Invalid URI, local URIS must not start with //"); + return _error->Error(_("Invalid URI, local URIS must not start with //")); // See if the file exists struct stat Buf; @@ -48,7 +51,7 @@ bool FileMethod::Fetch(FetchItem *Itm) Res.Filename = File; Res.LastModified = Buf.st_mtime; Res.IMSHit = false; - if (Itm->LastModified == Buf.st_mtime) + if (Itm->LastModified == Buf.st_mtime && Itm->LastModified != 0) Res.IMSHit = true; } @@ -64,7 +67,7 @@ bool FileMethod::Fetch(FetchItem *Itm) AltRes.Filename = File; AltRes.LastModified = Buf.st_mtime; AltRes.IMSHit = false; - if (Itm->LastModified == Buf.st_mtime) + if (Itm->LastModified == Buf.st_mtime && Itm->LastModified != 0) AltRes.IMSHit = true; URIDone(Res,&AltRes); @@ -73,8 +76,12 @@ bool FileMethod::Fetch(FetchItem *Itm) } if (Res.Filename.empty() == true) - return _error->Error("File not found"); - + return _error->Error(_("File not found")); + + Hashes Hash; + FileFd Fd(Res.Filename, FileFd::ReadOnly); + Hash.AddFD(Fd.Fd(), Fd.Size()); + Res.TakeHashes(Hash); URIDone(Res); return true; } @@ -82,6 +89,8 @@ bool FileMethod::Fetch(FetchItem *Itm) int main() { + setlocale(LC_ALL, ""); + FileMethod Mth; return Mth.Run(); }