events

package
v0.12.0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Sep 15, 2020 License: Apache-2.0 Imports: 11 Imported by: 4

Documentation

Index

Constants

View Source
const DefaultPolling = time.Millisecond * time.Duration(200)

Variables

View Source
var (
	Error = New("error")
)

Functions

This section is empty.

Types

type Event

type Event struct {
	ID   ID
	Data interface{}
}

Event represents a system event that is returned from an event source

type Function

type Function func(ctx context.Context) (core.Value, error)

type GenericSource added in v0.10.0

type GenericSource struct {
	// contains filtered or unexported fields
}

GenericSource represents a helper struct for generating custom event sources

func (*GenericSource) Close added in v0.10.0

func (src *GenericSource) Close() error

func (*GenericSource) EventID added in v0.10.0

func (src *GenericSource) EventID() ID

func (*GenericSource) Ready added in v0.10.0

func (src *GenericSource) Ready() <-chan struct{}

func (*GenericSource) Recv added in v0.10.0

func (src *GenericSource) Recv() (Event, error)

func (*GenericSource) RecvMsg added in v0.10.0

func (src *GenericSource) RecvMsg(m interface{}) error

type Handler added in v0.10.0

type Handler func(ctx context.Context, message interface{}) bool

Handler represents a function that is called when a particular event occurs Returned boolean value indicates whether the handler needs to be called again False value indicated that it needs to be removed and never called again

func Always added in v0.10.0

func Always(fn func(ctx context.Context, message interface{})) Handler

Always returns a handler wrapper that always gets executed by an event loop

func Once added in v0.10.0

func Once(fn func(ctx context.Context, message interface{})) Handler

Once returns a handler wrapper that gets executed only once by an event loop

type ID added in v0.10.0

type ID int

ID represents a unique event ID

func New added in v0.10.0

func New(name string) ID

type Listener added in v0.10.0

type Listener struct {
	ID      ListenerID
	EventID ID
	Handler Handler
}

Listener is an internal listener representation

type ListenerCollection added in v0.10.0

type ListenerCollection struct {
	// contains filtered or unexported fields
}

func NewListenerCollection added in v0.10.0

func NewListenerCollection() *ListenerCollection

func (*ListenerCollection) Add added in v0.10.0

func (lc *ListenerCollection) Add(listener Listener)

func (*ListenerCollection) Remove added in v0.10.0

func (lc *ListenerCollection) Remove(eventID ID, listenerID ListenerID)

func (*ListenerCollection) Size added in v0.10.0

func (lc *ListenerCollection) Size(eventID ID) int

func (*ListenerCollection) Values added in v0.10.0

func (lc *ListenerCollection) Values(eventID ID) []Listener

type ListenerID added in v0.10.0

type ListenerID int

ListenerID is an internal listener ID that can be used to unsubscribe from a particular event

type Loop added in v0.10.0

type Loop struct {
	// contains filtered or unexported fields
}

func NewLoop added in v0.10.0

func NewLoop() *Loop

func (*Loop) AddListener added in v0.10.0

func (loop *Loop) AddListener(eventID ID, handler Handler) ListenerID

func (*Loop) AddSource added in v0.10.0

func (loop *Loop) AddSource(source Source)

func (*Loop) RemoveListener added in v0.10.0

func (loop *Loop) RemoveListener(eventID ID, listenerID ListenerID)

func (*Loop) RemoveSource added in v0.10.0

func (loop *Loop) RemoveSource(source Source)

func (*Loop) Run added in v0.12.0

func (loop *Loop) Run(ctx context.Context)

type Source added in v0.10.0

type Source interface {
	rpcc.Stream
	Recv() (Event, error)
}

Source represents a custom source of system events

func NewSource added in v0.10.0

func NewSource(
	eventID ID,
	stream rpcc.Stream,
	recv func(stream rpcc.Stream) (interface{}, error),
) Source

NewSource create a new custom event source eventID - is a unique event ID stream - is a custom event stream recv - is a value conversion function

type SourceCollection added in v0.10.0

type SourceCollection struct {
	// contains filtered or unexported fields
}

func NewSourceCollection added in v0.10.0

func NewSourceCollection() *SourceCollection

func (*SourceCollection) Add added in v0.10.0

func (sc *SourceCollection) Add(source Source)

func (*SourceCollection) Close added in v0.10.0

func (sc *SourceCollection) Close() error

func (*SourceCollection) Get added in v0.10.0

func (sc *SourceCollection) Get(idx int) (Source, error)

func (*SourceCollection) Remove added in v0.10.0

func (sc *SourceCollection) Remove(source Source) bool

func (*SourceCollection) Size added in v0.10.0

func (sc *SourceCollection) Size() int

type WaitTask

type WaitTask struct {
	// contains filtered or unexported fields
}

func NewEvalWaitTask

func NewEvalWaitTask(
	ec *eval.ExecutionContext,
	predicate string,
	polling time.Duration,
) *WaitTask

func NewValueWaitTask added in v0.7.0

func NewValueWaitTask(
	when drivers.WaitEvent,
	value core.Value,
	getter Function,
	polling time.Duration,
) *WaitTask

func NewWaitTask

func NewWaitTask(
	fun Function,
	polling time.Duration,
) *WaitTask

func (*WaitTask) Run

func (task *WaitTask) Run(ctx context.Context) (core.Value, error)

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL