joint_traj_pt.cpp
Go to the documentation of this file.
00001 /*
00002  * Software License Agreement (BSD License)
00003  *
00004  * Copyright (c) 2011, Southwest Research Institute
00005  * All rights reserved.
00006  *
00007  * Redistribution and use in source and binary forms, with or without
00008  * modification, are permitted provided that the following conditions are met:
00009  *
00010  *      * Redistributions of source code must retain the above copyright
00011  *      notice, this list of conditions and the following disclaimer.
00012  *      * Redistributions in binary form must reproduce the above copyright
00013  *      notice, this list of conditions and the following disclaimer in the
00014  *      documentation and/or other materials provided with the distribution.
00015  *      * Neither the name of the Southwest Research Institute, nor the names
00016  *      of its contributors may be used to endorse or promote products derived
00017  *      from this software without specific prior written permission.
00018  *
00019  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
00020  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
00021  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
00022  * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE
00023  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
00024  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
00025  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
00026  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
00027  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
00028  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00029  * POSSIBILITY OF SUCH DAMAGE.
00030  */
00031 #ifdef ROS
00032 #include "simple_message/joint_traj_pt.h"
00033 #include "simple_message/shared_types.h"
00034 #include "simple_message/log_wrapper.h"
00035 #endif
00036 
00037 #ifdef MOTOPLUS
00038 #include "joint_traj_pt.h"
00039 #include "shared_types.h"
00040 #include "log_wrapper.h"
00041 #endif
00042 
00043 using namespace industrial::joint_data;
00044 using namespace industrial::shared_types;
00045 
00046 namespace industrial
00047 {
00048 namespace joint_traj_pt
00049 {
00050 
00051 JointTrajPt::JointTrajPt(void)
00052 {
00053   this->init();
00054 }
00055 JointTrajPt::~JointTrajPt(void)
00056 {
00057 
00058 }
00059 
00060 void JointTrajPt::init()
00061 {
00062         this->joint_position_.init();
00063         this->sequence_ = 0;
00064         this->velocity_ = 0.0;
00065 }
00066 
00067 void JointTrajPt::init(shared_int sequence, JointData & position, shared_real velocity)
00068 {
00069         this->setJointPosition(position);
00070         this->setSequence(sequence);
00071         this->setVelocity(velocity);
00072 }
00073 
00074 
00075 void JointTrajPt::copyFrom(JointTrajPt &src)
00076 {
00077   this->setSequence(src.getSequence());
00078   src.getJointPosition(this->joint_position_);
00079   this->setVelocity(src.getVelocity());
00080 }
00081 
00082 bool JointTrajPt::operator==(JointTrajPt &rhs)
00083 {
00084   return this->joint_position_ == rhs.joint_position_ &&
00085                   this->sequence_ == rhs.sequence_ &&
00086                   this->velocity_ == rhs.velocity_;
00087 
00088 }
00089 
00090 bool JointTrajPt::load(industrial::byte_array::ByteArray *buffer)
00091 {
00092         bool rtn = false;
00093 
00094         LOG_COMM("Executing joint trajectory point load");
00095 
00096         if (buffer->load(this->sequence_))
00097         {
00098                 if (this->joint_position_.load(buffer))
00099                 {
00100                         if (buffer->load(this->velocity_))
00101                         {
00102                                 LOG_COMM("Trajectory point successfully loaded");
00103                                 rtn = true;
00104                         }
00105                         else
00106                         {
00107                                 rtn = false;
00108                                 LOG_ERROR("Failed to load joint traj pt. velocity");
00109                         }
00110 
00111                 }
00112                 else
00113                 {
00114                         rtn = false;
00115                         LOG_ERROR("Failed to load joint traj. pt.  position data");
00116                 }
00117         }
00118         else
00119         {
00120                 rtn = false;
00121                 LOG_ERROR("Failed to load joint traj. pt. sequence number");
00122         }
00123 
00124         return rtn;
00125 }
00126 
00127 bool JointTrajPt::unload(industrial::byte_array::ByteArray *buffer)
00128 {
00129   bool rtn = false;
00130 
00131   LOG_COMM("Executing joint traj. pt. unload");
00132   if (buffer->unload(this->velocity_))
00133   {
00134           if(this->joint_position_.unload(buffer))
00135           {
00136                   if (buffer->unload(this->sequence_))
00137                   {
00138                           rtn = true;
00139                           LOG_COMM("Joint traj. pt successfully unloaded");
00140                   }
00141                   else
00142                   {
00143                                 LOG_ERROR("Failed to unload joint traj. pt. sequence number");
00144                                 rtn = false;
00145                   }
00146           }
00147           else
00148           {
00149                   LOG_ERROR("Failed to unload joint traj. pt.  position data");
00150                   rtn = false;
00151           }
00152 
00153   }
00154   else
00155   {
00156           LOG_ERROR("Failed to unload joint traj. pt. velocity");
00157           rtn = false;
00158   }
00159 
00160   return rtn;
00161 }
00162 
00163 }
00164 }
00165 


simple_message
Author(s): Shaun Edwards
autogenerated on Fri Jan 3 2014 11:26:56