From 7689b075628c2120bf5184c8df48273b0b9e8e81 Mon Sep 17 00:00:00 2001 From: Zac Medico Date: Fri, 31 Dec 2010 19:09:11 -0800 Subject: egencache: handle ImportError for ExpatError --- bin/egencache | 15 ++++++++++----- 1 file changed, 10 insertions(+), 5 deletions(-) (limited to 'bin') 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: -- cgit v1.2.3-1-g7c22