From 131643695d7ba9d0c32bf8e192e7e3942f50f318 Mon Sep 17 00:00:00 2001 From: Richard Purdie Date: Tue, 5 Feb 2013 16:01:20 +0000 Subject: terminal.bbclass: Use BB_ORIGENV to restore user environmental variables Signed-off-by: Richard Purdie --- meta/classes/terminal.bbclass | 13 ++++++++++++- 1 file changed, 12 insertions(+), 1 deletion(-) (limited to 'meta/classes/terminal.bbclass') diff --git a/meta/classes/terminal.bbclass b/meta/classes/terminal.bbclass index cec854d54a..d5a6277896 100644 --- a/meta/classes/terminal.bbclass +++ b/meta/classes/terminal.bbclass @@ -4,7 +4,7 @@ OE_TERMINAL[choices] = 'auto none \ ${@" ".join(o.name \ for o in oe.terminal.prioritized())}' -OE_TERMINAL_EXPORTS += 'XAUTHORITY SHELL DBUS_SESSION_BUS_ADDRESS DISPLAY EXTRA_OEMAKE SCREENDIR' +OE_TERMINAL_EXPORTS += 'EXTRA_OEMAKE' OE_TERMINAL_EXPORTS[type] = 'list' XAUTHORITY ?= "${HOME}/.Xauthority" @@ -26,6 +26,17 @@ def oe_terminal(command, title, d): os.environ[export] = str(value) env[export] = str(value) + # Add in all variables from the user's original environment which + # haven't subsequntly been set/changed + origbbenv = d.getVar("BB_ORIGENV", False) or {} + for key in origbbenv: + if key in env: + continue + value = origbbenv.getVar(key, True) + if value is not None: + os.environ[key] = str(value) + env[key] = str(value) + terminal = oe.data.typed_value('OE_TERMINAL', d).lower() if terminal == 'none': bb.fatal('Devshell usage disabled with OE_TERMINAL') -- cgit 1.2.3-korg