From 18de7eb55f69953e368a279e46a7568ad71fa7ca Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Thu, 21 Dec 2006 07:44:30 +0000 Subject: Create a backward compatibility mode for dep_check() so that emerge can use it to gracefully deal with installed packages that have invalid atoms or dep syntax. svn path=/main/trunk/; revision=5345 --- pym/portage.py | 3 ++- pym/portage_dep.py | 10 ++++++++++ 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/pym/portage.py b/pym/portage.py index 5cceb6556..8b39c621f 100644 --- a/pym/portage.py +++ b/pym/portage.py @@ -3647,7 +3647,8 @@ def _expand_new_virtuals(mysplit, edebug, mydbapi, mysettings, myroot="/", newsplit.append(_expand_new_virtuals(x, edebug, mydbapi, mysettings, myroot=myroot, trees=trees, **kwargs)) continue - if not isvalidatom(x, allow_blockers=True): + if portage_dep._dep_check_strict and \ + not isvalidatom(x, allow_blockers=True): raise portage_exception.ParseError( "invalid atom: '%s'" % x) mykey = dep_getkey(x) diff --git a/pym/portage_dep.py b/pym/portage_dep.py index a482ab2f4..ef6486f19 100644 --- a/pym/portage_dep.py +++ b/pym/portage_dep.py @@ -103,6 +103,11 @@ def paren_enclose(mylist): mystrparts.append(x) return " ".join(mystrparts) +# This is just for use by emerge so that it can enable a backward compatibility +# mode in order to gracefully deal with installed packages that have invalid +# atoms or dep syntax. +_dep_check_strict = True + def use_reduce(deparray, uselist=[], masklist=[], matchall=0, excludeall=[]): """ Takes a paren_reduce'd array and reduces the use? conditionals out @@ -127,6 +132,8 @@ def use_reduce(deparray, uselist=[], masklist=[], matchall=0, excludeall=[]): if deparray and deparray[-1] and deparray[-1][-1] == "?": raise portage_exception.InvalidDependString("Conditional without target in \""+paren_enclose(deparray)+"\"") + global _dep_check_strict + mydeparray = deparray[:] rlist = [] while mydeparray: @@ -186,6 +193,9 @@ def use_reduce(deparray, uselist=[], masklist=[], matchall=0, excludeall=[]): additions = use_reduce(target, uselist, masklist, matchall, excludeall) if additions: rlist.append(additions) + elif not _dep_check_strict: + # The old deprecated behavior. + rlist.append(target) else: raise portage_exception.InvalidDependString( "Conditional without parenthesis: '%s?'" % head) -- cgit v1.2.3-1-g7c22