00001 """autogenerated by genmsg_py from FibonacciActionResult.msg. Do not edit."""
00002 import roslib.message
00003 import struct
00004
00005 import actionlib_tutorials.msg
00006 import roslib.rostime
00007 import actionlib_msgs.msg
00008 import std_msgs.msg
00009
00010 class FibonacciActionResult(roslib.message.Message):
00011 _md5sum = "bee73a9fe29ae25e966e105f5553dd03"
00012 _type = "actionlib_tutorials/FibonacciActionResult"
00013 _has_header = True
00014 _full_text = """# ====== DO NOT MODIFY! AUTOGENERATED FROM AN ACTION DEFINITION ======
00015
00016 Header header
00017 actionlib_msgs/GoalStatus status
00018 FibonacciResult result
00019
00020 ================================================================================
00021 MSG: std_msgs/Header
00022 # Standard metadata for higher-level stamped data types.
00023 # This is generally used to communicate timestamped data
00024 # in a particular coordinate frame.
00025 #
00026 # sequence ID: consecutively increasing ID
00027 uint32 seq
00028 #Two-integer timestamp that is expressed as:
00029 # * stamp.secs: seconds (stamp_secs) since epoch
00030 # * stamp.nsecs: nanoseconds since stamp_secs
00031 # time-handling sugar is provided by the client library
00032 time stamp
00033 #Frame this data is associated with
00034 # 0: no frame
00035 # 1: global frame
00036 string frame_id
00037
00038 ================================================================================
00039 MSG: actionlib_msgs/GoalStatus
00040 GoalID goal_id
00041 uint8 status
00042 uint8 PENDING = 0 # The goal has yet to be processed by the action server
00043 uint8 ACTIVE = 1 # The goal is currently being processed by the action server
00044 uint8 PREEMPTED = 2 # The goal received a cancel request after it started executing
00045 # and has since completed its execution (Terminal State)
00046 uint8 SUCCEEDED = 3 # The goal was achieved successfully by the action server (Terminal State)
00047 uint8 ABORTED = 4 # The goal was aborted during execution by the action server due
00048 # to some failure (Terminal State)
00049 uint8 REJECTED = 5 # The goal was rejected by the action server without being processed,
00050 # because the goal was unattainable or invalid (Terminal State)
00051 uint8 PREEMPTING = 6 # The goal received a cancel request after it started executing
00052 # and has not yet completed execution
00053 uint8 RECALLING = 7 # The goal received a cancel request before it started executing,
00054 # but the action server has not yet confirmed that the goal is canceled
00055 uint8 RECALLED = 8 # The goal received a cancel request before it started executing
00056 # and was successfully cancelled (Terminal State)
00057 uint8 LOST = 9 # An action client can determine that a goal is LOST. This should not be
00058 # sent over the wire by an action server
00059
00060 #Allow for the user to associate a string with GoalStatus for debugging
00061 string text
00062
00063
00064 ================================================================================
00065 MSG: actionlib_msgs/GoalID
00066 # The stamp should store the time at which this goal was requested.
00067 # It is used by an action server when it tries to preempt all
00068 # goals that were requested before a certain time
00069 time stamp
00070
00071 # The id provides a way to associate feedback and
00072 # result message with specific goal requests. The id
00073 # specified must be unique.
00074 string id
00075
00076
00077 ================================================================================
00078 MSG: actionlib_tutorials/FibonacciResult
00079 # ====== DO NOT MODIFY! AUTOGENERATED FROM AN ACTION DEFINITION ======
00080 #result definition
00081 int32[] sequence
00082
00083 """
00084 __slots__ = ['header','status','result']
00085 _slot_types = ['Header','actionlib_msgs/GoalStatus','actionlib_tutorials/FibonacciResult']
00086
00087 def __init__(self, *args, **kwds):
00088 """
00089 Constructor. Any message fields that are implicitly/explicitly
00090 set to None will be assigned a default value. The recommend
00091 use is keyword arguments as this is more robust to future message
00092 changes. You cannot mix in-order arguments and keyword arguments.
00093
00094 The available fields are:
00095 header,status,result
00096
00097 @param args: complete set of field values, in .msg order
00098 @param kwds: use keyword arguments corresponding to message field names
00099 to set specific fields.
00100 """
00101 if args or kwds:
00102 super(FibonacciActionResult, self).__init__(*args, **kwds)
00103
00104 if self.header is None:
00105 self.header = std_msgs.msg._Header.Header()
00106 if self.status is None:
00107 self.status = actionlib_msgs.msg.GoalStatus()
00108 if self.result is None:
00109 self.result = actionlib_tutorials.msg.FibonacciResult()
00110 else:
00111 self.header = std_msgs.msg._Header.Header()
00112 self.status = actionlib_msgs.msg.GoalStatus()
00113 self.result = actionlib_tutorials.msg.FibonacciResult()
00114
00115 def _get_types(self):
00116 """
00117 internal API method
00118 """
00119 return self._slot_types
00120
00121 def serialize(self, buff):
00122 """
00123 serialize message into buffer
00124 @param buff: buffer
00125 @type buff: StringIO
00126 """
00127 try:
00128 _x = self
00129 buff.write(_struct_3I.pack(_x.header.seq, _x.header.stamp.secs, _x.header.stamp.nsecs))
00130 _x = self.header.frame_id
00131 length = len(_x)
00132 buff.write(struct.pack('<I%ss'%length, length, _x))
00133 _x = self
00134 buff.write(_struct_2I.pack(_x.status.goal_id.stamp.secs, _x.status.goal_id.stamp.nsecs))
00135 _x = self.status.goal_id.id
00136 length = len(_x)
00137 buff.write(struct.pack('<I%ss'%length, length, _x))
00138 buff.write(_struct_B.pack(self.status.status))
00139 _x = self.status.text
00140 length = len(_x)
00141 buff.write(struct.pack('<I%ss'%length, length, _x))
00142 length = len(self.result.sequence)
00143 buff.write(_struct_I.pack(length))
00144 pattern = '<%si'%length
00145 buff.write(struct.pack(pattern, *self.result.sequence))
00146 except struct.error, se: self._check_types(se)
00147 except TypeError, te: self._check_types(te)
00148
00149 def deserialize(self, str):
00150 """
00151 unpack serialized message in str into this message instance
00152 @param str: byte array of serialized message
00153 @type str: str
00154 """
00155 try:
00156 if self.header is None:
00157 self.header = std_msgs.msg._Header.Header()
00158 if self.status is None:
00159 self.status = actionlib_msgs.msg.GoalStatus()
00160 if self.result is None:
00161 self.result = actionlib_tutorials.msg.FibonacciResult()
00162 end = 0
00163 _x = self
00164 start = end
00165 end += 12
00166 (_x.header.seq, _x.header.stamp.secs, _x.header.stamp.nsecs,) = _struct_3I.unpack(str[start:end])
00167 start = end
00168 end += 4
00169 (length,) = _struct_I.unpack(str[start:end])
00170 start = end
00171 end += length
00172 self.header.frame_id = str[start:end]
00173 _x = self
00174 start = end
00175 end += 8
00176 (_x.status.goal_id.stamp.secs, _x.status.goal_id.stamp.nsecs,) = _struct_2I.unpack(str[start:end])
00177 start = end
00178 end += 4
00179 (length,) = _struct_I.unpack(str[start:end])
00180 start = end
00181 end += length
00182 self.status.goal_id.id = str[start:end]
00183 start = end
00184 end += 1
00185 (self.status.status,) = _struct_B.unpack(str[start:end])
00186 start = end
00187 end += 4
00188 (length,) = _struct_I.unpack(str[start:end])
00189 start = end
00190 end += length
00191 self.status.text = str[start:end]
00192 start = end
00193 end += 4
00194 (length,) = _struct_I.unpack(str[start:end])
00195 pattern = '<%si'%length
00196 start = end
00197 end += struct.calcsize(pattern)
00198 self.result.sequence = struct.unpack(pattern, str[start:end])
00199 return self
00200 except struct.error, e:
00201 raise roslib.message.DeserializationError(e)
00202
00203
00204 def serialize_numpy(self, buff, numpy):
00205 """
00206 serialize message with numpy array types into buffer
00207 @param buff: buffer
00208 @type buff: StringIO
00209 @param numpy: numpy python module
00210 @type numpy module
00211 """
00212 try:
00213 _x = self
00214 buff.write(_struct_3I.pack(_x.header.seq, _x.header.stamp.secs, _x.header.stamp.nsecs))
00215 _x = self.header.frame_id
00216 length = len(_x)
00217 buff.write(struct.pack('<I%ss'%length, length, _x))
00218 _x = self
00219 buff.write(_struct_2I.pack(_x.status.goal_id.stamp.secs, _x.status.goal_id.stamp.nsecs))
00220 _x = self.status.goal_id.id
00221 length = len(_x)
00222 buff.write(struct.pack('<I%ss'%length, length, _x))
00223 buff.write(_struct_B.pack(self.status.status))
00224 _x = self.status.text
00225 length = len(_x)
00226 buff.write(struct.pack('<I%ss'%length, length, _x))
00227 length = len(self.result.sequence)
00228 buff.write(_struct_I.pack(length))
00229 pattern = '<%si'%length
00230 buff.write(self.result.sequence.tostring())
00231 except struct.error, se: self._check_types(se)
00232 except TypeError, te: self._check_types(te)
00233
00234 def deserialize_numpy(self, str, numpy):
00235 """
00236 unpack serialized message in str into this message instance using numpy for array types
00237 @param str: byte array of serialized message
00238 @type str: str
00239 @param numpy: numpy python module
00240 @type numpy: module
00241 """
00242 try:
00243 if self.header is None:
00244 self.header = std_msgs.msg._Header.Header()
00245 if self.status is None:
00246 self.status = actionlib_msgs.msg.GoalStatus()
00247 if self.result is None:
00248 self.result = actionlib_tutorials.msg.FibonacciResult()
00249 end = 0
00250 _x = self
00251 start = end
00252 end += 12
00253 (_x.header.seq, _x.header.stamp.secs, _x.header.stamp.nsecs,) = _struct_3I.unpack(str[start:end])
00254 start = end
00255 end += 4
00256 (length,) = _struct_I.unpack(str[start:end])
00257 start = end
00258 end += length
00259 self.header.frame_id = str[start:end]
00260 _x = self
00261 start = end
00262 end += 8
00263 (_x.status.goal_id.stamp.secs, _x.status.goal_id.stamp.nsecs,) = _struct_2I.unpack(str[start:end])
00264 start = end
00265 end += 4
00266 (length,) = _struct_I.unpack(str[start:end])
00267 start = end
00268 end += length
00269 self.status.goal_id.id = str[start:end]
00270 start = end
00271 end += 1
00272 (self.status.status,) = _struct_B.unpack(str[start:end])
00273 start = end
00274 end += 4
00275 (length,) = _struct_I.unpack(str[start:end])
00276 start = end
00277 end += length
00278 self.status.text = str[start:end]
00279 start = end
00280 end += 4
00281 (length,) = _struct_I.unpack(str[start:end])
00282 pattern = '<%si'%length
00283 start = end
00284 end += struct.calcsize(pattern)
00285 self.result.sequence = numpy.frombuffer(str[start:end], dtype=numpy.int32, count=length)
00286 return self
00287 except struct.error, e:
00288 raise roslib.message.DeserializationError(e)
00289
00290 _struct_I = roslib.message.struct_I
00291 _struct_3I = struct.Struct("<3I")
00292 _struct_B = struct.Struct("<B")
00293 _struct_2I = struct.Struct("<2I")