SST
11.1.0
StructuralSimulationToolkit
|
A OneShot Event class. More...
#include <oneshot.h>
Public Types | |
using | HandlerBase = SSTHandlerBaseNoArgs< void, false > |
Base handler for OneShot callbacks. | |
template<typename classT , typename dataT = void> | |
using | Handler = SSTHandlerNoArgs< void, classT, false, dataT > |
Used to create handlers for clock. More... | |
Public Member Functions | |
OneShot (TimeConverter *timeDelay, int priority=ONESHOTPRIORITY) | |
Create a new One Shot for a specified time that will callback the handler function. More... | |
bool | isScheduled () |
Is OneShot scheduled. | |
void | registerHandler (OneShot::HandlerBase *handler) |
Add a handler to be called on this OneShot Event. | |
void | print (const std::string &header, Output &out) const override |
Print details about the OneShot. | |
Public Member Functions inherited from SST::Activity | |
void | setDeliveryTime (SimTime_t time) |
Set the time for which this Activity should be delivered. | |
SimTime_t | getDeliveryTime () const |
Return the time at which this Activity will be delivered. | |
int | getPriority () const |
Return the Priority of this Activity. | |
std::string | getDeliveryTimeInfo () const |
virtual std::string | toString () const |
Get a string represenation of the event. More... | |
void | setQueueOrder (uint64_t order) |
Set a new Queue order. | |
uint64_t | getQueueOrder () |
int32_t | getEnforceLinkOrder () |
Public Member Functions inherited from SST::Core::Serialization::serializable | |
virtual const char * | cls_name () const =0 |
virtual uint32_t | cls_id () const =0 |
virtual std::string | serialization_name () const =0 |
Additional Inherited Members | |
Static Public Attributes inherited from SST::Core::Serialization::serializable | |
static constexpr uint32_t | NullClsId = std::numeric_limits<uint32_t>::max() |
Protected Types inherited from SST::Core::Serialization::serializable | |
enum | cxn_flag_t { ConstructorFlag } |
Protected Member Functions inherited from SST::Action | |
void | endSimulation () |
Called to signal to the Simulation object to end the simulation. | |
void | endSimulation (SimTime_t end) |
Protected Member Functions inherited from SST::Activity | |
void | setPriority (int priority) |
Set the priority of the Activity. | |
void | serialize_order (SST::Core::Serialization::serializer &ser) override |
Static Protected Member Functions inherited from SST::Core::Serialization::serializable | |
static void | serializable_abort (uint32_t line, const char *file, const char *func, const char *obj) |
Protected Attributes inherited from SST::Activity | |
int32_t | enforce_link_order |
using SST::OneShot::Handler = SSTHandlerNoArgs<void, classT, false, dataT> |
Used to create handlers for clock.
The callback function is expected to be in the form of:
void func()
In which case, the class is created with:
new OneShot::Handler<classname>(this, &classname::function_name)
Or, to add static data, the callback function is:
void func(dataT data)
and the class is created with:
new OneShot::Handler<classname, dataT>(this, &classname::function_name, data)
SST::OneShot::OneShot | ( | TimeConverter * | timeDelay, |
int | priority = ONESHOTPRIORITY |
||
) |
Create a new One Shot for a specified time that will callback the handler function.
Note: OneShot cannot be canceled, and will always callback after the timedelay.
References SST::Activity::setPriority().