syncz

package
v16.10.5 Latest Latest
Warning

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

Go to latest
Published: May 7, 2024 License: MIT Imports: 5 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

This section is empty.

Types

type EventCallback added in v16.2.0

type EventCallback[E any] func(ctx context.Context, e E)

type Mutex

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

Mutex is a non-reentrant (like sync.Mutex) mutex that (unlike sync.Mutex) allows to acquire the mutex with a possibility to abort the attempt early if a context signals done.

A buffered channel of size 1 is used as the mutex. Think of it as of a box - the party that has put something into it has acquired the mutex. To unlock it, remove the contents from the box, so that someone else can use it. An empty box is created in the NewMutex() constructor.

TryLock, Lock, and Unlock provide memory access ordering guarantees by piggybacking on channel's "happens before" guarantees. See https://golang.org/ref/mem

func NewMutex

func NewMutex() Mutex

func (Mutex) Lock

func (m Mutex) Lock(ctx context.Context) bool

func (Mutex) TryLock

func (m Mutex) TryLock() bool

func (Mutex) Unlock

func (m Mutex) Unlock()

type StripedValue added in v16.4.0

type StripedValue[V any] struct {
	// Stripes holds the stripes.
	Stripes []V
	// contains filtered or unexported fields
}

StripedValue is a value that is partitioned into 2^n stripes. See https://github.com/google/guava/wiki/StripedExplained for a similar idea applied to mutexes.

Number of stripes is a power of two to make it possible to use fast bit operations instead of slow division remainder.

func NewStripedValueInit added in v16.4.0

func NewStripedValueInit[V any](n int, newV func() V) StripedValue[V]

NewStripedValueInit constructs a new striped value. Each stripe has a value provided by a constructor function.

It's not a pointer because it doesn't contain any non-pointer mutable fields.

func (*StripedValue[V]) GetPointer added in v16.4.0

func (v *StripedValue[V]) GetPointer(x int64) *V

GetPointer retrieves the pointer to the stripe for x.

type Subscriptions added in v16.2.0

type Subscriptions[E any] struct {
	// contains filtered or unexported fields
}

func (*Subscriptions[E]) Dispatch added in v16.2.0

func (s *Subscriptions[E]) Dispatch(ctx context.Context, e E)

Dispatch dispatches the given event to all added subscriptions.

func (*Subscriptions[E]) On added in v16.2.0

func (s *Subscriptions[E]) On(ctx context.Context, cb EventCallback[E])

type Worker added in v16.1.3

type Worker interface {
	Run(context.Context)
}

type WorkerFunc added in v16.1.3

type WorkerFunc func(context.Context)

func (WorkerFunc) Run added in v16.1.3

func (wf WorkerFunc) Run(ctx context.Context)

type WorkerHolder added in v16.1.3

type WorkerHolder[C any] struct {
	// contains filtered or unexported fields
}

WorkerHolder holds a worker and restarts it when configuration changes.

func NewComparableWorkerHolder added in v16.1.3

func NewComparableWorkerHolder[C comparable](factory func(C) Worker) *WorkerHolder[C]

func NewProtoWorkerHolder added in v16.1.3

func NewProtoWorkerHolder[C proto.Message](factory func(C) Worker) *WorkerHolder[C]

func NewWorkerHolder added in v16.1.3

func NewWorkerHolder[C any](factory func(C) Worker, isEqual func(config1, config2 C) bool) *WorkerHolder[C]

func (*WorkerHolder[C]) ApplyConfig added in v16.1.3

func (w *WorkerHolder[C]) ApplyConfig(ctx context.Context, config C) bool

ApplyConfig ensures a worker is running with the provided or equal config.

This method starts a worker if it's not running already. If it is running and the config is not equal then the worker is stopped, a new worker is started then with the new config.

func (*WorkerHolder[C]) StopAndWait added in v16.1.3

func (w *WorkerHolder[C]) StopAndWait()

Jump to

Keyboard shortcuts

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