]> git.saurik.com Git - apt.git/commitdiff
fix apt-get download truncation (closes: #736962)
authorMichael Vogt <mvo@debian.org>
Wed, 29 Jan 2014 09:37:17 +0000 (10:37 +0100)
committerMichael Vogt <mvo@debian.org>
Wed, 29 Jan 2014 09:39:18 +0000 (10:39 +0100)
cmdline/apt-get.cc
test/integration/test-apt-get-download

index da7d28a1e9ba8044b1760ae32701b69d43ff7148..6bff6e7de5963d6097e976c2250f2a68b08aefb1 100644 (file)
@@ -678,14 +678,17 @@ bool DoDownload(CommandLine &CmdL)
 
    // copy files in local sources to the current directory
    for (pkgAcquire::ItemIterator I = Fetcher.ItemsBegin(); I != Fetcher.ItemsEnd(); ++I)
-      if ((*I)->Local == true && (*I)->Status == pkgAcquire::Item::StatDone)
+   {
+      std::string const filename = cwd + flNotDir((*I)->DestFile);
+      if ((*I)->Local == true &&
+          filename != (*I)->DestFile &&
+          (*I)->Status == pkgAcquire::Item::StatDone)
       {
-        std::string const filename = cwd + flNotDir((*I)->DestFile);
         std::ifstream src((*I)->DestFile.c_str(), std::ios::binary);
         std::ofstream dst(filename.c_str(), std::ios::binary);
         dst << src.rdbuf();
       }
-
+   }
    return Failed == false;
 }
                                                                        /*}}}*/
index fce0be01853b3fe37a7f1cb6720ca39aaa244bda..c2a5c3d8eb263aae1fa46a17ecece5a844027612 100755 (executable)
@@ -24,6 +24,7 @@ testdownload() {
        rm $1
 }
 
+# normal case(es)
 testdownload apt_1.0_all.deb apt stable
 testdownload apt_2.0_all.deb apt
 
@@ -32,3 +33,9 @@ testequal "'file://${DEBFILE}' apt_2.0_all.deb $(stat -c%s $DEBFILE) SHA512:$(sh
 
 # deb:677887
 testequal "E: Can't find a source to download version '1.0' of 'vrms:i386'" aptget download vrms
+
+# deb:736962 - apt-get download foo && 
+aptget download apt
+aptget download apt
+testsuccess test -s apt_2.0_all.deb
+rm -f apt_1.0_all.deb