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 PKG = 'rxbag'
00038 import roslib; roslib.load_manifest(PKG)
00039
00040 import sys
00041 import traceback
00042
00043 import roslib.rospack
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 to_check = roslib.rospack.rospack_depends_on_1('rxbag')
00055
00056 for pkg in to_check:
00057 manifest_file = roslib.manifest.manifest_file(pkg, True)
00058 manifest = roslib.manifest.parse_file(manifest_file)
00059
00060 plugin_module_names = manifest.get_export('rxbag', 'plugin')
00061
00062 if not plugin_module_names:
00063 continue
00064 elif len(plugin_module_names) != 1:
00065 print >> sys.stderr, "Cannot load plugin [%s]: invalid 'plugin' attribute" % (pkg)
00066 continue
00067 plugin_module_name = plugin_module_names[0]
00068
00069 try:
00070
00071 roslib.load_manifest(pkg)
00072
00073
00074 plugin_module = __import__(plugin_module_name)
00075 for sub_module in plugin_module_name.split('.')[1:]:
00076 plugin_module = getattr(plugin_module, sub_module)
00077
00078
00079 plugins_func = None
00080 try:
00081 plugins_func = getattr(plugin_module, 'get_rxbag_plugins')
00082 except AttributeError: pass
00083
00084 if plugins_func:
00085 plugins.extend(plugins_func())
00086 else:
00087 print >> sys.stderr, "Cannot load plugin [%s]: no 'get_rxbag_plugins' attribute" % (plugin_module_name)
00088
00089 except Exception, ex:
00090 print >> sys.stderr, "Unable to load plugin [%s] from package [%s]:\n%s" % (plugin_module_name, pkg, traceback.format_exc())
00091
00092 return plugins