async

package
v0.3.4 Latest Latest
Warning

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

Go to latest
Published: Oct 31, 2018 License: MIT Imports: 5 Imported by: 6

Documentation

Index

Constants

View Source
const (
	// LatchStopped is a latch lifecycle state.
	LatchStopped int32 = 0
	// LatchStarting is a latch lifecycle state.
	LatchStarting int32 = 1
	// LatchRunning is a latch lifecycle state.
	LatchRunning int32 = 2
	// LatchStopping is a latch lifecycle state.
	LatchStopping int32 = 3
)
View Source
const (
	// DefaultQueueWorkerMaxWork is the maximum number of work items before queueing blocks.
	DefaultQueueWorkerMaxWork = 1 << 10
)

Variables

View Source
var (
	ErrCannotStart exception.Class = "cannot start; already started"
	ErrCannotStop  exception.Class = "cannot stop; already stopped"
)

Errors

Functions

func RunToError

func RunToError(fns ...func() error) error

RunToError runs a given set of functions until one of them panics or errors. It is useful when you need to start multiple servers and exit if any of them crashes.

Types

type AutoflushBuffer

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

AutoflushBuffer is a backing store that operates either on a fixed length flush or a fixed interval flush. A handler should be provided but without one the buffer will just clear. Adds that would cause fixed length flushes do not block on the flush handler.

func NewAutoflushBuffer

func NewAutoflushBuffer(maxLen int, interval time.Duration) *AutoflushBuffer

NewAutoflushBuffer creates a new autoflush buffer.

func (*AutoflushBuffer) Add

func (ab *AutoflushBuffer) Add(obj interface{})

Add adds a new object to the buffer, blocking if it triggers a flush. If the buffer is full, it will call the flush handler on a separate goroutine.

func (*AutoflushBuffer) AddMany

func (ab *AutoflushBuffer) AddMany(objs ...interface{})

AddMany adds many objects to the buffer at once.

func (*AutoflushBuffer) Flush

func (ab *AutoflushBuffer) Flush()

Flush clears the buffer, if a handler is provided it is passed the contents of the buffer. This call is synchronous, in that it will call the flush handler on the same goroutine.

func (*AutoflushBuffer) FlushAsync

func (ab *AutoflushBuffer) FlushAsync()

FlushAsync clears the buffer, if a handler is provided it is passed the contents of the buffer. This call is asynchronous, in that it will call the flush handler on its own goroutine.

func (*AutoflushBuffer) Interval

func (ab *AutoflushBuffer) Interval() time.Duration

Interval returns the flush interval.

func (*AutoflushBuffer) MaxLen

func (ab *AutoflushBuffer) MaxLen() int

MaxLen returns the maximum buffer length before a flush is triggered.

func (*AutoflushBuffer) NotifyStarted added in v0.3.1

func (ab *AutoflushBuffer) NotifyStarted() <-chan struct{}

NotifyStarted returns the started signal.

func (*AutoflushBuffer) NotifyStopped added in v0.3.1

func (ab *AutoflushBuffer) NotifyStopped() <-chan struct{}

NotifyStopped returns the started stopped.

func (*AutoflushBuffer) ShouldFlushOnAbort

func (ab *AutoflushBuffer) ShouldFlushOnAbort() bool

ShouldFlushOnAbort returns if the buffer will do one final flush on abort.

func (*AutoflushBuffer) Start

func (ab *AutoflushBuffer) Start() error

Start starts the buffer flusher.

func (*AutoflushBuffer) Stop

func (ab *AutoflushBuffer) Stop() error

Stop stops the buffer flusher.

func (*AutoflushBuffer) WithFlushHandler

func (ab *AutoflushBuffer) WithFlushHandler(handler func(objs []interface{})) *AutoflushBuffer

WithFlushHandler sets the buffer flush handler and returns a reference to the buffer.

func (*AutoflushBuffer) WithFlushOnAbort

func (ab *AutoflushBuffer) WithFlushOnAbort(should bool) *AutoflushBuffer

WithFlushOnAbort sets if we should flush on aborts or not. This defaults to true.

type Interval

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

Interval is a managed goroutine that does things.

func NewInterval

func NewInterval(action func() error, interval time.Duration) *Interval

NewInterval returns a new worker that runs an action on an interval.

func (*Interval) Action

func (i *Interval) Action() func() error

Action returns the interval action.

func (*Interval) Delay

func (i *Interval) Delay() time.Duration

Delay returns the start delay.

func (*Interval) Errors

func (i *Interval) Errors() chan error

Errors returns a channel to read action errors from.

func (Interval) Interval

func (i Interval) Interval() time.Duration

Interval returns the interval for the ticker.

func (*Interval) IsRunning

func (i *Interval) IsRunning() bool

IsRunning returns if the worker is running.

func (*Interval) Latch

func (i *Interval) Latch() *Latch

Latch returns the inteval worker latch.

func (*Interval) NotifyStarted added in v0.3.1

