From: Zac Medico Date: Sun, 18 Sep 2011 22:47:45 +0000 (-0700) Subject: env_update: use global vardbapi as fallback X-Git-Tag: v2.2.0_alpha59~3 X-Git-Url: http://git.tremily.us/?a=commitdiff_plain;h=1a5a662780f7a4401a89f0939a9180872f36f05f;p=portage.git env_update: use global vardbapi as fallback --- diff --git a/pym/portage/util/env_update.py b/pym/portage/util/env_update.py index 71dcf376a..78bef82fa 100644 --- a/pym/portage/util/env_update.py +++ b/pym/portage/util/env_update.py @@ -20,6 +20,7 @@ from portage.util import atomic_ofstream, ensure_dirs, getconfig, \ normalize_path, writemsg from portage.util.listdir import listdir from portage.dbapi.vartree import vartree +from portage.package.ebuild.config import config if sys.hexversion >= 0x3000000: long = int @@ -41,7 +42,12 @@ def env_update(makelinks=1, target_root=None, prev_mtimes=None, contents=None, @type target_root: String (Path) """ if vardbapi is None: - vardbapi = vartree(settings=portage.settings).dbapi + if isinstance(env, config): + vardbapi = vartree(settings=env).dbapi + else: + if target_root is None: + target_root = portage.settings["ROOT"] + vardbapi = portage.db[target_root]["vartree"].dbapi # Lock the config memory file to prevent symlink creation # in merge_contents from overlapping with env-update.