]> git.saurik.com Git - apt.git/commitdiff
Alfredo Patch
authorArch Librarian <arch@canonical.com>
Mon, 20 Sep 2004 16:57:07 +0000 (16:57 +0000)
committerArch Librarian <arch@canonical.com>
Mon, 20 Sep 2004 16:57:07 +0000 (16:57 +0000)
Author: jgg
Date: 2001-03-06 03:11:22 GMT
Alfredo Patch

methods/gzip.cc

index 78b196115aafae26819414dd8345e090ac83fa74..f58a7263dc958448afa41b4ebab885e45bf01236 100644 (file)
@@ -1,6 +1,6 @@
 // -*- mode: cpp; mode: fold -*-
 // Description                                                         /*{{{*/
-// $Id: gzip.cc,v 1.10 2000/03/18 07:39:33 jgg Exp $
+// $Id: gzip.cc,v 1.11 2001/03/06 03:11:22 jgg Exp $
 /* ######################################################################
 
    GZip method - Take a file URI in and decompress it into the target 
@@ -26,7 +26,7 @@ class GzipMethod : public pkgAcqMethod
    
    public:
    
-   GzipMethod() : pkgAcqMethod("1.0",SingleInstance | SendConfig) {};
+   GzipMethod() : pkgAcqMethod("1.1",SingleInstance | SendConfig) {};
 };
 
 // GzipMethod::Fetch - Decompress the passed URI                       /*{{{*/
@@ -36,6 +36,7 @@ bool GzipMethod::Fetch(FetchItem *Itm)
 {
    URI Get = Itm->Uri;
    string Path = Get.Host + Get.Path; // To account for relative paths
+   string GzipPath = _config->Find("Dir::bin::gzip","gzip");
    
    FetchResult Res;
    Res.Filename = Itm->DestFile;
@@ -51,7 +52,7 @@ bool GzipMethod::Fetch(FetchItem *Itm)
    // Fork gzip
    int Process = fork();
    if (Process < 0)
-      return _error->Errno("fork","Couldn't fork gzip");
+      return _error->Errno("fork",string("Couldn't fork "+GzipPath).c_str());
    
    // The child
    if (Process == 0)
@@ -64,7 +65,7 @@ bool GzipMethod::Fetch(FetchItem *Itm)
       SetCloseExec(STDOUT_FILENO,false);
       
       const char *Args[3];
-      Args[0] = _config->Find("Dir::bin::gzip","gzip").c_str();
+      Args[0] = GzipPath.c_str();
       Args[1] = "-d";
       Args[2] = 0;
       execvp(Args[0],(char **)Args);
@@ -73,7 +74,7 @@ bool GzipMethod::Fetch(FetchItem *Itm)
    From.Close();
    
    // Wait for gzip to finish
-   if (ExecWait(Process,_config->Find("Dir::bin::gzip","gzip").c_str(),false) == false)
+   if (ExecWait(Process,GzipPath.c_str(),false) == false)
    {
       To.OpFail();
       return false;