💾 Archived View for godocs.io › github.com › mediocregopher › radix › v4 › internal › proc captured on 2024-12-17 at 16:52:58. Gemini links have been rewritten to link to archived content
⬅️ Previous capture (2024-08-19)
-=-=-=-=-=-=-
import "github.com/mediocregopher/radix/v4/internal/proc"
Package proc implements a simple framework for initializing and cleanly shutting down components.
var ErrClosed = errors.New("closed")
ErrClosed indicates that an operation could not be completed because the component has been closed.
type Proc struct { // contains filtered or unexported fields }
Proc implements a lightweight pattern for setting up and tearing down components cleanly and consistently.
func New() *Proc
New initializes and returns a clean Proc.
func (p *Proc) Close(fn func() error) error
Close marks this Proc as having been closed (all methods will return ErrClosed after this), waits for all go-routines spawned with Run to return, and then calls the given callback. If Close is called multiple times it will return ErrClosed the subsequent times without taking any other action.
func (p *Proc) ClosedCh() <-chan struct{}
ClosedCh returns a channel which will be closed when the Proc is closed.
func (p *Proc) IsClosed() bool
IsClosed returns true if Close has been called.
func (p *Proc) PrefixedClose(prefixFn, fn func() error) error
PrefixedClose is like Close but it will additionally perform a callback prior to marking the Proc as closed.
func (p *Proc) Run(fn func(ctx context.Context))
Run spawns a new go-routine which will run with the given callback. The callback's context will be closed when Close is called on Proc, and the go-routine must return for Close to return.
func (p *Proc) WithLock(fn func() error) error
WithLock performs the given callback while holding a write lock on an internal RWMutex. This will return ErrClosed without calling the callback if Close has already been called.
func (p *Proc) WithRLock(fn func() error) error
WithRLock performs the given callback while holding a read lock on an internal RWMutex. This will return ErrClosed without calling the callback if Close has already been called.