client_helpers.h
Go to the documentation of this file.
00001 /*********************************************************************
00002 * Software License Agreement (BSD License)
00003 *
00004 *  Copyright (c) 2008, Willow Garage, Inc.
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
00009 *  are met:
00010 *
00011 *   * Redistributions of source code must retain the above copyright
00012 *     notice, this list of conditions and the following disclaimer.
00013 *   * Redistributions in binary form must reproduce the above
00014 *     copyright notice, this list of conditions and the following
00015 *     disclaimer in the documentation and/or other materials provided
00016 *     with the distribution.
00017 *   * Neither the name of the Willow Garage nor the names of its
00018 *     contributors may be used to endorse or promote products derived
00019 *     from this software without specific prior written permission.
00020 *
00021 *  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
00022 *  "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
00023 *  LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
00024 *  FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
00025 *  COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
00026 *  INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
00027 *  BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
00028 *  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
00029 *  CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
00030 *  LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
00031 *  ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
00032 *  POSSIBILITY OF SUCH DAMAGE.
00033 *********************************************************************/
00034 
00035 #ifndef ACTIONLIB_GOAL_MANAGER_H_
00036 #define ACTIONLIB_GOAL_MANAGER_H_
00037 
00038 #include <boost/thread/recursive_mutex.hpp>
00039 #include <boost/interprocess/sync/scoped_lock.hpp>
00040 #include <boost/shared_ptr.hpp>
00041 #include <boost/weak_ptr.hpp>
00042 
00043 
00044 #include "actionlib/action_definition.h"
00045 
00046 #include "actionlib/managed_list.h"
00047 #include "actionlib/enclosure_deleter.h"
00048 #include "actionlib/goal_id_generator.h"
00049 
00050 #include "actionlib/client/comm_state.h"
00051 #include "actionlib/client/terminal_state.h"
00052 
00053 #include "actionlib/destruction_guard.h"
00054 
00055 // msgs
00056 #include "actionlib_msgs/GoalID.h"
00057 #include "actionlib_msgs/GoalStatusArray.h"
00058 
00059 namespace actionlib
00060 {
00061 
00062 template <class ActionSpec>
00063 class ClientGoalHandle;
00064 
00065 template <class ActionSpec>
00066 class CommStateMachine;
00067 
00068 template <class ActionSpec>
00069 class GoalManager
00070 {
00071 public:
00072   ACTION_DEFINITION(ActionSpec);
00073   typedef GoalManager<ActionSpec> GoalManagerT;
00074   typedef ClientGoalHandle<ActionSpec> GoalHandleT;
00075   typedef boost::function<void (GoalHandleT) > TransitionCallback;
00076   typedef boost::function<void (GoalHandleT, const FeedbackConstPtr&) > FeedbackCallback;
00077   typedef boost::function<void (const ActionGoalConstPtr)> SendGoalFunc;
00078   typedef boost::function<void (const actionlib_msgs::GoalID&)> CancelFunc;
00079 
00080   GoalManager(const boost::shared_ptr<DestructionGuard>& guard) : guard_(guard) { }
00081 
00082   void registerSendGoalFunc(SendGoalFunc send_goal_func);
00083   void registerCancelFunc(CancelFunc cancel_func);
00084 
00085   GoalHandleT initGoal( const Goal& goal,
00086                         TransitionCallback transition_cb = TransitionCallback(),
00087                         FeedbackCallback feedback_cb = FeedbackCallback() );
00088 
00089   void updateStatuses(const actionlib_msgs::GoalStatusArrayConstPtr& status_array);
00090   void updateFeedbacks(const ActionFeedbackConstPtr& action_feedback);
00091   void updateResults(const ActionResultConstPtr& action_result);
00092 
00093   friend class ClientGoalHandle<ActionSpec>;
00094 
00095   // should be private
00096   typedef ManagedList< boost::shared_ptr<CommStateMachine<ActionSpec> > > ManagedListT;
00097   ManagedListT list_;
00098 private:
00099   SendGoalFunc send_goal_func_ ;
00100   CancelFunc cancel_func_ ;
00101 
00102   boost::shared_ptr<DestructionGuard> guard_;
00103 
00104   boost::recursive_mutex list_mutex_;
00105 
00106   GoalIDGenerator id_generator_;
00107 
00108   void listElemDeleter(typename ManagedListT::iterator it);
00109 };
00110 
00118 template <class ActionSpec>
00119 class ClientGoalHandle
00120 {
00121 private:
00122   ACTION_DEFINITION(ActionSpec);
00123 
00124 public:
00131   ClientGoalHandle();
00132 
00133   ~ClientGoalHandle();
00134 
00141   void reset();
00142 
00149   inline bool isExpired() const;
00150 
00158   CommState getCommState();
00159 
00167   TerminalState getTerminalState();
00168 
00174   ResultConstPtr getResult();
00175 
00181   void resend();
00182 
00188   void cancel();
00189 
00194   bool operator==(const ClientGoalHandle<ActionSpec>& rhs) const;
00195 
00199   bool operator!=(const ClientGoalHandle<ActionSpec>& rhs) const;
00200 
00201   friend class GoalManager<ActionSpec>;
00202 private:
00203   typedef GoalManager<ActionSpec> GoalManagerT;
00204   typedef ManagedList< boost::shared_ptr<CommStateMachine<ActionSpec> > > ManagedListT;
00205 
00206   ClientGoalHandle(GoalManagerT* gm, typename ManagedListT::Handle handle, const boost::shared_ptr<DestructionGuard>& guard);
00207 
00208   GoalManagerT* gm_;
00209   bool active_;
00210   //typename ManagedListT::iterator it_;
00211   boost::shared_ptr<DestructionGuard> guard_;   // Guard must still exist when the list_handle_ is destroyed
00212   typename ManagedListT::Handle list_handle_;
00213 };
00214 
00215 template <class ActionSpec>
00216 class CommStateMachine
00217 {
00218   private:
00219     //generates typedefs that we'll use to make our lives easier
00220     ACTION_DEFINITION(ActionSpec);
00221 
00222   public:
00223     typedef boost::function<void (const ClientGoalHandle<ActionSpec>&) > TransitionCallback;
00224     typedef boost::function<void (const ClientGoalHandle<ActionSpec>&, const FeedbackConstPtr&) > FeedbackCallback;
00225     typedef ClientGoalHandle<ActionSpec> GoalHandleT;
00226 
00227     CommStateMachine(const ActionGoalConstPtr& action_goal,
00228                      TransitionCallback transition_callback,
00229                      FeedbackCallback feedback_callback);
00230 
00231     ActionGoalConstPtr getActionGoal() const;
00232     CommState getCommState() const;
00233     actionlib_msgs::GoalStatus getGoalStatus() const;
00234     ResultConstPtr getResult() const;
00235 
00236     // Transitions caused by messages
00237     void updateStatus(GoalHandleT& gh, const actionlib_msgs::GoalStatusArrayConstPtr& status_array);
00238     void updateFeedback(GoalHandleT& gh, const ActionFeedbackConstPtr& feedback);
00239     void updateResult(GoalHandleT& gh, const ActionResultConstPtr& result);
00240 
00241     // Forced transitions
00242     void transitionToState(GoalHandleT& gh, const CommState::StateEnum& next_state);
00243     void transitionToState(GoalHandleT& gh, const CommState& next_state);
00244     void processLost(GoalHandleT& gh);
00245   private:
00246     CommStateMachine();
00247 
00248     // State
00249     CommState state_;
00250     ActionGoalConstPtr action_goal_;
00251     actionlib_msgs::GoalStatus latest_goal_status_;
00252     ActionResultConstPtr latest_result_;
00253 
00254     // Callbacks
00255     TransitionCallback transition_cb_;
00256     FeedbackCallback   feedback_cb_;
00257 
00258     // **** Implementation ****
00260     void setCommState(const CommState& state);
00261     void setCommState(const CommState::StateEnum& state);
00262     const actionlib_msgs::GoalStatus* findGoalStatus(const std::vector<actionlib_msgs::GoalStatus>& status_vec) const;
00263 };
00264 
00265 }
00266 
00267 #include "actionlib/client/goal_manager_imp.h"
00268 #include "actionlib/client/client_goal_handle_imp.h"
00269 #include "actionlib/client/comm_state_machine_imp.h"
00270 
00271 #endif // ACTIONLIB_GOAL_MANAGER_H_


actionlib
Author(s): Eitan Marder-Eppstein, Vijay Pradeep
autogenerated on Fri Aug 28 2015 10:04:41