Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033 """
00034 Loads plugins.
00035 """
00036
00037 from __future__ import print_function
00038
00039 import sys
00040 import traceback
00041
00042 import roslib
00043 import rospkg
00044
00045 def load_plugins():
00046 """
00047 Finds all rxbag plugins.
00048
00049 @return: a list of plugins
00050 @rtype: list of functions which return tuples of (MessageView, TimelineRenderer, list of: message type or '*')
00051 """
00052 plugins = []
00053
00054 rospack = rospkg.RosPack()
00055 to_check = rospack.get_depends_on('rxbag', implicit=False)
00056
00057 for pkg in to_check:
00058 manifest = rospack.get_manifest(pkg)
00059 plugin_module_names = manifest.get_export('rxbag', 'plugin')
00060
00061 if not plugin_module_names:
00062 continue
00063 elif len(plugin_module_names) != 1:
00064 print("Cannot load plugin [%s]: invalid 'plugin' attribute" % (pkg), file=sys.stderr)
00065 continue
00066 plugin_module_name = plugin_module_names[0]
00067
00068 try:
00069
00070 roslib.load_manifest(pkg)
00071
00072
00073 plugin_module = __import__(plugin_module_name)
00074 for sub_module in plugin_module_name.split('.')[1:]:
00075 plugin_module = getattr(plugin_module, sub_module)
00076
00077
00078 plugins_func = None
00079 try:
00080 plugins_func = getattr(plugin_module, 'get_rxbag_plugins')
00081 except AttributeError: pass
00082
00083 if plugins_func:
00084 plugins.extend(plugins_func())
00085 else:
00086 print("Cannot load plugin [%s]: no 'get_rxbag_plugins' attribute" % (plugin_module_name), file=sys.stderr)
00087
00088 except Exception as ex:
00089 print("Unable to load plugin [%s] from package [%s]:\n%s" % (plugin_module_name, pkg, traceback.format_exc()), file=sys.stderr)
00090
00091 return plugins