示例#1
0
 def setupPublisher(self, data):
     """ Register a new publisher. """
     try:
         msg = TopicInfo()
         msg.deserialize(data)
         pub = Publisher(msg)
         self.publishers[msg.topic_id] = pub
         self.callbacks[msg.topic_id] = pub.handlePacket
         self.setPublishSize(msg.buffer_size)
         rospy.loginfo("Setup publisher on %s [%s]" % (msg.topic_name, msg.message_type) )
     except Exception as e:
         rospy.logerr("Creation of publisher failed: %s", e)
示例#2
0
 def handleLoggingRequest(self, data):
     """ Forward logging information from serial device into ROS. """
     msg = Log()
     msg.deserialize(data)
     if msg.level == Log.ROSDEBUG:
         rospy.logdebug(msg.msg)
     elif msg.level == Log.INFO:
         rospy.loginfo(msg.msg)
     elif msg.level == Log.WARN:
         rospy.logwarn(msg.msg)
     elif msg.level == Log.ERROR:
         rospy.logerr(msg.msg)
     elif msg.level == Log.FATAL:
         rospy.logfatal(msg.msg)
示例#3
0
 def setupServiceClientSubscriber(self, data):
     """ Register a new service client. """
     try:
         msg = TopicInfo()
         msg.deserialize(data)
         self.setSubscribeSize(msg.buffer_size)
         try:
             srv = self.services[msg.topic_name]
         except KeyError:
             srv = ServiceClient(msg, self)
             rospy.loginfo("Setup service client on %s [%s]" % (msg.topic_name, msg.message_type) )
             self.services[msg.topic_name] = srv
         if srv.mres._md5sum == msg.md5sum:
             srv.id = msg.topic_id
         else:
             raise Exception('Checksum does not match: ' + srv.mres._md5sum + ',' + msg.md5sum)
     except Exception as e:
         rospy.logerr("Creation of service client failed: %s", e)
示例#4
0
 def setupServiceServerPublisher(self, data):
     """ Register a new service server. """
     try:
         msg = TopicInfo()
         msg.deserialize(data)
         self.setPublishSize(msg.buffer_size)
         try:
             srv = self.services[msg.topic_name]
         except KeyError:
             srv = ServiceServer(msg, self)
             rospy.loginfo("Setup service server on %s [%s]" % (msg.topic_name, msg.message_type) )
             self.services[msg.topic_name] = srv
         if srv.mres._md5sum == msg.md5sum:
             self.callbacks[msg.topic_id] = srv.handlePacket
         else:
             raise Exception('Checksum does not match: ' + srv.mres._md5sum + ',' + msg.md5sum)
     except Exception as e:
         rospy.logerr("Creation of service server failed: %s", e)
示例#5
0
 def setupSubscriber(self, data):
     """ Register a new subscriber. """
     try:
         msg = TopicInfo()
         msg.deserialize(data)
         if not msg.topic_name in self.subscribers.keys():
             sub = Subscriber(msg, self)
             self.subscribers[msg.topic_name] = sub
             self.setSubscribeSize(msg.buffer_size)
             rospy.loginfo("Setup subscriber on %s [%s]" % (msg.topic_name, msg.message_type) )
         elif msg.message_type != self.subscribers[msg.topic_name].message._type:
             old_message_type = self.subscribers[msg.topic_name].message._type
             self.subscribers[msg.topic_name].unregister()
             sub = Subscriber(msg, self)
             self.subscribers[msg.topic_name] = sub
             self.setSubscribeSize(msg.buffer_size)
             rospy.loginfo("Change the message type of subscriber on %s from [%s] to [%s]" % (msg.topic_name, old_message_type, msg.message_type) )
     except Exception as e:
         rospy.logerr("Creation of subscriber failed: %s", e)