summaryrefslogtreecommitdiffstats
path: root/pym/portage/elog
diff options
context:
space:
mode:
authorZac Medico <zmedico@gentoo.org>2007-11-29 09:06:52 +0000
committerZac Medico <zmedico@gentoo.org>2007-11-29 09:06:52 +0000
commit94ea294e4b07a4f9cb5814a205510a899d1c106a (patch)
tree293ccf54d3fc47711cad2b9f23eed91f5c3a631e /pym/portage/elog
parentc7d55759963ab10685ec142613c30101f5baa999 (diff)
downloadportage-94ea294e4b07a4f9cb5814a205510a899d1c106a.tar.gz
portage-94ea294e4b07a4f9cb5814a205510a899d1c106a.tar.bz2
portage-94ea294e4b07a4f9cb5814a205510a899d1c106a.zip
When portage reinstalls itself, pre-load elog modules in
dblink.merge() since we won't be able to later if they get unmerged (happens when namespace changes). svn path=/main/trunk/; revision=8749
Diffstat (limited to 'pym/portage/elog')
-rw-r--r--pym/portage/elog/__init__.py10
1 files changed, 7 insertions, 3 deletions
diff --git a/pym/portage/elog/__init__.py b/pym/portage/elog/__init__.py
index e1df6d9bd..c68fedca0 100644
--- a/pym/portage/elog/__init__.py
+++ b/pym/portage/elog/__init__.py
@@ -42,6 +42,7 @@ def _combine_logentries(logentries):
rValue.append("\n")
return "".join(rValue)
+_elog_mod_imports = {}
_elog_atexit_handlers = []
_preserve_logentries = {}
def elog_process(cpv, mysettings, phasefilter=None):
@@ -94,9 +95,12 @@ def elog_process(cpv, mysettings, phasefilter=None):
# FIXME: ugly ad.hoc import code
# TODO: implement a common portage module loader
name = "portage.elog.mod_" + s
- m = __import__(name)
- for comp in name.split(".")[1:]:
- m = getattr(m, comp)
+ m = _elog_mod_imports.get(name)
+ if m is None:
+ m = __import__(name)
+ for comp in name.split(".")[1:]:
+ m = getattr(m, comp)
+ _elog_mod_imports[name] = m
def timeout_handler(signum, frame):
raise PortageException("Timeout in elog_process for system '%s'" % s)
import signal