From: Zac Medico Date: Sat, 1 Jan 2011 03:09:11 +0000 (-0800) Subject: egencache: handle ImportError for ExpatError X-Git-Tag: v2.1.9.28~15 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=7689b075628c2120bf5184c8df48273b0b9e8e81;p=portage.git egencache: handle ImportError for ExpatError --- diff --git a/bin/egencache b/bin/egencache index e0834a4ad..c01ced058 100755 --- a/bin/egencache +++ b/bin/egencache @@ -45,12 +45,16 @@ from portage.dep import Atom, isjustname from portage.versions import pkgcmp, pkgsplit, vercmp try: - import xml.etree.ElementTree + from xml.etree import ElementTree except ImportError: pass else: - from repoman.utilities import parse_metadata_use - from xml.parsers.expat import ExpatError + try: + from xml.parsers.expat import ExpatError + except ImportError: + pass + else: + from repoman.utilities import parse_metadata_use from repoman.utilities import FindVCS @@ -171,7 +175,8 @@ def parse_args(args): if options.update_use_local_desc: try: - xml.etree.ElementTree + ElementTree + ExpatError except NameError: parser.error('--update-use-local-desc requires python with USE=xml!') @@ -406,7 +411,7 @@ class GenUseLocalDesc(object): for cp in self._portdb.cp_all(): metadata_path = os.path.join(repo_path, cp, 'metadata.xml') try: - metadata = xml.etree.ElementTree.parse(metadata_path) + metadata = ElementTree.parse(metadata_path) except IOError: pass except (ExpatError, EnvironmentError) as e: