summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristopher Larson <chris_larson@mentor.com>2016-04-30 12:40:57 -0700
committerRichard Purdie <richard.purdie@linuxfoundation.org>2016-05-06 10:19:59 +0100
commit99db61bf816d9c735032caa762aae8e6a0803402 (patch)
tree504f8626422a2df2d91cc2057ee7e79082319a03
parentb492836e08745e04bd9ba2fb0b56a680a5fdce79 (diff)
downloadopenembedded-core-contrib-99db61bf816d9c735032caa762aae8e6a0803402.tar.gz
bb.utils: add load_plugins from scriptutils
Imported as of oe-core 184a256. Signed-off-by: Christopher Larson <chris_larson@mentor.com> Signed-off-by: Richard Purdie <richard.purdie@linuxfoundation.org>
-rw-r--r--lib/bb/utils.py21
1 files changed, 21 insertions, 0 deletions
diff --git a/lib/bb/utils.py b/lib/bb/utils.py
index 3544bbe170..92f1b60206 100644
--- a/lib/bb/utils.py
+++ b/lib/bb/utils.py
@@ -27,6 +27,7 @@ import bb
import bb.msg
import multiprocessing
import fcntl
+import imp
import subprocess
import glob
import fnmatch
@@ -1451,3 +1452,23 @@ def export_proxies(d):
exported = True
return exported
+
+
+def load_plugins(logger, plugins, pluginpath):
+ def load_plugin(name):
+ logger.debug('Loading plugin %s' % name)
+ fp, pathname, description = imp.find_module(name, [pluginpath])
+ try:
+ return imp.load_module(name, fp, pathname, description)
+ finally:
+ if fp:
+ fp.close()
+
+ logger.debug('Loading plugins from %s...' % pluginpath)
+ for fn in glob.glob(os.path.join(pluginpath, '*.py')):
+ name = os.path.splitext(os.path.basename(fn))[0]
+ if name != '__init__':
+ plugin = load_plugin(name)
+ if hasattr(plugin, 'plugin_init'):
+ plugin.plugin_init(plugins)
+ plugins.append(plugin)