Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017 import logging
00018
00019 from rosgraph_msgs.msg import Log
00020 import rospy
00021
00022 from nao_driver.nao_driver_naoqi import NaoNode
00023
00024 import qi
00025
00026
00027 LEVELS = [Log.DEBUG, Log.FATAL, Log.ERROR, Log.WARN, Log.INFO, Log.DEBUG, Log.DEBUG]
00028 try:
00029 ROSOUT_PUB = rospy.topics.Publisher('/rosout', Log, latch=True, queue_size=100)
00030 except:
00031
00032 ROSOUT_PUB = rospy.topics.Publisher('/rosout', Log, latch=True)
00033
00034 def onMessageCallback(msg):
00035 """
00036 Given a NAOqi dict message, publish it in /rosout
00037 :param msg: dict corresponding to a NAOqi log message
00038 """
00039 file, function, line = msg['source'].split(':')
00040 if line:
00041 line = int(line)
00042
00043 l = Log(level=LEVELS[msg['level']], name=str(msg['category']), msg=msg['message'], file=file, line=line, function=function)
00044 l.header.stamp = rospy.Time(msg['timestamp']['tv_sec'], msg['timestamp']['tv_usec'])
00045 ROSOUT_PUB.publish(l)
00046
00047 class NaoLogger(NaoNode):
00048
00049 NODE_NAME = 'nao_logger'
00050
00051 def __init__( self ):
00052
00053 NaoNode.__init__( self, self.NODE_NAME )
00054
00055 from distutils.version import LooseVersion
00056 if self.get_version() < LooseVersion('2.0.0'):
00057 rospy.loginfo('The NAOqi version is inferior to 2.0, hence no log bridge possible')
00058 exit(0)
00059
00060 rospy.init_node( self.NODE_NAME )
00061
00062
00063 self.session = qi.Session()
00064 self.session.connect("tcp://%s:%s" % (self.pip, self.pport))
00065 self.logManager = self.session.service("LogManager")
00066
00067 self.listener = self.logManager.getListener()
00068 self.listener.onLogMessage.connect(onMessageCallback)
00069 rospy.loginfo('Logger initialized')
00070
00071 if __name__ == '__main__':
00072 try:
00073 nao_logger = NaoLogger()
00074 except RuntimeError as e:
00075 rospy.logerr('Something went wrong: %s' % str(e) )
00076
00077 rospy.spin()
nao_driver
Author(s): Armin Hornung, Armin Hornung, Stefan Osswald, Daniel Maier, Miguel Sarabia, Séverin Lemaignan
autogenerated on Thu Oct 30 2014 09:20:04