]> code.ossystems Code Review - openembedded-core.git/commitdiff
data_smart: be explicit about what we make available to eval'd python code
authorChris Larson <chris_larson@mentor.com>
Thu, 25 Mar 2010 01:58:59 +0000 (18:58 -0700)
committerRichard Purdie <rpurdie@linux.intel.com>
Thu, 25 Mar 2010 17:25:58 +0000 (17:25 +0000)
(Bitbake rev: 6a73dda60f50e9b3e5513795d1ec7207d1446de2)

Signed-off-by: Chris Larson <chris_larson@mentor.com>
Signed-off-by: Richard Purdie <rpurdie@linux.intel.com>
bitbake/lib/bb/data_smart.py

index dac7fb705e7a1fa3304cc5d6c38d0fd5909f1d8a..9067d54bfa3c1b8f1b1a77a3e211b374aaf9d4f9 100644 (file)
@@ -39,6 +39,11 @@ __setvar_keyword__ = ["_append","_prepend"]
 __setvar_regexp__ = re.compile('(?P<base>.*?)(?P<keyword>_append|_prepend)(_(?P<add>.*))?')
 __expand_var_regexp__ = re.compile(r"\${[^{}]+}")
 __expand_python_regexp__ = re.compile(r"\${@.+?}")
+_expand_globals = {
+    "os": os,
+    "bb": bb,
+    "time": time,
+}
 
 
 class DataSmart:
@@ -50,6 +55,7 @@ class DataSmart:
         self._seen_overrides = seen
 
         self.expand_cache = {}
+        self.expand_locals = {"d": self}
 
     def expand(self,s, varname):
         def var_sub(match):
@@ -66,8 +72,7 @@ class DataSmart:
         def python_sub(match):
             import bb
             code = match.group()[3:-1]
-            locals()['d'] = self
-            s = eval(code)
+            s = eval(code, _expand_globals, self.expand_locals)
             if type(s) == types.IntType: s = str(s)
             return s