27#include <lttng/tracepoint.h>
38using namespace std::chrono_literals;
46: schedulerThread(nullptr),
47 signalDetectorLoop(nullptr),
48 signalDetector(nullptr),
83 lastState_ = std::numeric_limits<int64_t>::quiet_NaN();
100 auto & orthogonal = pair.second;
101 auto & clients = orthogonal->getClients();
103 for (
auto & client : clients)
108 if (updatableClient !=
nullptr)
116 std::vector<std::shared_ptr<ISmaccComponent>> components;
117 client->getComponents(components);
118 for (
auto & componententry : components)
120 auto updatableComponent =
dynamic_cast<ISmaccUpdatable *
>(componententry.get());
121 if (updatableComponent !=
nullptr)
125 "Adding updatable component: " <<
demangleType(
typeid(*updatableComponent)));
146 auto & orthogonal = pair.second;
147 auto & behaviors = orthogonal->getClientBehaviors().back();
149 for (
auto & currentBehavior : behaviors)
154 if (updatableClientBehavior !=
nullptr)
158 "Adding updatable behavior: " <<
demangleType(
typeid(updatableClientBehavior)));
159 updatableElements.push_back(updatableClientBehavior);
165 if (updatableState !=
nullptr)
167 updatableElements.push_back(updatableState);
171 for (
auto & sr : statereactors)
174 if (updatableStateReactor !=
nullptr)
178 "Adding updatable stateReactorr: " <<
demangleType(
typeid(updatableStateReactor)));
179 updatableElements.push_back(updatableStateReactor);
184 for (
auto & eg : eventgenerators)
187 if (updatableEventGenerator !=
nullptr)
191 "Adding updatable eventGenerator: " <<
demangleType(
typeid(updatableEventGenerator)));
192 updatableElements.push_back(updatableEventGenerator);
250 RCLCPP_INFO(
getLogger(),
"[SignalDetector] Terminating scheduler...");
280 auto updatableElementName =
demangleType(
typeid(*updatableClient)).c_str();
285 "[PollOnce] update client call: " <<
demangleType(
typeid(*updatableClient)));
291 catch (
const std::exception & e)
295 "Error in updatable elemnent " << updatableElementName <<
": " << e.what() <<
'\n');
304 this->smaccStateMachine_->stateMachineCurrentAction !=
306 this->smaccStateMachine_->stateMachineCurrentAction !=
308 this->smaccStateMachine_->stateMachineCurrentAction !=
316 for (
auto * udpatableStateElement : stateElement)
318 std::string updatableElementName =
demangleType(
typeid(*udpatableStateElement));
319 auto updatableElementNameCstr = updatableElementName.c_str();
322 getLogger(),
"pollOnce update client behavior call: "
332 catch (std::exception & ex)
334 RCLCPP_ERROR(
getLogger(),
"Exception during Signal Detector update loop. %s.", ex.what());
338 rclcpp::spin_some(nh);
350 rclcpp::Node::SharedPtr _;
360 if (!nh->get_parameter(
"signal_detector_loop_freq", this->loop_rate_hz))
364 "Signal Detector frequency (ros param signal_detector_loop_freq) was not set, using default "
372 getLogger(),
"Signal Detector frequency (ros param signal_detector_loop_freq): %lf",
376 nh->set_parameter(rclcpp::Parameter(
"signal_detector_loop_freq", this->
loop_rate_hz));
382 RCLCPP_INFO_STREAM(
getLogger(),
"[SignalDetector] Running in single-threaded mode.");
385 while (rclcpp::ok() && !
end_)
387 RCLCPP_INFO_STREAM_THROTTLE(
390 rclcpp::spin_some(nh);
396 RCLCPP_INFO_STREAM(
getLogger(),
"[SignalDetector] Running in multi-threaded mode.");
398 rclcpp::executors::MultiThreadedExecutor executor;
399 executor.add_node(nh);
425 RCLCPP_INFO(rclcpp::get_logger(
"SMACC"),
"SignalDetector: SIGQUIT received.");
StateMachineInternalAction stateMachineCurrentAction
rclcpp::Node::SharedPtr getNode()
const std::map< std::string, std::shared_ptr< smacc2::ISmaccOrthogonal > > & getOrthogonals() const
std::recursive_mutex m_mutex_
std::vector< std::shared_ptr< StateReactor > > & getStateReactors()
std::vector< std::shared_ptr< SmaccEventGenerator > > & getEventGenerators()
SmaccFifoScheduler * scheduler_
void terminateScheduler()
boost::thread signalDetectorThread_
void notifyStateExited(ISmaccState *currentState)
ExecutionModel executionModel_
void initialize(ISmaccStateMachine *stateMachine)
std::vector< std::vector< ISmaccUpdatable * > > updatableStateElements_
rclcpp::Logger getLogger()
rclcpp::Node::SharedPtr getNode()
SmaccFifoScheduler::processor_handle processorHandle_
SignalDetector(SmaccFifoScheduler *scheduler, ExecutionModel executionModel=ExecutionModel::SINGLE_THREAD_SPINNER)
std::atomic< int64_t > lastState_
std::vector< ISmaccUpdatable * > updatableClients_
void setProcessorHandle(SmaccFifoScheduler::processor_handle processorHandle)
void findUpdatableStateElements(ISmaccState *currentState)
void findUpdatableClientsAndComponents()
ISmaccStateMachine * smaccStateMachine_
void notifyStateConfigured(ISmaccState *currentState)
std::atomic< bool > initialized_
static SmExecution & getInstance()
SignalDetector * signalDetector
std::string demangleType(const std::type_info *tinfo)
void onSignalShutdown(int sig)
boost::statechart::fifo_scheduler< SmaccFifoWorker, SmaccAllocator > SmaccFifoScheduler
void TRACEPOINT(spinOnce)
smacc2_state_update_start