summaryrefslogtreecommitdiffstats
path: root/pym
diff options
context:
space:
mode:
authorZac Medico <zmedico@gentoo.org>2007-07-30 06:50:13 +0000
committerZac Medico <zmedico@gentoo.org>2007-07-30 06:50:13 +0000
commitfa46d408abfad360f6de4fa777ca74818ac0cfcf (patch)
tree3669883fd238792103b0010d896e0bbd9bbfaa7d /pym
parentf549de68439ce01b1d21916a5bc8c53697001067 (diff)
downloadportage-fa46d408abfad360f6de4fa777ca74818ac0cfcf.tar.gz
portage-fa46d408abfad360f6de4fa777ca74818ac0cfcf.tar.bz2
portage-fa46d408abfad360f6de4fa777ca74818ac0cfcf.zip
If the fetcher reported success and the file is too small, don't attempt to resume. Upstream probably changed the distfile and we need to show a digest verification failure so the user gets a clue. (branches/2.1.2 r7322)
svn path=/main/branches/2.1.2.9/; revision=7501
Diffstat (limited to 'pym')
-rw-r--r--pym/portage.py12
1 files changed, 10 insertions, 2 deletions
diff --git a/pym/portage.py b/pym/portage.py
index e8c079d06..3f21c7532 100644
--- a/pym/portage.py
+++ b/pym/portage.py
@@ -2645,7 +2645,7 @@ def fetch(myuris, mysettings, listonly=0, fetchonly=0, locks_in_subdir=".locks",
"gid" : portage_gid,
"groups" : userpriv_groups,
"umask" : 002})
-
+ myret = -1
try:
if mysettings.selinux_enabled():
@@ -2694,7 +2694,15 @@ def fetch(myuris, mysettings, listonly=0, fetchonly=0, locks_in_subdir=".locks",
else:
# no exception? file exists. let digestcheck() report
# an appropriately for size or checksum errors
- if (mystat[stat.ST_SIZE]<mydigests[myfile]["size"]):
+
+ # If the fetcher reported success and the file is
+ # too small, it's probably because the digest is
+ # bad (upstream changed the distfile). In this
+ # case we don't want to attempt to resume. Show a
+ # digest verification failure to that the user gets
+ # a clue about what just happened.
+ if myret != os.EX_OK and \
+ mystat.st_size < mydigests[myfile]["size"]:
# Fetch failed... Try the next one... Kill 404 files though.
if (mystat[stat.ST_SIZE]<100000) and (len(myfile)>4) and not ((myfile[-5:]==".html") or (myfile[-4:]==".htm")):
html404=re.compile("<title>.*(not found|404).*</title>",re.I|re.M)