diff options
author | Ed Bartosh <ed.bartosh@linux.intel.com> | 2017-02-15 14:58:22 +0200 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2017-03-04 10:42:30 +0000 |
commit | 875d4eede61b548d64f426c2ef077cc17e50cd45 (patch) | |
tree | b78fc9547efb5699f0850105805f37b2c1da43ce /scripts/lib/wic/plugin.py | |
parent | aaab003e472416124d7342fc8c4a17c252b83f4d (diff) | |
download | openembedded-core-875d4eede61b548d64f426c2ef077cc17e50cd45.tar.gz openembedded-core-875d4eede61b548d64f426c2ef077cc17e50cd45.tar.bz2 openembedded-core-875d4eede61b548d64f426c2ef077cc17e50cd45.zip |
wic: reimplement PluginMgr.get_plugin_methods
Simplified the implementation of get_plugin_methods:
- get rid of looping over the dicrtionary, used access by key instead
- get rid of filling a dictionary that passed as a parameter
Signed-off-by: Ed Bartosh <ed.bartosh@linux.intel.com>
Diffstat (limited to 'scripts/lib/wic/plugin.py')
-rw-r--r-- | scripts/lib/wic/plugin.py | 22 |
1 files changed, 9 insertions, 13 deletions
diff --git a/scripts/lib/wic/plugin.py b/scripts/lib/wic/plugin.py index 064243dc9d..c200822af7 100644 --- a/scripts/lib/wic/plugin.py +++ b/scripts/lib/wic/plugin.py @@ -109,22 +109,18 @@ class PluginMgr: return pluginbase.get_plugins(ptype) @classmethod - def get_source_plugin_methods(cls, source_name, methods): + def get_plugin_methods(cls, ptype, pname, methods): """ The methods param is a dict with the method names to find. On return, the dict values will be filled in with pointers to the corresponding methods. If one or more methods are not found, None is returned. """ - return_methods = None - for _source_name, klass in cls.get_plugins('source').items(): - if _source_name == source_name: - for _method_name in methods: - if not hasattr(klass, _method_name): - logger.warning("Unimplemented %s source interface for: %s", - _method_name, _source_name) - return None - func = getattr(klass, _method_name) - methods[_method_name] = func - return_methods = methods - return return_methods + result = {} + plugin = cls.get_plugins(ptype).get(pname) + for method in methods: + if not hasattr(plugin, method): + raise WicError("Unimplemented %s plugin interface for: %s" % + (method, pname)) + result[method] = getattr(plugin, method) + return result |