00001 
00002 #ifndef OBJECT_MANIPULATION_MSGS_MESSAGE_PLACEACTIONFEEDBACK_H
00003 #define OBJECT_MANIPULATION_MSGS_MESSAGE_PLACEACTIONFEEDBACK_H
00004 #include <string>
00005 #include <vector>
00006 #include <ostream>
00007 #include "ros/serialization.h"
00008 #include "ros/builtin_message_traits.h"
00009 #include "ros/message_operations.h"
00010 #include "ros/message.h"
00011 #include "ros/time.h"
00012 
00013 #include "std_msgs/Header.h"
00014 #include "actionlib_msgs/GoalStatus.h"
00015 #include "object_manipulation_msgs/PlaceFeedback.h"
00016 
00017 namespace object_manipulation_msgs
00018 {
00019 template <class ContainerAllocator>
00020 struct PlaceActionFeedback_ : public ros::Message
00021 {
00022   typedef PlaceActionFeedback_<ContainerAllocator> Type;
00023 
00024   PlaceActionFeedback_()
00025   : header()
00026   , status()
00027   , feedback()
00028   {
00029   }
00030 
00031   PlaceActionFeedback_(const ContainerAllocator& _alloc)
00032   : header(_alloc)
00033   , status(_alloc)
00034   , feedback(_alloc)
00035   {
00036   }
00037 
00038   typedef  ::std_msgs::Header_<ContainerAllocator>  _header_type;
00039    ::std_msgs::Header_<ContainerAllocator>  header;
00040 
00041   typedef  ::actionlib_msgs::GoalStatus_<ContainerAllocator>  _status_type;
00042    ::actionlib_msgs::GoalStatus_<ContainerAllocator>  status;
00043 
00044   typedef  ::object_manipulation_msgs::PlaceFeedback_<ContainerAllocator>  _feedback_type;
00045    ::object_manipulation_msgs::PlaceFeedback_<ContainerAllocator>  feedback;
00046 
00047 
00048 private:
00049   static const char* __s_getDataType_() { return "object_manipulation_msgs/PlaceActionFeedback"; }
00050 public:
00051   ROS_DEPRECATED static const std::string __s_getDataType() { return __s_getDataType_(); }
00052 
00053   ROS_DEPRECATED const std::string __getDataType() const { return __s_getDataType_(); }
00054 
00055 private:
00056   static const char* __s_getMD5Sum_() { return "a69d6edb4d5dfc5a4153c29e148d8f24"; }
00057 public:
00058   ROS_DEPRECATED static const std::string __s_getMD5Sum() { return __s_getMD5Sum_(); }
00059 
00060   ROS_DEPRECATED const std::string __getMD5Sum() const { return __s_getMD5Sum_(); }
00061 
00062 private:
00063   static const char* __s_getMessageDefinition_() { return "\n\
00064 Header header\n\
00065 actionlib_msgs/GoalStatus status\n\
00066 PlaceFeedback feedback\n\
00067 \n\
00068 ================================================================================\n\
00069 MSG: std_msgs/Header\n\
00070 # Standard metadata for higher-level stamped data types.\n\
00071 # This is generally used to communicate timestamped data \n\
00072 # in a particular coordinate frame.\n\
00073 # \n\
00074 # sequence ID: consecutively increasing ID \n\
00075 uint32 seq\n\
00076 #Two-integer timestamp that is expressed as:\n\
00077 # * stamp.secs: seconds (stamp_secs) since epoch\n\
00078 # * stamp.nsecs: nanoseconds since stamp_secs\n\
00079 # time-handling sugar is provided by the client library\n\
00080 time stamp\n\
00081 #Frame this data is associated with\n\
00082 # 0: no frame\n\
00083 # 1: global frame\n\
00084 string frame_id\n\
00085 \n\
00086 ================================================================================\n\
00087 MSG: actionlib_msgs/GoalStatus\n\
00088 GoalID goal_id\n\
00089 uint8 status\n\
00090 uint8 PENDING         = 0   # The goal has yet to be processed by the action server\n\
00091 uint8 ACTIVE          = 1   # The goal is currently being processed by the action server\n\
00092 uint8 PREEMPTED       = 2   # The goal received a cancel request after it started executing\n\
00093                             #   and has since completed its execution (Terminal State)\n\
00094 uint8 SUCCEEDED       = 3   # The goal was achieved successfully by the action server (Terminal State)\n\
00095 uint8 ABORTED         = 4   # The goal was aborted during execution by the action server due\n\
00096                             #    to some failure (Terminal State)\n\
00097 uint8 REJECTED        = 5   # The goal was rejected by the action server without being processed,\n\
00098                             #    because the goal was unattainable or invalid (Terminal State)\n\
00099 uint8 PREEMPTING      = 6   # The goal received a cancel request after it started executing\n\
00100                             #    and has not yet completed execution\n\
00101 uint8 RECALLING       = 7   # The goal received a cancel request before it started executing,\n\
00102                             #    but the action server has not yet confirmed that the goal is canceled\n\
00103 uint8 RECALLED        = 8   # The goal received a cancel request before it started executing\n\
00104                             #    and was successfully cancelled (Terminal State)\n\
00105 uint8 LOST            = 9   # An action client can determine that a goal is LOST. This should not be\n\
00106                             #    sent over the wire by an action server\n\
00107 \n\
00108 #Allow for the user to associate a string with GoalStatus for debugging\n\
00109 string text\n\
00110 \n\
00111 \n\
00112 ================================================================================\n\
00113 MSG: actionlib_msgs/GoalID\n\
00114 # The stamp should store the time at which this goal was requested.\n\
00115 # It is used by an action server when it tries to preempt all\n\
00116 # goals that were requested before a certain time\n\
00117 time stamp\n\
00118 \n\
00119 # The id provides a way to associate feedback and\n\
00120 # result message with specific goal requests. The id\n\
00121 # specified must be unique.\n\
00122 string id\n\
00123 \n\
00124 \n\
00125 ================================================================================\n\
00126 MSG: object_manipulation_msgs/PlaceFeedback\n\
00127 # The number of the place location currently being attempted\n\
00128 int32 current_location\n\
00129 \n\
00130 # The total number of locations that will be attempted\n\
00131 int32 total_locations\n\
00132 \n\
00133 \n\
00134 \n\
00135 \n\
00136 "; }
00137 public:
00138   ROS_DEPRECATED static const std::string __s_getMessageDefinition() { return __s_getMessageDefinition_(); }
00139 
00140   ROS_DEPRECATED const std::string __getMessageDefinition() const { return __s_getMessageDefinition_(); }
00141 
00142   ROS_DEPRECATED virtual uint8_t *serialize(uint8_t *write_ptr, uint32_t seq) const
00143   {
00144     ros::serialization::OStream stream(write_ptr, 1000000000);
00145     ros::serialization::serialize(stream, header);
00146     ros::serialization::serialize(stream, status);
00147     ros::serialization::serialize(stream, feedback);
00148     return stream.getData();
00149   }
00150 
00151   ROS_DEPRECATED virtual uint8_t *deserialize(uint8_t *read_ptr)
00152   {
00153     ros::serialization::IStream stream(read_ptr, 1000000000);
00154     ros::serialization::deserialize(stream, header);
00155     ros::serialization::deserialize(stream, status);
00156     ros::serialization::deserialize(stream, feedback);
00157     return stream.getData();
00158   }
00159 
00160   ROS_DEPRECATED virtual uint32_t serializationLength() const
00161   {
00162     uint32_t size = 0;
00163     size += ros::serialization::serializationLength(header);
00164     size += ros::serialization::serializationLength(status);
00165     size += ros::serialization::serializationLength(feedback);
00166     return size;
00167   }
00168 
00169   typedef boost::shared_ptr< ::object_manipulation_msgs::PlaceActionFeedback_<ContainerAllocator> > Ptr;
00170   typedef boost::shared_ptr< ::object_manipulation_msgs::PlaceActionFeedback_<ContainerAllocator>  const> ConstPtr;
00171 }; 
00172 typedef  ::object_manipulation_msgs::PlaceActionFeedback_<std::allocator<void> > PlaceActionFeedback;
00173 
00174 typedef boost::shared_ptr< ::object_manipulation_msgs::PlaceActionFeedback> PlaceActionFeedbackPtr;
00175 typedef boost::shared_ptr< ::object_manipulation_msgs::PlaceActionFeedback const> PlaceActionFeedbackConstPtr;
00176 
00177 
00178 template<typename ContainerAllocator>
00179 std::ostream& operator<<(std::ostream& s, const  ::object_manipulation_msgs::PlaceActionFeedback_<ContainerAllocator> & v)
00180 {
00181   ros::message_operations::Printer< ::object_manipulation_msgs::PlaceActionFeedback_<ContainerAllocator> >::stream(s, "", v);
00182   return s;}
00183 
00184 } 
00185 
00186 namespace ros
00187 {
00188 namespace message_traits
00189 {
00190 template<class ContainerAllocator>
00191 struct MD5Sum< ::object_manipulation_msgs::PlaceActionFeedback_<ContainerAllocator> > {
00192   static const char* value() 
00193   {
00194     return "a69d6edb4d5dfc5a4153c29e148d8f24";
00195   }
00196 
00197   static const char* value(const  ::object_manipulation_msgs::PlaceActionFeedback_<ContainerAllocator> &) { return value(); } 
00198   static const uint64_t static_value1 = 0xa69d6edb4d5dfc5aULL;
00199   static const uint64_t static_value2 = 0x4153c29e148d8f24ULL;
00200 };
00201 
00202 template<class ContainerAllocator>
00203 struct DataType< ::object_manipulation_msgs::PlaceActionFeedback_<ContainerAllocator> > {
00204   static const char* value() 
00205   {
00206     return "object_manipulation_msgs/PlaceActionFeedback";
00207   }
00208 
00209   static const char* value(const  ::object_manipulation_msgs::PlaceActionFeedback_<ContainerAllocator> &) { return value(); } 
00210 };
00211 
00212 template<class ContainerAllocator>
00213 struct Definition< ::object_manipulation_msgs::PlaceActionFeedback_<ContainerAllocator> > {
00214   static const char* value() 
00215   {
00216     return "\n\
00217 Header header\n\
00218 actionlib_msgs/GoalStatus status\n\
00219 PlaceFeedback feedback\n\
00220 \n\
00221 ================================================================================\n\
00222 MSG: std_msgs/Header\n\
00223 # Standard metadata for higher-level stamped data types.\n\
00224 # This is generally used to communicate timestamped data \n\
00225 # in a particular coordinate frame.\n\
00226 # \n\
00227 # sequence ID: consecutively increasing ID \n\
00228 uint32 seq\n\
00229 #Two-integer timestamp that is expressed as:\n\
00230 # * stamp.secs: seconds (stamp_secs) since epoch\n\
00231 # * stamp.nsecs: nanoseconds since stamp_secs\n\
00232 # time-handling sugar is provided by the client library\n\
00233 time stamp\n\
00234 #Frame this data is associated with\n\
00235 # 0: no frame\n\
00236 # 1: global frame\n\
00237 string frame_id\n\
00238 \n\
00239 ================================================================================\n\
00240 MSG: actionlib_msgs/GoalStatus\n\
00241 GoalID goal_id\n\
00242 uint8 status\n\
00243 uint8 PENDING         = 0   # The goal has yet to be processed by the action server\n\
00244 uint8 ACTIVE          = 1   # The goal is currently being processed by the action server\n\
00245 uint8 PREEMPTED       = 2   # The goal received a cancel request after it started executing\n\
00246                             #   and has since completed its execution (Terminal State)\n\
00247 uint8 SUCCEEDED       = 3   # The goal was achieved successfully by the action server (Terminal State)\n\
00248 uint8 ABORTED         = 4   # The goal was aborted during execution by the action server due\n\
00249                             #    to some failure (Terminal State)\n\
00250 uint8 REJECTED        = 5   # The goal was rejected by the action server without being processed,\n\
00251                             #    because the goal was unattainable or invalid (Terminal State)\n\
00252 uint8 PREEMPTING      = 6   # The goal received a cancel request after it started executing\n\
00253                             #    and has not yet completed execution\n\
00254 uint8 RECALLING       = 7   # The goal received a cancel request before it started executing,\n\
00255                             #    but the action server has not yet confirmed that the goal is canceled\n\
00256 uint8 RECALLED        = 8   # The goal received a cancel request before it started executing\n\
00257                             #    and was successfully cancelled (Terminal State)\n\
00258 uint8 LOST            = 9   # An action client can determine that a goal is LOST. This should not be\n\
00259                             #    sent over the wire by an action server\n\
00260 \n\
00261 #Allow for the user to associate a string with GoalStatus for debugging\n\
00262 string text\n\
00263 \n\
00264 \n\
00265 ================================================================================\n\
00266 MSG: actionlib_msgs/GoalID\n\
00267 # The stamp should store the time at which this goal was requested.\n\
00268 # It is used by an action server when it tries to preempt all\n\
00269 # goals that were requested before a certain time\n\
00270 time stamp\n\
00271 \n\
00272 # The id provides a way to associate feedback and\n\
00273 # result message with specific goal requests. The id\n\
00274 # specified must be unique.\n\
00275 string id\n\
00276 \n\
00277 \n\
00278 ================================================================================\n\
00279 MSG: object_manipulation_msgs/PlaceFeedback\n\
00280 # The number of the place location currently being attempted\n\
00281 int32 current_location\n\
00282 \n\
00283 # The total number of locations that will be attempted\n\
00284 int32 total_locations\n\
00285 \n\
00286 \n\
00287 \n\
00288 \n\
00289 ";
00290   }
00291 
00292   static const char* value(const  ::object_manipulation_msgs::PlaceActionFeedback_<ContainerAllocator> &) { return value(); } 
00293 };
00294 
00295 template<class ContainerAllocator> struct HasHeader< ::object_manipulation_msgs::PlaceActionFeedback_<ContainerAllocator> > : public TrueType {};
00296 template<class ContainerAllocator> struct HasHeader< const ::object_manipulation_msgs::PlaceActionFeedback_<ContainerAllocator> > : public TrueType {};
00297 } 
00298 } 
00299 
00300 namespace ros
00301 {
00302 namespace serialization
00303 {
00304 
00305 template<class ContainerAllocator> struct Serializer< ::object_manipulation_msgs::PlaceActionFeedback_<ContainerAllocator> >
00306 {
00307   template<typename Stream, typename T> inline static void allInOne(Stream& stream, T m)
00308   {
00309     stream.next(m.header);
00310     stream.next(m.status);
00311     stream.next(m.feedback);
00312   }
00313 
00314   ROS_DECLARE_ALLINONE_SERIALIZER;
00315 }; 
00316 } 
00317 } 
00318 
00319 namespace ros
00320 {
00321 namespace message_operations
00322 {
00323 
00324 template<class ContainerAllocator>
00325 struct Printer< ::object_manipulation_msgs::PlaceActionFeedback_<ContainerAllocator> >
00326 {
00327   template<typename Stream> static void stream(Stream& s, const std::string& indent, const  ::object_manipulation_msgs::PlaceActionFeedback_<ContainerAllocator> & v) 
00328   {
00329     s << indent << "header: ";
00330 s << std::endl;
00331     Printer< ::std_msgs::Header_<ContainerAllocator> >::stream(s, indent + "  ", v.header);
00332     s << indent << "status: ";
00333 s << std::endl;
00334     Printer< ::actionlib_msgs::GoalStatus_<ContainerAllocator> >::stream(s, indent + "  ", v.status);
00335     s << indent << "feedback: ";
00336 s << std::endl;
00337     Printer< ::object_manipulation_msgs::PlaceFeedback_<ContainerAllocator> >::stream(s, indent + "  ", v.feedback);
00338   }
00339 };
00340 
00341 
00342 } 
00343 } 
00344 
00345 #endif // OBJECT_MANIPULATION_MSGS_MESSAGE_PLACEACTIONFEEDBACK_H
00346