Documentation ¶
Index ¶
- func EmitEvent(m Module, ev stdtypes.Event)
- func EmitEvents(m Module, events *stdtypes.EventList)
- func EmitMirEvent(m Module, ev *eventpbtypes.Event)
- func MirOrigin(contextID ContextID) *dslpbtypes.Origin
- func UponEvent[T stdtypes.Event](m Module, handler func(ev T) error)
- func UponMirEvent[EvWrapper eventpbtypes.Event_TypeWrapper[Ev], Ev any](m Module, handler func(ev *Ev) error)
- func UponOtherEvent(m Module, handler func(ev stdtypes.Event) error)
- func UponStateUpdate(m Module, handler func() error)
- func UponStateUpdates(m Module, handler func() error)
- type ContextID
- type Handle
- type Module
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func EmitEvents ¶
EmitEvents adds the events to the queue of output events.
func EmitMirEvent ¶
func EmitMirEvent(m Module, ev *eventpbtypes.Event)
EmitMirEvent adds the Mir-generated event to the queue of output events. NB: this function works with the Mir-generated types. For use with the general event type, see EmitEvent.
func MirOrigin ¶
func MirOrigin(contextID ContextID) *dslpbtypes.Origin
MirOrigin creates a dslpb.Origin protobuf.
func UponEvent ¶
UponEvent registers an event handler for module m. This event handler will be called every time an event of type EvWrapper is received. NB: This function works with the (legacy) protoc-generated types and is likely to be removed in the future, with UponMirEvent taking its place.
func UponMirEvent ¶
func UponMirEvent[EvWrapper eventpbtypes.Event_TypeWrapper[Ev], Ev any](m Module, handler func(ev *Ev) error)
UponMirEvent registers an event handler for module m. This event handler will be called every time an event of type EvWrapper is received. NB: this function works with the Mir-generated types. For all other types, use the general UponEvent. We treat Mir-generated events specially, since all are grouped under a single common *eventpb.Event type and we need to make a distinction of different sub-types.
func UponStateUpdate ¶
UponStateUpdate registers a special type of handler that is invoked after the processing of every event. The handler is intended to represent a conditional action: it is supposed to check some predicate on the state and perform actions if the predicate is satisfied. This is, however, not enforced in any way, and the handler can contain arbitrary code. Use with care, especially if the execution overhead of the handler is not negligible. Execution of these handlers might easily have a severe impact on performance.
func UponStateUpdates ¶
UponStateUpdates registers a special type of handler that is invoked each time after processing a batch of events. It is a less resource-intensive alternative to UponStateUpdate that is useful if intermediate states of the module are not relevant (as not all intermediate states of the module are observed by handlers registered using UponStateUpdates).
ATTENTION: The handler always called after applying a *batch of* events, not after individual event application. This can lead to unintuitive behavior. For example, a counter module maintaining an internal counter variable that is incremented on every event could register a state update handler checking for counter == 10. Due to (unpredictable) event application batching, the counter can go from 0 to 20 without having triggered the condition handler, if events 10 and 11 are applied in the same batch.
Types ¶
type Handle ¶
type Handle struct {
// contains filtered or unexported fields
}
Handle is used to manage internal state of the dsl module.
func (Handle) CleanupContext ¶
CleanupContext schedules a disposal of context with the given id after the current batch of events is processed. NB: the context cannot be disposed of immediately because there may be more event handlers for this event that may need this context.
func (Handle) RecoverAndCleanupContext ¶
RecoverAndCleanupContext recovers the context with te given id and schedules a disposal of this context after the current batch of events is processed. NB: the context cannot be disposed of immediately because there may be more event handlers for this event that may need this context.
func (Handle) RecoverAndRetainContext ¶
RecoverAndRetainContext recovers the context with the given id and retains it in the internal context store so that it can be recovered again later. Only use this function when expecting to receive multiple events with the same context. In case of a typical request-response semantic, use RecoverAndCleanupContext.
func (Handle) StoreContext ¶
StoreContext stores the given data and returns an automatically deterministically generated unique id. The data can be later recovered or disposed of using this id.
type Module ¶
type Module interface { modules.PassiveModule // DslHandle is used to manage internal state of the dsl module. DslHandle() Handle // ModuleID returns the identifier of the module. // TODO: consider moving this method to modules.Module. ModuleID() stdtypes.ModuleID }
Module allows creating passive modules in a very natural declarative way.