func (i *Interval) NotifyStarted() <-chan struct{}

NotifyStarted returns the notify started signal.

func (*Interval) NotifyStopped added in v0.3.1

func (i *Interval) NotifyStopped() <-chan struct{}

NotifyStopped returns the notify stopped signal.

func (*Interval) Start

func (i *Interval) Start() error

Start starts the worker.

func (*Interval) Stop

func (i *Interval) Stop() error

Stop stops the worker.

func (*Interval) WithAction

func (i *Interval) WithAction(action func() error) *Interval

WithAction sets the interval action.

func (*Interval) WithDelay

func (i *Interval) WithDelay(d time.Duration) *Interval

WithDelay sets a start delay time.

func (*Interval) WithErrors

func (i *Interval) WithErrors(errors chan error) *Interval

WithErrors returns the error channel.

func (*Interval) WithInterval

func (i *Interval) WithInterval(d time.Duration) *Interval

WithInterval sets the inteval. It must be set before `.Start()` is called.

type Latch

type Latch struct {
	sync.Mutex
	// contains filtered or unexported fields
}

Latch is a helper to coordinate goroutine lifecycles. The lifecycle is generally as follows. 0 - stopped / idle 1 - starting 2 - running 3 - stopping goto 0 Each state includes a transition notification, i.e. `Starting()` triggers `NotifyStarting`

func NewLatch

func NewLatch() *Latch

NewLatch returns a new latch.

func (*Latch) CanStart

func (l *Latch) CanStart() bool

CanStart returns if the latch can start.

func (*Latch) CanStop

func (l *Latch) CanStop() bool

CanStop returns if the latch can stop.

func (*Latch) IsRunning

func (l *Latch) IsRunning() bool

IsRunning indicates we can signal to stop.

func (*Latch) IsStarting

func (l *Latch) IsStarting() bool

IsStarting indicates the latch is waiting to be scheduled.

func (*Latch) IsStopped

func (l *Latch) IsStopped() (isStopped bool)

IsStopped returns if the latch is stopped.

func (*Latch) IsStopping

func (l *Latch) IsStopping() bool

IsStopping returns if the latch is waiting to finish stopping.

func (*Latch) NotifyStarted

func (l *Latch) NotifyStarted() (notifyStarted <-chan struct{})

NotifyStarted returns the started signal. It is used to coordinate the transition from starting -> started.

func (*Latch) NotifyStarting

func (l *Latch) NotifyStarting() (notifyStarting <-chan struct{})

NotifyStarting returns the started signal. It is used to coordinate the transition from stopped -> starting.

func (*Latch) NotifyStopped

func (l *Latch) NotifyStopped() (notifyStopped <-chan struct{})

NotifyStopped returns the stopped signal. It is used to coordinate the transition from stopping -> stopped.

func (*Latch) NotifyStopping

func (l *Latch) NotifyStopping() (notifyStopping <-chan struct{})

NotifyStopping returns the should stop signal. It is used to trigger the transition from running -> stopping -> stopped.

func (*Latch) Reset

func (l *Latch) Reset()

Reset resets the latch.

func (*Latch) Started

func (l *Latch) Started()

Started signals that the latch is started and has entered the `IsRunning` state.

func (*Latch) Starting

func (l *Latch) Starting()

Starting signals the latch is starting. This is typically done before you kick off a goroutine.

func (*Latch) Stopped

func (l *Latch) Stopped()

Stopped signals the latch has stopped.

func (*Latch) Stopping

func (l *Latch) Stopping()

Stopping signals the latch to stop. It could also be thought of as `SignalStopping`.

type QueueWorker

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

QueueWorker is a worker that is pushed work over a channel.

func NewQueue

func NewQueue(action func(interface{}) error) *QueueWorker

NewQueue returns a new queue worker.

func (*QueueWorker) Enqueue

func (qw *QueueWorker) Enqueue(obj interface{})

Enqueue adds an item to the work queue.

func (*QueueWorker) ErrorCollector

func (qw *QueueWorker) ErrorCollector() chan error

ErrorCollector returns a channel to read action errors from.

func (*QueueWorker) Latch

func (qw *QueueWorker) Latch() *Latch

Latch returns the worker latch.

func (*QueueWorker) MaxWork

func (qw *QueueWorker) MaxWork() int

MaxWork returns the maximum work.

func (*QueueWorker) Start

func (qw *QueueWorker) Start()

Start starts the worker.

func (*QueueWorker) Stop

func (qw *QueueWorker) Stop()

Stop stops the worker.

func (*QueueWorker) WithErrorCollector

func (qw *QueueWorker) WithErrorCollector(errors chan error) *QueueWorker

WithErrorCollector returns the error channel.

func (*QueueWorker) WithMaxWork

func (qw *QueueWorker) WithMaxWork(maxWork int) *QueueWorker

WithMaxWork sets the worker max work.

Jump to

Keyboard shortcuts

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