From: Zac Medico Date: Sat, 21 Jul 2007 11:34:23 +0000 (-0000) Subject: For bug #169500, detect when the cvs server puts /Attic/ inside the $Header path... X-Git-Tag: v2.2_pre1~975 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=6e3a6a8b9cb8477afb12497b43f8f58c06a90128;p=portage.git For bug #169500, detect when the cvs server puts /Attic/ inside the $Header path and automatically correct it. svn path=/main/trunk/; revision=7340 --- diff --git a/bin/repoman b/bin/repoman index 6a617191d..b995c4706 100755 --- a/bin/repoman +++ b/bin/repoman @@ -1792,6 +1792,23 @@ else: else: raise portage.exception.PortageException("!!! gpg exited with '" + str(rValue) + "' status") + # When files are removed and re-added, the cvs server will put /Attic/ + # inside the $Header path. This code detects the problem and corrects it + # so that the Manifest will generate correctly. See bug #169500. + from portage.util import write_atomic + cvs_header = re.compile(r'^#\s*\$Header.*\$$') + for x in myheaders: + f = open(x) + mylines = f.readlines() + f.close() + modified = False + for i, line in enumerate(mylines): + if cvs_header.match(line) and "/Attic/" in line: + mylines[i] = line.replace("/Attic/", "/") + modified = True + if modified: + write_atomic(x, "".join(mylines)) + manifest_commit_required = True if myheaders or myupdates or myremoved or mynew: myfiles=myheaders+myupdates+myremoved+mynew