* Reset curl options and timestamp between downloaded files. Thanks to
authorMichael Vogt <michael.vogt@ubuntu.com>
Wed, 3 Oct 2007 00:21:52 +0000 (02:21 +0200)
committerMichael Vogt <michael.vogt@ubuntu.com>
Wed, 3 Oct 2007 00:21:52 +0000 (02:21 +0200)
  Ryan Murray <rmurray@debian.org> for the patch

debian/changelog
methods/https.cc

index 87b9dd0..375a6bb 100644 (file)
@@ -6,6 +6,8 @@ apt (0.7.6ubuntu12) gutsy; urgency=low
       (thanks to Laurent Bigonville, LP: #140019)
   * apt-pkg/deb/debmetaindex.cc: comparison with string literal results
       in unspecified behaviour;
+  * Reset curl options and timestamp between downloaded files. Thanks to
+    Ryan Murray <rmurray@debian.org> for the patch
 
   [Paul Sladen]
   * Have 'cron.daily/apt' send D-Bus doesn't exist error messages
index e6717e6..3b2b0bb 100644 (file)
@@ -115,6 +115,7 @@ bool HttpsMethod::Fetch(FetchItem *Itm)
    //       - error checking/reporting
    //       - more debug options? (CURLOPT_DEBUGFUNCTION?)
 
+   curl_easy_reset(curl);
    SetupProxy();
 
    // callbacks
@@ -125,6 +126,7 @@ bool HttpsMethod::Fetch(FetchItem *Itm)
    curl_easy_setopt(curl, CURLOPT_PROGRESSDATA, this);
    curl_easy_setopt(curl, CURLOPT_NOPROGRESS, false);
    curl_easy_setopt(curl, CURLOPT_FAILONERROR, true);
+   curl_easy_setopt(curl, CURLOPT_FILETIME, true);
 
    // FIXME: https: offer various options of verification
    bool peer_verify = _config->FindB("Acquire::https::Verify-Peer", false);
@@ -202,6 +204,9 @@ bool HttpsMethod::Fetch(FetchItem *Itm)
    CURLcode success = curl_easy_perform(curl);
    curl_easy_getinfo(curl, CURLINFO_RESPONSE_CODE, &curl_responsecode);
 
+   long curl_servdate;
+   curl_easy_getinfo(curl, CURLINFO_FILETIME, &curl_servdate);
+
    // cleanup
    if(success != 0) 
    {
@@ -215,6 +220,14 @@ bool HttpsMethod::Fetch(FetchItem *Itm)
    if (Res.Size == 0)
       Res.Size = File->Size();
 
+   // Timestamp
+   struct utimbuf UBuf;
+   if (curl_servdate != -1) {
+       UBuf.actime = curl_servdate;
+       UBuf.modtime = curl_servdate;
+       utime(File->Name().c_str(),&UBuf);
+   }
+
    // check the downloaded result
    struct stat Buf;
    if (stat(File->Name().c_str(),&Buf) == 0)