base: use a variable for the modules to import/inject
authorChris Larson <chris_larson@mentor.com>
Mon, 23 Aug 2010 20:39:20 +0000 (16:39 -0400)
committerChris Larson <chris_larson@mentor.com>
Mon, 23 Aug 2010 20:40:11 +0000 (16:40 -0400)
Signed-off-by: Chris Larson <chris_larson@mentor.com>
classes/base.bbclass

index 89f983f..ef9921d 100644 (file)
@@ -9,31 +9,26 @@ inherit utils
 inherit utility-tasks
 inherit metadata_scm
 
-python sys_path_eh () {
-    if isinstance(e, bb.event.ConfigParsed):
-        import sys
-        import os
-        import time
+OE_IMPORTS += "oe.path oe.utils sys os time"
 
+python oe_import () {
+    if isinstance(e, bb.event.ConfigParsed):
         bbpath = e.data.getVar("BBPATH", True).split(":")
         sys.path[0:0] = [os.path.join(dir, "lib") for dir in bbpath]
 
         def inject(name, value):
-            """Make a python object accessible from everywhere for the metadata"""
+            """Make a python object accessible from the metadata"""
             if hasattr(bb.utils, "_context"):
                 bb.utils._context[name] = value
             else:
                 __builtins__[name] = value
 
-        import oe.path
-        import oe.utils
-        inject("bb", bb)
-        inject("sys", sys)
-        inject("time", time)
-        inject("oe", oe)
+        for toimport in e.data.getVar("OE_IMPORTS", True).split():
+            imported = __import__(toimport)
+            inject(toimport, imported)
 }
 
-addhandler sys_path_eh
+addhandler oe_import
 
 die() {
        oefatal "$*"