Class ServerBase
- Defined in File server.hpp 
Inheritance Relationships
Base Type
- public rclcpp::Waitable
Derived Type
- public rclcpp_action::Server< ActionT >(Template Class Server)
Class Documentation
- 
class ServerBase : public rclcpp::Waitable
- Base Action Server implementation This class should not be used directly by users writing an action server. Instead users should use - rclcpp_action::Server.- Internally, this class is responsible for interfacing with the - rcl_actionAPI.- Subclassed by rclcpp_action::Server< ActionT > - Public Types - Public Functions - 
virtual ~ServerBase()
 - 
size_t get_number_of_ready_subscriptions() override
- Return the number of subscriptions used to implement an action server 
 - 
size_t get_number_of_ready_timers() override
- Return the number of timers used to implement an action server 
 - 
size_t get_number_of_ready_clients() override
- Return the number of service clients used to implement an action server 
 - 
size_t get_number_of_ready_services() override
- Return the number of service servers used to implement an action server 
 - 
size_t get_number_of_ready_guard_conditions() override
- Return the number of guard conditions used to implement an action server 
 - 
void add_to_wait_set(rcl_wait_set_t *wait_set) override
- Add all entities to a wait set. 
 - 
bool is_ready(rcl_wait_set_t*) override
- Return true if any entity belonging to the action server is ready to be executed. 
 - 
std::shared_ptr<void> take_data() override
 - 
std::shared_ptr<void> take_data_by_entity_id(size_t id) override
 - Act on entities in the wait set which are ready to be acted upon. 
 - 
void set_on_ready_callback(std::function<void(size_t, int)> callback) override
- The callback receives a size_t which is the number of messages received since the last time this callback was called. Normally this is 1, but can be > 1 if messages were received before any callback was set. - The callback also receives an int identifier argument, which identifies the action server entity which is ready. This implies that the provided callback can use the identifier to behave differently depending on which entity triggered the waitable to become ready. - Calling it again will clear any previously set callback. - An exception will be thrown if the callback is not callable. - This function is thread-safe. - If you want more information available in the callback, like the subscription or other information, you may use a lambda with captures or std::bind. - Parameters:
- callback – [in] functor to be called when a new message is received. 
 
 - 
void clear_on_ready_callback() override
- Unset the callback to be called whenever the waitable becomes ready. 
 - Protected Functions - 
virtual CancelResponse call_handle_cancel_callback(const GoalUUID &uuid) = 0
 - 
virtual GoalUUID get_goal_id_from_goal_request(void *message) = 0
- Given a goal request message, return the UUID contained within. 
 - 
virtual std::shared_ptr<void> create_goal_request() = 0
- Create an empty goal request message so it can be taken from a lower layer. 
 - Call user callback to inform them a goal has been accepted. 
 - 
virtual GoalUUID get_goal_id_from_result_request(void *message) = 0
- Given a result request message, return the UUID contained within. 
 - 
virtual std::shared_ptr<void> create_result_request() = 0
- Create an empty goal request message so it can be taken from a lower layer. 
 - 
virtual std::shared_ptr<void> create_result_response(decltype(action_msgs::msg::GoalStatus::status) status) = 0
- Create an empty goal result message so it can be sent as a reply in a lower layer 
 - 
void publish_status()
 - 
void notify_goal_terminal_state()
 - 
void set_on_ready_callback(EntityType entity_type, rcl_event_callback_t callback, const void *user_data)
- Set a callback to be called when the specified entity is ready. 
 - Protected Attributes - 
std::recursive_mutex listener_mutex_
 - 
std::unordered_map<EntityType, std::function<void(size_t)>> entity_type_to_on_ready_callback_
 - 
bool on_ready_callback_set_ = {false}
 
- 
virtual ~ServerBase()