Documentation ¶
Overview ¶
Package parl handles inter-thread communication and controls parallelism
parl has sub-packages augmenting the Go standard library:
perrors pfs plog pnet pos pruntime psql pstrings psyscall pterm ptime
parl has feature packages:
ev — handling of goroutine-based functions goid — unique goroutine IDs mains — functions for writing command-line utilities and services parlca — self-signed certificate authority progress — monitor work progress for a large number of threads sqlite — local SQL database threadprof — profiling and counters for what threads are doing // statuser: thread hang detector tracer — event lists by task rather than by time or thread
parl features per-writer thread-safe logging with topic and per-package output control:
Logging is to stderr except for the Out function. parl logging uses comma separator for numbers. One argument is output as string, two or more arguments is Printf. The location matched against the regular expression is full package path, optional type receiver and the funtion name: “github.com/haraldrudell/mypackage.(*MyType).MyFunc”
Out(string, ...interface{}) — Standard output Log(string, ...interface{}) — Always outputs to stderr parl.D(string, ...interface{}) — Same as Log, intended for temporary use Info(string, ...interface{}) — Informational progress messages SetSilent(true) — removes Info output IsSilent() — deteremines if Info printing applies Debug(string, ...interface{}) — only prints for locations where SetDebug(true) SetDebug(true) — Control Debug() globally, code location for all prints, long stack traces SetRegexp(regExp string) (err error) — Regular expression controlling local Debug() printing IsThisDebug() — Determines if debug is active for the executing function Console(string, ...interface{}) — terminal interactivity output
parl.Recover() and parl.Recover2() thread recovery and mains.Executable.Recover() process recovery:
Threads can provide their errors via the perrors.ParlError thread-safe error store, plain error channels, parl.NBChan[error] or parl.ClosableChan[error]. parl.Recover and parl.Recover2 convert thread panic to error along with regular errors, annotating, retrieving and storing those errors and invoking error handling functions for them. mains.Recover is similar for the process.
func thread(errCh *parl.NBChan[error]) { // real-time non-blocking error channel defer errCh.Close() // non-blocking close effective on send complete var err error defer parl.Recover2(parl.Annotation(), &err, errCh.Send) errCh.Ch() <- err // non-blocking if err = someFunc(); err != nil { err = perrors.Errorf("someFunc: %w", err) // labels and attaches a stack return … func myThreadSafeThread(wg *sync.WaitGroup, errs *perrors.ParlError) { // ParlError: thread-safe error store defer wg.Done() var err error defer parl.Recover(parl.Annotation(), &err, errs.AddErrorProc) …
parl package features:
AtomicBool — Thread-safe boolean Closer — Deferrable, panic-free channel close ClosableChan — Initialization-free channel with observable deferrable panic-free close Moderator — A ticketing system for limited parallelism NBChan — A non-blocking channel with trillion-size dynamic buffer SerialDo — Serialization of invocations WaitGroup —Observable WaitGroup Debouncer — Invocation debouncer, pre-generics Sprintf — Supporting thousands separator
Parl is about 15,000 lines of Go code with first line written on November 21, 2018 ¶
On March 16th, 2022, parl was open-sourced under an ISC License ¶
© 2018–present Harald Rudell <harald.rudell@gmail.com> (https://haraldrudell.github.io/haraldrudell/)
Index ¶
- Constants
- Variables
- func AddNotifier(ctx context.Context, notifier NotifierFunc) (ctx2 context.Context)
- func AddNotifier1(ctx context.Context, notifier NotifierFunc) (ctx2 context.Context)
- func AddToPanic(panicValue interface{}, additionalErr error) (err error)
- func Annotation() (annotation string)
- func CancelOnError(errp *error, ctx context.Context)
- func ChannelSend[T any](ch chan<- T, value T, nonBlocking ...bool) (didSend, isNilChannel, isClosedChannel bool, err error)
- func Close(closable io.Closer, errp *error)
- func CloseChannel[T any](ch chan T, errp *error, drainChannel ...bool) (isNilChannel, isCloseOfClosedChannel bool, n int, err error)
- func Closer[T any](ch chan T, errp *error)
- func CloserSend[T any](ch chan<- T, errp *error)
- func CollectError(errCh <-chan error, errp *error) (err error)
- func Console(format string, a ...interface{})
- func Consolew(format string, a ...interface{})
- func D(format string, a ...interface{})
- func Debug(format string, a ...interface{})
- func DoGoGetError(op func() (err error), g0 Go) (err error)
- func DoProcThread(op func(), g0 Go)
- func DoThread(op func() (err error), g0 Go)
- func DoThreadError(op func() (err error), errCh chan<- error, g0 Go)
- func EndCallbacks(err error) (err2 error)
- func EnsureError(panicValue interface{}) (err error)
- func ErrChWait(errCh <-chan error, errp *error)
- func GetD(skipFrames int) (debug func(format string, a ...interface{}))
- func GetDebug(skipFrames int) (debug func(format string, a ...interface{}))
- func HandleErrp(fn func(), errp *error)
- func HandlePanic(fn func()) (err error)
- func HandleParlError(fn func(), storeError func(err error))
- func HasCancel(ctx context.Context) (hasCancel bool)
- func Infallible(err error)
- func Info(format string, a ...interface{})
- func InvokeCancel(ctx context.Context)
- func InvokeIf[T comparable](tp *T, fn func())
- func IsNil(v any) (isNil bool)
- func IsSilent() (isSilent bool)
- func IsThisDebug() bool
- func IsThisDebugN(skipFrames int) (isDebug bool)
- func Log(format string, a ...interface{})
- func Logw(format string, a ...interface{})
- func NBChanLogger[T any](label string, n *NBChan[T], expectClose bool, log ...PrintfFunc)
- func NBChanState[T any](n *NBChan[T]) (s string)
- func New(text string) error
- func NewCancelContext(ctx context.Context) (cancelCtx context.Context)
- func NewCancelContextFunc(ctx context.Context, cancel context.CancelFunc) (cancelCtx context.Context)
- func NewThreadResult(err error) (failure error)
- func NilValueError(err error) (err2 error)
- func NoOnError(err error)
- func OnCancel(fn func(), ctx context.Context)
- func OnDebug(invokedIfDebug func() string)
- func Out(format string, a ...interface{})
- func Outw(format string, a ...interface{})
- func Recover(annotation string, errp *error, onError func(error))
- func Recover2(annotation string, errp *error, onError func(error))
- func RecoverInvocationPanic(fn func(), errp *error)
- func RecoverInvocationPanicErr(fn func() (err error)) (isPanic bool, err error)
- func SendErr(errCh chan<- error, errp *error)
- func SetDebug(debug bool)
- func SetRegexp(regExp string) (err error)
- func SetSilent(silent bool)
- func Short(tim ...time.Time) (s string)
- func ShortMs(tim ...time.Time) (s string)
- func ShortSpace(tim ...time.Time) (s string)
- func Sprintf(format string, a ...any) string
- func Uintptr(v any) (p uintptr)
- type AdbAdressProvider
- type AdbRequest
- type AdbResponseID
- type AdbSocketAddress
- type AdbSyncRequest
- type Adbette
- type Adbetter
- type AddError
- type AddErrorIf
- type AndroidSerial
- type AndroidStatus
- type AtomicBool
- type AtomicCounter
- func (max *AtomicCounter) Add(value uint64) (newValue uint64)
- func (max *AtomicCounter) Dec() (value uint64)
- func (max *AtomicCounter) Dec2() (value uint64, didDec bool)
- func (max *AtomicCounter) Inc() (value uint64)
- func (max *AtomicCounter) Inc2() (value uint64, didInc bool)
- func (max *AtomicCounter) Set(value uint64) (oldValue uint64)
- func (max *AtomicCounter) Value() (value uint64)
- type AtomicMax
- type AtomicMaxDuration
- type AtomicMin
- type AtomicReference
- type CBFunc
- type CBReason
- type CbSlowDetector
- type Certificate
- type CertificateAuthority
- type CertificateDer
- type ClosableChan
- type Counter
- type CounterID
- type CounterSet
- type CounterSetData
- type CounterStore
- type CounterValues
- type Counters
- type CountersFactory
- type CyclicWait
- func (cw *CyclicWait) Cancel()
- func (cw *CyclicWait) CancelAndRearm() (wasRearmed bool)
- func (cw *CyclicWait) Ch() (ch <-chan struct{})
- func (cw *CyclicWait) Context() (ctx context.Context)
- func (cw *CyclicWait) DidOccurer() (didOccurer *OnceWaiterRO)
- func (cw *CyclicWait) Done() (done <-chan struct{})
- func (cw *CyclicWait) IsCancel() (isCancel bool)
- func (cw *CyclicWait) Wait()
- type DB
- type DBFactory
- type DBPartition
- type DSNrFactory
- type DataSource
- type DataSourceNamer
- type Datapoint
- type DatapointValue
- type Debouncer
- type Dent
- type Devicette
- type DevicetteFactory
- type DoErr
- type Doneable
- type EchoModerator
- type Enum
- type EnumItem
- type Err
- type ErrorCloser
- type ErrorManager
- type ErrorSink
- type ErrorString
- type ExecResult
- type FSLocation
- type Frame
- type Future
- type Go
- type GoDebug
- type GoError
- type GoErrorContext
- type GoFactory
- type GoFatalCallback
- type GoGen
- type GoGroup
- type Interval
- type InvokeResult
- type InvokeTimer
- type Invoker
- type Iterator
- type KeyEnum
- type Moderator
- type ModeratorCore
- type MutexWait
- type NBChan
- func (n *NBChan[T]) Capacity() (capacity int)
- func (n *NBChan[T]) Ch() (ch <-chan T)
- func (n *NBChan[T]) Close() (didClose bool)
- func (n *NBChan[T]) CloseNow(errp ...*error) (didClose bool, err error)
- func (n *NBChan[T]) Count() (unsentCount int)
- func (n *NBChan[T]) DataWaitCh() (ch <-chan struct{})
- func (n *NBChan[T]) DidClose() (didClose bool)
- func (n *NBChan[T]) Get(elementCount ...int) (allItems []T)
- func (n *NBChan[T]) IsClosed() (isClosed bool)
- func (n *NBChan[T]) Scavenge(setCapacity int)
- func (n *NBChan[T]) Send(value T)
- func (n *NBChan[T]) SendMany(values []T)
- func (n *NBChan[T]) SetAllocationSize(size int) (nb *NBChan[T])
- func (n *NBChan[T]) SetAlwaysThread() (nb *NBChan[T])
- func (n *NBChan[T]) SetNoThread()
- func (n *NBChan[T]) ThreadStatus() (threadStatus string)
- func (n *NBChan[T]) WaitForClose(errp ...*error)
- func (n *NBChan[T]) WaitForCloseCh() (ch <-chan struct{})
- type NBChanThreadType
- type NotifierFunc
- type Once
- type OnceWaiter
- type OnceWaiterRO
- type Password
- type PemBytes
- type PeriodWaiter
- type Periodically
- type PrintfFunc
- type PrivateKey
- type PrivateKeyDer
- type PrivateKeyFactory
- type Promise
- type PublicKey
- type PublicKeyDer
- type Rate
- type RateCounterValues
- type RateType
- type SelectChannel
- type SerialDo
- type SerialDoCore
- type SerialDoEvent
- type SerialDoID
- type SerialDoType
- type ServerFactory
- type Serverette
- type ServeretteFactory
- type SlowDetector
- func (sd *SlowDetector) IsValid() (isValid bool)
- func (sd *SlowDetector) Start(label string, value ...time.Time) (slowInvocation SlowInvocation)
- func (sd *SlowDetector) Start0() (slowInvocation SlowInvocation)
- func (sd *SlowDetector) Status() (s string)
- func (sd *SlowDetector) Status0() (s string)
- func (sd *SlowDetector) Values() (last, average, max time.Duration, hasValue bool)
- type SlowDetectorCore
- type SlowDetectorInvocation
- func (sdi *SlowDetectorInvocation) Interval(label string, t ...time.Time)
- func (sdi *SlowDetectorInvocation) Intervals() (intervalStr string)
- func (sdi *SlowDetectorInvocation) Label() (label string)
- func (sdi *SlowDetectorInvocation) Stop(value ...time.Time)
- func (sdi *SlowDetectorInvocation) T0() (t0 time.Time)
- func (sdi *SlowDetectorInvocation) ThreadID() (threadID ThreadID)
- func (sdi *SlowDetectorInvocation) Time(t time.Time) (previousT time.Time)
- type SlowDetectorThread
- type SlowInvocation
- type Stack
- type Statuser
- type StatuserFactory
- type SubGo
- type SubGroup
- type SyncAdd
- type SyncDone
- type SyncWait
- type TFunc
- type TResult
- type ThreadData
- type ThreadID
- type ThreadResult
- type ThreadStatus
- type Timer
- type TraceGroup
- type Tracer
- type TracerFactory
- type TracerRecord
- type TracerTaskID
- type Trackerette
- type UniqueID
- type UniqueIDTypedUint64
- type UniqueIDUint64
- type WaitAction
- type WaitDo
- type WaitGroup
- type Waitable
- type WaitedOn
- type Waiter
- type WaitingFor
- type WinOrWaiterCore
- type WinOrWaiterStrategy
Constants ¶
const ( NBChanExpectClose = true NBChanWillNotClose = false )
const ( NBChanExit = "exit" // NBChan thread is not running NBChanAlert = "alert" // NBChan thread is always running and blocked idle waiting for alert NBChanGets = "GetWait" // NBChan thread is blocked waiting for Get invocations to complete NBChanSends = "SendWait" // NBChan thread is blocked waiting for Send/SendMany invocations to complete NBChanSendBlock = "chSend" // NBChan thread is blocked in channel send NBChanRunning = "run" // NBChan is running )
const ( Rfc3339s = "2006-01-02 15:04:05Z07:00" Rfc3339ms = "2006-01-02 15:04:05.000Z07:00" Rfc3339us = "2006-01-02 15:04:05.000000Z07:00" Rfc3339ns = "2006-01-02 15:04:05.000000000Z07:00" )
const ( SlowDefault slowType = iota SlowOwnThread SlowShutdownThread )
const (
CloseChannelDrain = true
)
const SendNonBlocking = true // with nonBlocking set to SendNonBlocking, ChannelSend will never block
Variables ¶
var ErrEndCallbacks = EndCallbacks(errors.New("end callbacks error"))
ErrEndCallbacks indicates upon retun from a callback function that no more callbacks are desired. It does not indicate an error and is not returned as an error by any other function than the callback.
callback invocations may be thread-safe, re-entrant and panic-handling but this depends on the callback-invoking implementation used.
Usage:
if errors.Is(err, parl.ErrEndCallbacks) { …
var ErrErrpNil = NilValueError(errors.New("errp cannot be nil"))
ErrErrpNil indicates that a function with an error pointer argument received an errp nil value.
if errors.Is(err, parl.ErrNilValue) …
var ErrNilValue = NilValueError(errors.New("end callbacks error"))
ErrNilValue indicates that a panic was caused by a value such as a function argument was nil that cannot be nil.
Usage:
if errors.Is(err, parl.ErrNilValue) { …
var ErrNotCancelContext = errors.New("context chain does not have CancelContext")
ErrNotCancelContext indicates that InvokeCancel was provided a context not a return value from NewCancelContext or NewCancelContextFunc.
Tets for ErrNotCancelContext:
if errors.Is(err, parl.ErrNotCancelContext) …
Functions ¶
func AddNotifier ¶ added in v0.4.29
func AddNotifier(ctx context.Context, notifier NotifierFunc) (ctx2 context.Context)
AddNotifier adds a function that is invoked when any context is canceled
func AddNotifier1 ¶ added in v0.4.97
func AddNotifier1(ctx context.Context, notifier NotifierFunc) (ctx2 context.Context)
AddNotifier1 adds a function that is invoked when a child context is canceled
func AddToPanic ¶
AddToPanic takes a recover() value and adds it to additionalErr.
func Annotation ¶
func Annotation() (annotation string)
Annotation provides a default annotation [base package].[function]: "mypackage.MyFunc"
func CancelOnError ¶ added in v0.4.28
CancelOnError invokes InvokeCancel if errp has an error. CancelOnError is deferrable and thread-safe. ctx must have been returned by either NewCancelContext or NewCancelContextFunc.
- errp == nil or *errp == nil means no error
- ctx nil is panic
- ctx not from NewCancelContext or NewCancelContextFunc is panic
- thread-safe, idempotent
func ChannelSend ¶ added in v0.4.101
func ChannelSend[T any](ch chan<- T, value T, nonBlocking ...bool) (didSend, isNilChannel, isClosedChannel bool, err error)
ChannelSend is channel send without panics and possibly non-blocking
- if nonBlocking is SendNonBlocking or true, channel send will be attempted but not block
- didSend is true if value was successfully sent on ch
- err is non-nil if a panic occurred or ch is nil
- isNilChannel is true if the channel is nil, ie. send would block indefinitely
- isClosedChannel is true if the panic was caused by ch being closed
- there should be no panics other than from ch being closed
func Close ¶ added in v0.4.15
Close is a deferrable function that closes an io.Closer object. Close handles panics. if errp is non-nil, panic values updates it using errors.AppendError.
func CloseChannel ¶ added in v0.4.103
func CloseChannel[T any](ch chan T, errp *error, drainChannel ...bool) ( isNilChannel, isCloseOfClosedChannel bool, n int, err error, )
CloseChannel closes a channel recovering panics
- deferrable
- if errp is non-nil, panic values updates it using errors.AppendError.
- if doDrain is CloseChannelDrain or true, the channel is drained first. Note: closing a channel while a thread is blocked in channel send is a data race. If a thread is continuously sending items and doDrain is true, CloseChannel will block indefinitely.
- n returns the number of drained items.
- isNilChannel returns true if ch is nil. No close will be attempted for a nil channel, it would panic.
func Closer ¶ added in v0.4.0
Closer is a deferrable function that closes a channel. Closer handles panics. if errp is non-nil, panic values updates it using errors.AppendError.
func CloserSend ¶ added in v0.4.15
CloserSend is a deferrable function that closes a send-channel. CloserSend handles panics. if errp is non-nil, panic values updates it using errors.AppendError.
func CollectError ¶ added in v0.4.95
CollectError is a deferrable function that reads a single error value from errCh
- if a non-nil error value is received, it is appended to errp
- CollectError is used to wait for a goroutine sending its result on a channel
func Console ¶
func Console(format string, a ...interface{})
Console always prints to interactive standard out
- intended for command-line interactivity.
- if debug is enabled, code location is appended.
func Consolew ¶ added in v0.4.12
func Consolew(format string, a ...interface{})
Consolew always prints to standard out
- intended for command-line interactivity.
- Consolew does not ensure ending newline
func D ¶
func D(format string, a ...interface{})
D always prints to stderr with code location. Thread-safe
- D is meant for temporary output intended to be removed prior to check-in
func Debug ¶
func Debug(format string, a ...interface{})
Debug outputs only if debug is configured globally or for the executing function
- Debug outputs to standard error
- code location is appended
func DoGoGetError ¶ added in v0.4.26
DoGoGetError executes op in a thread. err contains any error, error are not submitted to Go object. DoGoGetError blocks until the goroutine completes.
func DoProcThread ¶ added in v0.4.26
func DoProcThread(op func(), g0 Go)
func DoThread ¶ added in v0.4.26
DoThread is invoked in a go statement and executes op. g0 receives errors and is the wait-for function.
func DoThreadError ¶ added in v0.4.26
DoThreadError is a goroutine that returns its error separately.
func EndCallbacks ¶ added in v0.4.46
func EnsureError ¶
func EnsureError(panicValue interface{}) (err error)
AddToPanic ensures that a recover() value is an error or nil.
func ErrChWait ¶ added in v0.4.100
ErrChWait is a deferrable function receiving an error value on a channel
- used to wait for a goroutine
Usage:
var err error defer errorHandler(&err) var errCh = make(chan error, 1) go someFunc(errCh) defer parl.ErrChWait(errCh, &err) func someFunc(errCh chan<- error) { var err error defer parl.SendErr(errCh, &err) defer parl.Recover(parl.Annotation(), &err, parl.NoOnError)
func GetD ¶ added in v0.4.26
GetD returns a function value that always invokes logging
- output to stderr
- the caller frame is appended
- D is meant for temporary output intended to be removed prior to check-in
- the function value can be passed around or invoked later
func GetDebug ¶ added in v0.4.25
GetDebug returns a function value that can be used to invokes logging
- output to stderr if debug is enabled for the specified caller frame
- the caller frame is appended
- the function value can be passed around or invoked later
func HandleErrp ¶ added in v0.2.2
func HandleErrp(fn func(), errp *error)
HandleErrp recovers from a panic in fn storing at *errp. HandleErrp is deferable.
func HandlePanic ¶
func HandlePanic(fn func()) (err error)
HandlePanic recovers from panic in fn returning error.
func HandleParlError ¶ added in v0.2.2
func HandleParlError(fn func(), storeError func(err error))
HandleParlError recovers from panic in fn invoking an error callback. HandleParlError is deferable storeError can be the thread-safe perrors.ParlError.AddErrorProc()
func Infallible ¶ added in v0.4.12
func Infallible(err error)
func Info ¶
func Info(format string, a ...interface{})
Info prints unless silence has been configured with SetSilence(true)
- Info outputs to standard error
- IsSilent() deteremines the state of silence
- if debug is enabled, code location is appended
func InvokeCancel ¶ added in v0.4.28
InvokeCancel finds the cancel method in the context chain and invokes it. ctx must have been returned by either NewCancelContext or NewCancelContextFunc.
- ctx nil is panic
- ctx not from NewCancelContext or NewCancelContextFunc is panic
- thread-safe, idempotent
func InvokeIf ¶ added in v0.4.29
func InvokeIf[T comparable](tp *T, fn func())
InvokeIf is a deferrable function invoking its function argument when:
- the pointer tp is non-nil and the function fn is non-nil
- what tp points to is not a T zero-value
Usage:
someFlag := false defer InvokeIf(&someFlag, someFunction) … someFlag = someValue
func IsNil ¶ added in v0.4.36
IsNil checks whether an interface value is truly nil
- In Go, comparison of an interface value that has been assigned a concretely typed nil value yields unexpected results
- (any)((*int)(nil)) == nil → false, where true is expected
- IsNil((*int)(nil)) → true
- as of go1.20.3, an interface value is 2 pointers,
- — the first currently assigned type and
- —the second currently assigned value
func IsThisDebug ¶
func IsThisDebug() bool
IsThisDebug returns whether the executing code location has debug logging enabled
- true when -debug globally enabled using SetDebug(true)
- true when the -verbose regexp set with SetRegexp matches
func IsThisDebugN ¶ added in v0.4.25
IsThisDebugN returns whether the specified stack frame has debug logging enabled. 0 means caller of IsThisDebugN.
- true when -debug globally enabled using SetDebug(true)
- true when the -verbose regexp set with SetRegexp matches
func Log ¶
func Log(format string, a ...interface{})
Log always prints to standard error
- if debug is enabled, code location is appended
func Logw ¶ added in v0.4.12
func Logw(format string, a ...interface{})
Logw always prints to standard error
- Logw outputs without ensruing ending newline
func NBChanLogger ¶ added in v0.4.100
func NBChanLogger[T any](label string, n *NBChan[T], expectClose bool, log ...PrintfFunc)
NBChanLogger is a debug logger for an NBChan instance
- label is a string leading printouts, default a small integer
- NBChan is the channel watched
- printout continues until the channel is empty and the thread has exited
- if expectClose is true, printout will continue until the underlying channel is closed
- log default is parl.Log
func NBChanState ¶ added in v0.4.100
“length/i/o: 1/0/0 close-now:true-false thread: send sends: 0 gets: 0 always: true-true chClosed: false err: false”
func New ¶
New returns an error that formats as the given text. Each call to New returns a distinct error value even if the text is identical.
func NewCancelContext ¶ added in v0.4.12
NewCancelContext creates a context that can be provided to InvokeCancel. the return value encapsulates a cancel function.
NewCancelContext is like context.WithCancel but with the CancelFunc embedded instead, InvokeCancel is used with cancelCtx as argument.
ctx := NewCancelContext(context.Background()) … InvokeCancel(ctx)
func NewCancelContextFunc ¶ added in v0.4.26
func NewCancelContextFunc(ctx context.Context, cancel context.CancelFunc) (cancelCtx context.Context)
NewCancelContextFunc stores the cancel function cancel in the context ctx. the returned context can be provided to InvokeCancel to cancel the context.
func NewThreadResult ¶ added in v0.4.12
func NilValueError ¶ added in v0.4.46
func NoOnError ¶ added in v0.4.12
func NoOnError(err error)
NoOnError is used with Recover to silence the default error logging
func OnCancel ¶ added in v0.4.12
OnCancel invokes fn when work done on behalf of context ctx should be canceled
func OnDebug ¶ added in v0.4.114
func OnDebug(invokedIfDebug func() string)
OnDebug is similar to parl.Debug but arguments are only resolved when debug is true, ie. when arguments should actually be printed
- the argument can be a function literal invoking parl.Sprintf
Usage:
var x int parl.OnDebug(func() string { return parl.Sprintf("before: %d", x)})
func Out ¶
func Out(format string, a ...interface{})
Out always prints to standard out
- if debug is enabled, code location is appended
func Outw ¶ added in v0.4.12
func Outw(format string, a ...interface{})
Outw always prints to standard out without ensuring terminating newline
func Recover ¶
Recover recovers from a panic invoking a function no more than once. If there is *errp does not hold an error and there is no panic, onError is not invoked. Otherwise, onError is invoked exactly once. *errp is updated with a possible panic.
func Recover2 ¶
Recover2 recovers from a panic and may invoke onError multiple times. onError is invoked if there is an error at *errp and on a possible panic. *errp is updated with a possible panic.
func RecoverInvocationPanic ¶ added in v0.4.29
func RecoverInvocationPanic(fn func(), errp *error)
RecoverInvocationPanic is intended to wrap callback invocations in the callee in order to recover from panics in the callback function. when an error occurs, perrors.AppendError appends the callback error to *errp. if fn is nil, a recovered panic results. if errp is nil, a panic is thrown, can be check with:
if errors.Is(err, parl.ErrNilValue) …
func RecoverInvocationPanicErr ¶ added in v0.4.54
func SendErr ¶ added in v0.4.100
SendErr sends error as the final action of a goroutine
- SendErr should only panic from structural coding problems
func SetDebug ¶
func SetDebug(debug bool)
if SetDebug is true, Debug prints everywhere produce output
- other printouts have location appended
- More selective debug printing can be achieved using SetInfoRegexp that matches on function names.
func SetRegexp ¶
SetRegexp defines a regular expression for function-level debug printing to stderr.
- SetRegexp affects Debug() GetDebug() IsThisDebug() IsThisDebugN() functions.
Regular Expression ¶
Regular expression is the RE2 syntax used by golang. command-line documentation: “go doc regexp/syntax”. The regular expression is matched against code location.
Code Location Format ¶
Code location is the fully qualified function name for the executing code line being evaluated. This is a fully qualified golang package path, ".", a possible type name in parenthesis ending with "." and the function name.
- method with pointer receiver:
- — "github.com/haraldrudell/parl/mains.(*Executable).AddErr"
- — sample regexp: mains...Executable..AddErr
- top-level function:
- — "github.com/haraldrudell/parl/g0.NewGoGroup"
- — sample regexp: g0.NewGoGroup
To obtain the fully qualified function name for a particular location:
parl.Log(pruntime.NewCodeLocation(0).String())
func SetSilent ¶
func SetSilent(silent bool)
SetSilent(true) prevents Info() invocations from printing
func Short ¶ added in v0.4.26
Short provides a brief time-stamp in compact second-precision including time-zone.
- sample: 060102_15:04:05-08
- The timestamp does not contain space.
- time zone is what is included in tim, typically time.Local
- if tim is not specified, time.Now() in local time zone
func ShortMs ¶ added in v0.4.27
ShortMs provides a brief time-stamp in compact milli-second-precision including time-zone.
- sample: 060102_15:04:05.123-08
- The timestamp does not contain space.
- time zone is what is included in tim, typically time.Local
- if tim is not specified, time.Now() in local time zone
func ShortSpace ¶ added in v0.4.28
Short provides a brief time-stamp in compact second-precision including time-zone.
- sample: 060102 15:04:05-08
- date is 6-digit separated from time by a space
- time zone is what is included in tim, typically time.Local
- if tim is not specified, time.Now() in local time zone
func Uintptr ¶ added in v0.4.97
Uintptr returns v as a pointer
- usable with fmt.Printf %x
Usage:
var p = &SomeStruct{} parl.Log("p: 0x%x", parl.Uintptr(p))
Types ¶
type AdbAdressProvider ¶ added in v0.4.0
type AdbAdressProvider interface { // AdbSocketAddress retrievs the tcp socket address used // by a near Adbette implementation AdbSocketAddress() (socketAddress AdbSocketAddress) }
AdressProvider retrieves the address from an adb server or device so that custom devices can be created
type AdbRequest ¶ added in v0.3.0
type AdbRequest string
AdbRequest is a string formatted as an adb request. AdbRequest is only required for implementations using the Adbette protocol impementation
type AdbResponseID ¶ added in v0.4.0
type AdbResponseID string
type AdbSocketAddress ¶ added in v0.4.0
type AdbSocketAddress string
AdbSocketAddress is a tcp socket address accessible to the local host. The format is two parts separated by a colon. The first part is an IP address or hostname. The second part is a numeric port number. The empty string "" represents "localhost:5037". If the port part is missing, such as "localhost" it implies port 5037. If the host part is missing, it implies "localhost". Note that locahost is valid both for IPv4 and IPv6.
type AdbSyncRequest ¶ added in v0.4.0
type AdbSyncRequest string
type Adbette ¶ added in v0.3.0
type Adbette interface { // SendReadOkay sends a request to a remote adb endpoint. // if anything else than OKAY is received back from the // remote endpoint, err is non-nil. SendReadOkay(request AdbRequest) (err error) // ReadString reads utf-8 text up to 64 KiB-1 in length ReadString() (s string, err error) // ConnectToDevice sends a forwarding request to an adb // server to connect to one of its devices ConnectToDevice(serial AndroidSerial) (err error) // Shell executes a shell command on a device connected to the adb server. // - out is a combination of stderr and stdout. // - The status code from an on-device command cannot be obtained Shell(command string) (out []byte, err error) // ShellStream executes a shell command on the device returning a readable socket ShellStream(command string) (conn io.ReadWriteCloser, err error) // TrackDevices orders a server to emit serial number as they become available TrackDevices() (err error) // Devices lists the currently online serials Devices() (serials []AndroidSerial, err error) // DeviceStati returns all available serials and their status // The two slices correspond and are of the same length DeviceStati() (serials []AndroidSerial, stati []AndroidStatus, err error) // Closer closes an adb connection, meant to be a deferred function Closer(errp *error) // SetSync sets the protocol mode of an adb device connection to sync SetSync() (err error) // LIST is a sync request that lists file system entries in a directory of an adb device LIST(remoteDir string, dentReceiver func(mode uint32, size uint32, time uint32, byts []byte) (err error)) (err error) // RECV fetches the contents of a file on an adb device RECV(remotePath string, blobReceiver func(data []byte) (err error)) (err error) // CancelError is a value that a LIST or RECV callback routines can return to // cancel further invocations CancelError() (cancelError error) SendBlob(syncRequest AdbSyncRequest, data []byte) (err error) ReadBlob() (byts []byte, err error) ReadResponseID() (responseID AdbResponseID, err error) ReadBytes(byts []byte) (err error) SendBytes(byts []byte) (err error) }
Adbette is a minimal implementation of the adb Android debug bridge protocol. Adbette include both adb server and Android device functions. Adbette is extensible in that additional protocol features are easily implemented without concern for protocol details. to shutdown an Adbette and release its resouces, invoke the Closer method
type Adbetter ¶ added in v0.3.0
type Adbetter interface {
NewConnection(address AdbSocketAddress, ctx context.Context) (conn Adbette, err error)
}
Adbetter is a factory instance for connections featuring Adbette context is used for terminating a connection attempt. context is not retained in the connection.
type AddErrorIf ¶ added in v0.4.106
type AddErrorIf interface {
AddError(err error)
}
type AndroidSerial ¶ added in v0.3.0
type AndroidSerial string
AndroidSerial uniquely identities an Android device.
- has .String and .IsValid, is Ordered
- typically a string of a dozen or so 8-bit chanacters consisting of lower and upper case a-zA-Z0-9
func NewAndroidSerial ¶ added in v0.4.113
func NewAndroidSerial(s string) (serial AndroidSerial)
func (AndroidSerial) IsValid ¶ added in v0.4.106
func (a AndroidSerial) IsValid() (isValid bool)
func (AndroidSerial) String ¶ added in v0.4.106
func (a AndroidSerial) String() (s string)
type AndroidStatus ¶ added in v0.3.0
type AndroidStatus string
AndroidStatus indicates the current status of a device known to a Server or Serverette it is a single word of ANSII-set characters
const AndroidOnline AndroidStatus = "device"
AndroidOnline is the Android device status that indicates an online device
- can be checked using method [AndroidSerial.IsOnline]
func NewAndroidStatus ¶ added in v0.4.113
func NewAndroidStatus(s string) (status AndroidStatus)
func (AndroidStatus) IsOnline ¶ added in v0.4.113
func (a AndroidStatus) IsOnline() (isOnline bool)
func (AndroidStatus) IsValid ¶ added in v0.4.113
func (a AndroidStatus) IsValid() (isValid bool)
func (AndroidStatus) String ¶ added in v0.4.113
func (a AndroidStatus) String() (s string)
type AtomicBool ¶
type AtomicBool struct {
// contains filtered or unexported fields
}
AtomicBool is a thread-safe flag. AtomicBool requires no initialization
var isDone parl.AtomicBool if isDone.Set() // isDone was not set, but is set now … if !isDone.IsTrue() // isDone is not set
func (*AtomicBool) Clear ¶
func (ab *AtomicBool) Clear() (wasSet bool)
Clear sets the flag to false and returns true if the flag was not already false. thread-safe
func (*AtomicBool) IsFalse ¶ added in v0.4.43
func (ab *AtomicBool) IsFalse() (isFalse bool)
IsFalse returns the flag’s current bool value. thread-safe
func (*AtomicBool) IsTrue ¶
func (ab *AtomicBool) IsTrue() (isTrue bool)
IsTrue returns the flag’s current bool value. thread-safe
func (*AtomicBool) Set ¶
func (ab *AtomicBool) Set() (wasNotSet bool)
Set sets the flag to true and returns true if the flag was not already true. thread-safe
type AtomicCounter ¶ added in v0.4.41
type AtomicCounter uint64
func (*AtomicCounter) Add ¶ added in v0.4.43
func (max *AtomicCounter) Add(value uint64) (newValue uint64)
func (*AtomicCounter) Dec ¶ added in v0.4.41
func (max *AtomicCounter) Dec() (value uint64)
func (*AtomicCounter) Dec2 ¶ added in v0.4.106
func (max *AtomicCounter) Dec2() (value uint64, didDec bool)
func (*AtomicCounter) Inc ¶ added in v0.4.41
func (max *AtomicCounter) Inc() (value uint64)
func (*AtomicCounter) Inc2 ¶ added in v0.4.106
func (max *AtomicCounter) Inc2() (value uint64, didInc bool)
func (*AtomicCounter) Set ¶ added in v0.4.46
func (max *AtomicCounter) Set(value uint64) (oldValue uint64)
func (*AtomicCounter) Value ¶ added in v0.4.41
func (max *AtomicCounter) Value() (value uint64)
type AtomicMax ¶ added in v0.4.41
type AtomicMax[T constraints.Integer] struct { // contains filtered or unexported fields }
func NewAtomicMax ¶ added in v0.4.41
func NewAtomicMax[T constraints.Integer](value T) (atomicMax *AtomicMax[T])
type AtomicMaxDuration ¶ added in v0.4.44
type AtomicMaxDuration struct {
// contains filtered or unexported fields
}
AtomicMaxDuration calculates durations maintaining max duration value
- Thread-Safe but designed for single thread
- for re-entrant timer, use SlowDetector
func (*AtomicMaxDuration) Max ¶ added in v0.4.44
func (ad *AtomicMaxDuration) Max() (max time.Duration, hasValue bool)
Stop returns the duration of a timing cycle
type AtomicMin ¶ added in v0.4.43
type AtomicMin[T constraints.Integer] struct { // contains filtered or unexported fields }
type AtomicReference ¶ added in v0.4.41
type AtomicReference[T any] struct { // contains filtered or unexported fields }
AtomicReference holds a typed reference that is accessed atomically.
func MakeAtomicReference ¶ added in v0.4.41
func MakeAtomicReference[T any]() (reference AtomicReference[T])
func (*AtomicReference[T]) Get ¶ added in v0.4.41
func (ref *AtomicReference[T]) Get() (reference *T)
func (*AtomicReference[T]) Put ¶ added in v0.4.41
func (ref *AtomicReference[T]) Put(reference *T) (r0 *T)
func (*AtomicReference[T]) PutIf ¶ added in v0.4.54
func (ref *AtomicReference[T]) PutIf(reference *T, expected *T) (swapped bool)
type CBFunc ¶ added in v0.4.41
type CBFunc func(reason CBReason, maxParallelism uint64, maxLatency time.Duration, threadID ThreadID)
CBFunc is a thread-safe function invoked on
- parallelism exceeding parallelismWarningPoint
- latency of an ongoing invocation exceeds latencyWarningPoint
type CBReason ¶ added in v0.4.41
type CBReason uint8
CBReason explains to consumer why the callback was invoked
- ITParallelism ITLatency
type CbSlowDetector ¶ added in v0.4.44
type CbSlowDetector func(sdi *SlowDetectorInvocation, hasReturned bool, duration time.Duration)
type Certificate ¶ added in v0.4.26
type Certificate interface { DER() (der CertificateDer) PEM() (pemBytes PemBytes) ParseCertificate() (certificate *x509.Certificate, err error) }
type CertificateAuthority ¶ added in v0.4.26
type CertificateAuthority interface { Check() (cert *x509.Certificate, err error) // gets x509.Certificate version DER() (certificateDer CertificateDer) // untyped bytes, der: Distinguished Encoding Rules binary format Sign(template *x509.Certificate, publicKey crypto.PublicKey) (certDER CertificateDer, err error) PEM() (pemBytes PemBytes) Private() (privateKey PrivateKey) }
type CertificateDer ¶ added in v0.4.26
type CertificateDer []byte
CertificateDer is a binary encoding of a certificate. der: Distinguished Encoding Rules is a binary format based on asn1.
type ClosableChan ¶ added in v0.4.0
type ClosableChan[T any] struct { // contains filtered or unexported fields }
ClosableChan wraps a channel with thread-safe idempotent panic-free observable close.
- ClosableChan is initialization-free
- Close is deferrable
- IsClosed provides wether the channel is closed
Usage:
var errCh parl.ClosableChan[error] go thread(&errCh) err, ok := <-errCh.Ch() if errCh.IsClosed() { // can be inspected … func thread(errCh *parl.ClosableChan[error]) { var err error … defer errCh.Close(&err) // will not terminate the process errCh.Ch() <- err
func NewClosableChan ¶ added in v0.4.5
func NewClosableChan[T any](ch ...chan T) (cl *ClosableChan[T])
NewClosableChan returns a channel with idempotent panic-free observable close
- ch is an optional non-closed channel object
- if ch is not present, an unbuffered channel will be created
- cannot use lock in new function
- if an unbuffered channel is used, NewClosableChan is not required
func (*ClosableChan[T]) Ch ¶ added in v0.4.0
func (c *ClosableChan[T]) Ch() (ch chan T)
Ch retrieves the channel. Thread-safe
- nil is never returned
- the channel may already be closed
- do not close the channel other than using the Close method
- per Go channel close, if one thread is blocked in channel send while another thread closes the channel, a data race occurs
func (*ClosableChan[T]) Close ¶ added in v0.4.0
func (cl *ClosableChan[T]) Close(errp ...*error) (didClose bool, err error)
Close ensures the channel is closed
- Close does not return until the channel is closed.
- thread-safe panic-free deferrable observable
- all invocations have close result in err
- didClose indicates whether this invocation closed the channel
- if errp is non-nil, it will receive the close result
- per Go channel close, if one thread is blocked in channel send while another thread closes the channel, a data race occurs
func (*ClosableChan[T]) IsClosed ¶ added in v0.4.0
func (c *ClosableChan[T]) IsClosed(includePending ...bool) (isClosed bool)
IsClosed indicates whether the channel is closed. Thread-safe
- includePending: because there is a small amount of time between
- — a thread discovering the channel closed and
- — closeOnce indicating close complete
- includePending true includes a check for the channel being about to close
func (*ClosableChan[T]) ReceiveCh ¶ added in v0.4.100
func (c *ClosableChan[T]) ReceiveCh() (ch <-chan T)
ReceiveCh retrieves the channel. Thread-safe
- nil is never returned
- the channel may already be closed
- do not close the channel other than using the Close method
func (*ClosableChan[T]) SendCh ¶ added in v0.4.100
func (c *ClosableChan[T]) SendCh() (ch chan<- T)
SendCh retrieves the channel. Thread-safe
- nil is never returned
- the channel may already be closed
- do not close the channel other than using the Close method
- per Go channel close, if one thread is blocked in channel send while another thread closes the channel, a data race occurs
type Counter ¶ added in v0.3.0
type Counter interface { // Inc increments the counter. Thread-Safe, method chaining Inc() (counter Counter) // Dec decrements the counter but not below zero. Thread-Safe, method chaining Dec() (counter Counter) // Add adds a positive or negative delta. Thread-Safe, method chaining Add(delta int64) (counter Counter) }
Counter is the data provider interface for a counter
- Inc Dec Add operations, Thread-safe
type CounterID ¶ added in v0.3.0
type CounterID string
CounterID is a unique type containing counter names
type CounterSet ¶ added in v0.4.29
type CounterSet interface { // GetCounters gets a list and a map for consuming counter data GetCounters() (orderedKeys []CounterID, m map[CounterID]any) // ResetCounters resets all counters to their initial state ResetCounters(stopRateCounters bool) }
CounterSet is the consumer interface for a counter set
type CounterSetData ¶ added in v0.4.41
type CounterSetData interface { Exists(name CounterID) (exists bool) // Value returns the monotonically increasing value for a possible plain counter // - if no such counter exists, 0 Value(name CounterID) (value uint64) // Running returns the increasing and decreasing running value for a possible plain counter // - if no such counter exists, 0 Get(name CounterID) (value, running, max uint64) // Rates returns the rate values a possible rate counter // - if no such counter exists or values are not yet available, nil Rates(name CounterID) (rates map[RateType]float64) // DatapointValue returns the latest value a possible datapoint // - if no such datapoint exists, 0 DatapointValue(name CounterID) (value uint64) // DatapointMax returns the highest seen value for a possible datapoint // - if no such datapoint exists, 0 DatapointMax(name CounterID) (max uint64) // DatapointMin returns the lowest seen value for a possible datapoint // - if no such datapoint exists, 0 DatapointMin(name CounterID) (min uint64) // GetDatapoint returns dfatapoint data for a possible datapoint // - if no such datapoint exists, 0 GetDatapoint(name CounterID) (value, max, min uint64, isValid bool, average float64, n uint64) }
CounterSetData provides simple access to a set of counters, rate counters and datapoints/
type CounterStore ¶ added in v0.4.100
type CounterStore interface { // GetOrCreateCounter retrieves a regular counter // - never returns nil // - type asserted to CounterValues GetCounter(name CounterID) (counter Counter) //GetCounter retrieves a counter that must exist // - may return nil // - type asserted to RateCounterValues or DatapointValue GetNamedCounter(name CounterID) (counter any) }
CounterStore is a CounterSet consumer interface facilitating caching
type CounterValues ¶ added in v0.3.0
type CounterValues interface { // Get returns value/running/max with integrity. Thread-Safe // - value is the monotonically increasing value // - running is the fluctuating running value // - max is the highest value running has had Get() (value, running, max uint64) // GetReset returns value/running/max with integrity and resets the counter. Thread-Safe // - value is the monotonically increasing value // - running is the fluctuating running value // - max is the highest value running has had GetReset() (value, running, max uint64) // Value returns the monotonically increasing value. Thread-Safe // - number of Inc invocations and positive Adds Value() (value uint64) // Running returns the fluctuating running value. Thread-Safe // - number of Inc less Dec invocations and sum of Adds // - never below 0 Running() (running uint64) // Max returns the highest value running has had. Thread-Safe Max() (max uint64) }
CounterValues is the consumer interface for a counter. Thread-safe
type Counters ¶ added in v0.3.0
type Counters interface { // GetOrCreateCounter is used by the data provider of a counter. // - A counter has Inc and Dec operations. // - Counters can be used to track number of currently operating invocations. // - if period is present and positive, the counter created is a RateCounter. // Rate counters use threads, one per distinct period requested. // Rate counter threads are monitored by the provided Go group and failure // may force a counter restart or cause application termination. Failures // are typically caused by panics in the counter update task. // - Counter is the data-provider side of a counter // - CounterValues is the consumer side of a counter GetOrCreateCounter(name CounterID, period ...time.Duration) (counter Counter) // GetOrCreateCounter is used by the data provider of a datapoint. // A datapoint supports SetValue operation. // A datapoint tracks a quantity such as a latency value. GetOrCreateDatapoint(name CounterID, period time.Duration) (datapoint Datapoint) }
Counters is the data provider interface for a counter set.
- max and running values are offered
- Counters and datapointy are thread-safe
- counters may be used to determine that code abide by intended paralellism and identifying hangs or abnormalisms.
- Printing counters every second can verify adequate progress and possibly identify blocking of threads or swapping and garbage collection outages.
type CountersFactory ¶ added in v0.3.0
type CountersFactory interface { // NewCounters returns a counter container. // is useCounters is false, the container does not actually do any counting. NewCounters(useCounters bool, g0 GoGen) (counters Counters) }
CountersFactory is an abstract counter factory. CountersFactory enables providing of different counter implementations.
type CyclicWait ¶ added in v0.4.29
type CyclicWait struct {
// contains filtered or unexported fields
}
CyclicWait allows any number of threads to wait for a next occurrence.
- a parent context may be passed in that on cancel triggers the wait and prevents further cycles
- a channel can be obtained that sends one item on the next trig but never closes
- a channel can be obtained that closes on next trig
- next trig can be awaited
- a did-occurer object can be obtained that returns true once the cycle trigs.
- a context can be obtained that cancels on the next trig
- the cycles can be permanently canceled or trigged and rearmed
func NewCyclicWait ¶ added in v0.4.29
func NewCyclicWait(ctx context.Context) (onceReceiver *CyclicWait)
NewCyclicWait returns a channel that will send one item when the context cancels or immediately if the context was already canceled.
func (*CyclicWait) Cancel ¶ added in v0.4.29
func (cw *CyclicWait) Cancel()
Cancel cancels the object and prevents rearming.
func (*CyclicWait) CancelAndRearm ¶ added in v0.4.29
func (cw *CyclicWait) CancelAndRearm() (wasRearmed bool)
CancelAndRearm trigs the object and then rearms unless a possible parent context has been canceled.
func (*CyclicWait) Ch ¶ added in v0.4.29
func (cw *CyclicWait) Ch() (ch <-chan struct{})
Ch returns a channel that will emit one item on the next trig. It will then not send anything else. the channel never closes.
func (*CyclicWait) Context ¶ added in v0.4.29
func (cw *CyclicWait) Context() (ctx context.Context)
Context returns a context that cancels on the next trig.
func (*CyclicWait) DidOccurer ¶ added in v0.4.29
func (cw *CyclicWait) DidOccurer() (didOccurer *OnceWaiterRO)
DidOccurer returns an object with a DidOccur method returning true after this cycle has trigged.
func (*CyclicWait) Done ¶ added in v0.4.29
func (cw *CyclicWait) Done() (done <-chan struct{})
Done returns a channel that will close on the next trig or parent context cancel. Similar to the Done method of a context.
func (*CyclicWait) IsCancel ¶ added in v0.4.29
func (cw *CyclicWait) IsCancel() (isCancel bool)
IsCancel returns whether Cancel has been invoked. ISCancel will return false during CancelAndRearm cycles.
func (*CyclicWait) Wait ¶ added in v0.4.29
func (cw *CyclicWait) Wait()
Wait waits until the next trig or parent context cancel.
type DB ¶ added in v0.4.12
type DB interface { Exec(partition DBPartition, query string, ctx context.Context, args ...any) (execResult ExecResult, err error) Query(partition DBPartition, query string, ctx context.Context, args ...any) (sqlRows *sql.Rows, err error) QueryRow(partition DBPartition, query string, ctx context.Context, args ...any) (sqlRow *sql.Row, err error) QueryString(partition DBPartition, query string, ctx context.Context, args ...any) (value string, err error) QueryInt(partition DBPartition, query string, ctx context.Context, args ...any) (value int, err error) Close() (err error) }
type DBFactory ¶ added in v0.4.12
type DBFactory interface { NewDB( dsnr DataSourceNamer, schema func(dataSource DataSource, ctx context.Context) (err error)) (db DB) }
DBFactory is a standardized way to obtain DB objects
type DBPartition ¶ added in v0.4.14
type DBPartition string
type DSNrFactory ¶ added in v0.4.14
type DSNrFactory interface {
NewDSNr(appName string) (dsnr DataSourceNamer)
}
type DataSource ¶ added in v0.4.12
type DataSourceNamer ¶ added in v0.4.12
type DataSourceNamer interface { DSN(partition ...DBPartition) (dataSourceName string) DataSource(dsn string) (dataSource DataSource, err error) }
type Datapoint ¶ added in v0.4.29
type Datapoint interface { // SetValue records a value at time.Now(). // SetValue supports method chaining. SetValue(value uint64) (datapoint Datapoint) }
Datapoint tracks a value with average, max-min, and increase/decrease rates.
type DatapointValue ¶ added in v0.4.29
type DatapointValue interface { CloneDatapoint() (datapoint Datapoint) // Clone takes a snapshot of a counter state. CloneDatapointReset() (datapoint Datapoint) // CloneReset takes a snapshot of a counter state and resets it to its initial state. GetDatapoint() (value, max, min uint64, isValid bool, average float64, n uint64) DatapointValue() (value uint64) DatapointMax() (max uint64) DatapointMin() (min uint64) }
type Debouncer ¶ added in v0.4.26
type Debouncer[T any] struct { // contains filtered or unexported fields }
Debouncer debounces event stream values. T values are received from the in channel. Once d time has elapsed with no further incoming Ts, a slice of read Ts are provided to the send function.
- the debouncer may be held up indefinitely for an uninterrupted stream of Ts
- two threads are launched per debouncer
- errFn receives any panics in the threads
- sender and errFn functions must be thread-safe.
- Debouncer is shutdown gracefully by input channel close or immediately using Shutdown method
func NewDebouncer ¶
func NewDebouncer[T any]( duration time.Duration, inputCh <-chan T, sender func([]T), errFn func(err error)) (debouncer *Debouncer[T])
NewDebouncer returns a channel debouncer
type Dent ¶ added in v0.3.0
type Dent interface { // Name is utf-8 base path in device file system. // Name is base name, ie. file name and extension. Name() (name string) // Modified time, the time file contents was changed, second precision, continuous time Modified() (modified time.Time) // IsDir indicates directory. // LIST only support symbolic link, directory and regular file types IsDir() (isDir bool) // IsRegular indicates regular file, ie. not a directory or symbolic link. // LIST only support symbolic link, directory and regular file types IsRegular() (isRegular bool) // ie.not directory or symlink // Perm returns os.FileMode data. // 9-bit Unix permissions per os.FilePerm. // LIST also supports directory and symlink bits Perm() (perm fs.FileMode) // Size is limited to 4 GiB-1 Size() (size uint32) }
Dent is the information returned by adb ls or LIST
type Devicette ¶ added in v0.3.0
type Devicette interface { // Serial returns the serial number for this device Serial() (serial AndroidSerial) // Shell executes a shell command on the device. // - the response is a byte sequence // - note: interning large strings may lead to memory leaks Shell(command string) (out []byte, err error) // ShellStream executes a shell command on the device returning a readable socket ShellStream(command string) (conn io.ReadWriteCloser, err error) /* Pull copies a remote file or directory on the Android device to a local file system location. the local file must not exist. Pull refuses certain files like product apks. shell cat works */ Pull(remotePath, nearPath string) (err error) /* List has some peculiarities: If remoteDir is not an existing directory, an empty list is returned. Entries with insufficient permisions are ignored. Update: . and .. are removed, adb LIST ortherwise do return those. File mode: the only present type bits beyond 9-bit Unix permissions are symlink, regular file and directory. File size is limited to 4 GiB-1. Modification time resolution is second and range is confined to a 32-bit Unix timestamp. */ List(remoteDir string) (dFileInfo []Dent, err error) }
Devicette is a generic implementation of the capabilities of a device implementing the adb Android debug bridge protocol
type DevicetteFactory ¶ added in v0.4.0
type DevicetteFactory interface { // NewDevicette creates a Devicette interacting with remote adb Android Debug Bridge // devices via an adb server available at the socket address address NewDevicette(address AdbSocketAddress, serial AndroidSerial, ctx context.Context) (devicette Devicette) }
DevicetteFactory describes how Devicette objects are obtained.
type Doneable ¶ added in v0.4.12
type Doneable interface { Add(delta int) Done() }
Doneable is the callee part of sync.Waitgroup and other implementations Doneable is a many-to-many relation. Doneable allows the callee to instatiate and invoke any number of things that are awaitable by the caller.
… = NewSomething(&waitsForLots, &shutsDownLots) go someThread(&waitsForLots, &shutsDownLots) func someThread(Doneable w, context.Context ctx) { defer w.Done() w.Add(2) go somethingElse()
type EchoModerator ¶ added in v0.4.41
type EchoModerator struct {
// contains filtered or unexported fields
}
EchoModerator is a parallelism-limiting Moderator that:
- prints any increase in parallelism over concurrency
- prints exhibited invocation slowness exceeding latencyWarningPoint
- prints progressive slowness exceeding latencyWarningPoint for an invocation in progress on schedule timerPeriod
EchoModerator is intended to control and diagnose exec.Command invocations
func NewEchoModerator ¶ added in v0.4.41
func NewEchoModerator( concurrency uint64, latencyWarningPoint time.Duration, waitingWarningPoint uint64, timerPeriod time.Duration, label string, g0 GoGen, log PrintfFunc) (echoModerator *EchoModerator)
NewEchoModerator returns a parallelism-limiting moderator with printouts for excessive slowness or parallelism
func (*EchoModerator) Do ¶ added in v0.4.41
func (em *EchoModerator) Do(fn func())
type Enum ¶ added in v0.4.33
Enum is an enumeration using string keys mapping to a value type T. T is a unique named type that separates the values of this enumeration from all other values.
type EnumItem ¶ added in v0.4.33
type EnumItem[K constraints.Ordered, V any] interface { Key() (key K) // Key returns the key for this enumeration value Description() (desc string) // Description returns a descriptive sentence for this enumeration value Value() (value V) // Value returns this enumeration value’s value using the restricted type fmt.Stringer }
EnumItem is a generic interface for enumeration item implementations. Enumeration items are ordered by the K key type.
- K is a key type whose values map to restricted type V values one-to-one.
- V is a restricted type for enumeration values that may store more efficiently compared to a portable type.
type ErrorCloser ¶ added in v0.4.20
type ErrorCloser interface { InvokeIfError(addError func(err error)) Close() }
type ErrorManager ¶ added in v0.4.20
type ErrorManager interface {
Ch() (ch <-chan GoError)
}
type ErrorString ¶ added in v0.4.46
type ErrorString struct {
// contains filtered or unexported fields
}
ErrorString is similar to the private type errors.errorString
func (*ErrorString) Error ¶ added in v0.4.46
func (e *ErrorString) Error() string
type ExecResult ¶ added in v0.4.14
type FSLocation ¶
type FSLocation interface {
Directory() (directory string)
}
type Frame ¶ added in v0.4.20
type Frame interface { Loc() (location *pruntime.CodeLocation) // the code location for this frame, never nil Args() (args string) // invocation values like "(0x14000113040)" // package funtion name, base filename ad line number String() (s string) }
type Future ¶ added in v0.4.26
type Future[T any] struct { // contains filtered or unexported fields }
Future contains an awaitable calculation using performant sync.RWMutex and atomics. Thread-safe
func NewFuture ¶ added in v0.4.26
NewFuture returns an awaitable calculation using performant sync.RWMutex and atomics. Thread-safe
func (*Future[T]) End ¶ added in v0.4.60
End writes the result of the calculation, deferrable
- result is considered valid if errp is nil or *errp is nil
func (*Future[T]) IsCompleted ¶ added in v0.4.60
IsCompleted returns whether the calculation is complete. Thread-safe
type Go ¶ added in v0.4.12
type Go interface { // Register performs no function but allows the Go object to collect // information on the new thread. // - label is an optional name that can be assigned to a Go goroutine thread Register(label ...string) (g0 Go) // AddError emits a non-fatal error. AddError(err error) // Go returns a Go object to be provided as a go-statement function-argument // in a function call invocation launching a new gorotuine thread. // - the new thread belongs to the same GoGroup thread-group as the Go // object whose Go method was invoked. Go() (g0 Go) // SubGo returns a GoGroup thread-group whose fatal and non-fatel errors go to // the Go object’s parent thread-group. // - a SubGo is used to ensure sub-threads exiting prior to their parent thread // or to facilitate separate cancelation of the threads in the subordinate thread-group. // - fatal errors from SubGo threads are handled in the same way as those of the // Go object, typically terminating the application. // - the SubGo thread-group terminates when both its own threads have exited and // - the threads of its subordinate thread-groups. SubGo(onFirstFatal ...GoFatalCallback) (subGo SubGo) // SubGroup returns a thread-group with its own error channel. // - a SubGroup is used for threads whose fatal errors should be handled // in the Go thread. // - The threads of the Subgroup can be canceled separately. // - SubGroup’s error channel collects fatal thread terminations // - the SubGroup’s error channel needs to be read in real-time or after // SubGroup termination // - non-fatal errors in SubGroup threads are sent to the Go object’s parent // similar to the AddError method // - the SubGroup thread-group terminates when both its own threads have exited and // - the threads of its subordinate thread-groups. SubGroup(onFirstFatal ...GoFatalCallback) (subGroup SubGroup) // Done indicates that this goroutine has finished. // - err == nil means successful exit // - non-nil err indicates a fatal error. // - Done is deferrable. Done(errp *error) // Wait awaits exit of this Go thread. Wait() // Cancel signals for the threads in this Go thread’s parent GoGroup thread-group // and any subordinate thread-groups to exit. Cancel() // Context will Cancel when the parent thread-group Cancels // or Cancel is invoked on this Go object. // Subordinate thread-groups do not Cancel the context of the Go thread. Context() (ctx context.Context) // ThreadInfo returns thread data that is partially or fully populated ThreadInfo() (threadData ThreadData) // values always present Creator() (threadID ThreadID, createLocation *pruntime.CodeLocation) // ThreadID may be invalid: threadID.IsValid. // goFunction may be zero-value: goFunction.IsSet GoRoutine() (threadID ThreadID, goFunction *pruntime.CodeLocation) // GoID efficiently returns the goroutine ID that mey be invalid GoID() (threadID ThreadID) fmt.Stringer }
Go provides methods for a running goroutione thread to be provided as a function argument in the go statement function call launching the thread.
- Go.CancelGo affects this Go thread only.
- Go.Cancel cancels:
- — this Go thread
- — this Go’s parent thread-group and
- — this Go’s parent thread-group’s subordinate thread-groups
- The Go Context is canceled when
- — the parent GoGroup thread-group’s context is Canceled or
- —a thread in the parent GoGroup thread-group initiates Cancel
- Cancel by threads in sub ordinate thread-groups do not Cancel this Go thread
type GoError ¶ added in v0.4.12
type GoError interface { error // Error() string // Err retrieves the original error value Err() (err error) // Time provides when this error occurred Time() time.Time // IsThreadExit determines if this error is a thread exit, ie. GeExit GePreDoneExit // - thread exits may have err nil // - fatals are non-nil thread exits that may require specific actions such as // application termination IsThreadExit() (isThreadExit bool) // IsFatal determines if this error is a fatal thread-exit, ie. a thread exiting with non-nil error IsFatal() (isThreadExit bool) // ErrContext returns in what situation this error occurred ErrContext() (errContext GoErrorContext) // Go provides the thread and goroutine emitting this error Go() (g0 Go) fmt.Stringer }
GoError is an error or a thread exit associated with a goroutine
- GoError encapsulates the original unadulterated error
- GoError provides context for taking action on the error
- Go provides the thread associated with the error. All GoErrors are associated with a Go object
- because GoError is both error and fmt.Stringer, to print its string representation requires using the String() method, otherwise fmt.Printf defaults to the Error() method
type GoErrorContext ¶ added in v0.4.29
type GoErrorContext uint8
const ( // GeNonFatal indicates a non-fatal error ocurring during processing. // err is non-nil GeNonFatal GoErrorContext = iota + 1 // GePreDoneExit indicates an exit value of a subordinate goroutine, // other than the final exit of the last running goroutine. // err may be nil GePreDoneExit // A SubGroup with its own error channel is sending a // locally fatal error not intended to terminate the app GeLocalChan // A thread is requesting app termination without a fatal error. // - this could be a callback GeTerminate // GeExit indicates exit of the last goroutine. // err may be nil. // The error channel may close after GeExit. GeExit )
func (GoErrorContext) String ¶ added in v0.4.29
func (ge GoErrorContext) String() (s string)
type GoFactory ¶ added in v0.4.29
type GoFactory interface { // NewGo returns a light-weight thread-group. // - GoGroup only receives Cancel from ctx, it does not cancel this context. NewGoGroup(ctx context.Context, onFirstFatal ...GoFatalCallback) (g0 GoGroup) }
type GoFatalCallback ¶ added in v0.4.29
type GoFatalCallback func(goGen GoGen)
GoFatalCallback receives the thread-group on its first fatal thread-exit
- GoFatalCallback is an optional onFirstFatal argument to
- — NewGoGroup
- — SubGo
- — SubGroup
type GoGen ¶ added in v0.4.29
type GoGen interface { // Go returns a Go object to be provided as a go statement function argument. Go() (g0 Go) // SubGo returns a thread-group whose fatal errors go to GoGen’s parent. // - both non-fatal and fatal errors in SubGo threads are sent to GoGen’s parent // like Go.AddError and Go.Done. // - therefore, when a SubGo thread fails, the application will typically exit. // - by awaiting SubGo, Go can delay its exit until SubGo has terminated // - the SubGo thread-group terminates when the its thread exits SubGo(onFirstFatal ...GoFatalCallback) (subGo SubGo) // SubGroup creates a sub-ordinate thread-group SubGroup(onFirstFatal ...GoFatalCallback) (subGroup SubGroup) // Cancel terminates the threads in the Go consumer thread-group. Cancel() // Context will Cancel when the parent thread-group Cancels. // Subordinate thread-groups do not Cancel this context. Context() (ctx context.Context) }
GoGen allows for new Go threads, new SubGo and SubGroup thread-groups and cancel of threads in the thread-group and its subordinate thread-groups.
- GoGen is value from NewGoGroup GoGroup SubGo SubGroup Go, ie. any Go-interface object
type GoGroup ¶ added in v0.4.18
type GoGroup interface { // Go returns a Go object to be provided as a go statement function argument. Go() (g0 Go) // SubGo returns athread-group whose fatal errors go to Go’s parent. // - both non-fatal and fatal errors in SubGo threads are sent to Go’s parent // like Go.AddError and Go.Done. // - therefore, when a SubGo thread fails, the application will typically exit. // - by awaiting SubGo, Go can delay its exit until SubGo has terminated // - the SubGo thread-group terminates when the its thread exits SubGo(onFirstFatal ...GoFatalCallback) (subGo SubGo) // SubGroup creates a sub-ordinate GoGroup. // - SubGroup fatal and non-fatal errors are sent to the parent GoGroup. // - SubGroup-context initiated Cancel only affect threads in the SubGroup thread-group // - parent-initiated Cancel terminates SubGroup threads // - SubGroup only awaits SubGroup threads // - parent await also awaits SubGroup threads SubGroup(onFirstFatal ...GoFatalCallback) (subGroup SubGroup) // Ch returns a channel sending the all fatal termination errors when // the FailChannel option is present, or only the first when both // FailChannel and StoreSubsequentFail options are present. Ch() (ch <-chan GoError) // Wait waits for all threads of this thread-group to terminate. Wait() // EnableTermination false prevents the SubGo or GoGroup from terminating // even if the number of threads is zero EnableTermination(allowTermination bool) IsEnableTermination() (mayTerminate bool) // Cancel terminates the threads in this and subordinate thread-groups. Cancel() // Context will Cancel when the parent context Cancels. // Subordinate thread-groups do not Cancel this context. Context() (ctx context.Context) // the available data for all threads Threads() (threads []ThreadData) // threads that have been named ordered by name NamedThreads() (threads []ThreadData) // SetDebug enables debug logging on this particular instance // - parl.NoDebug // - parl.DebugPrint // - parl.AggregateThread SetDebug(debug GoDebug) fmt.Stringer }
GoGroup manages a thread-group.
- A thread from this thread-group will terminate all threads in this and subordinate thread-groups if this thread-group was provided the FirstFailTerminates option, which is default.
- A fatal thread-termination in a sub thread-group only affects this thread-group if the sub thread-group was provided a nil fatal function, the FirstFailTerminates option, which is default, and no explicit FailChannel option.
- Fatal thread terminations will propagate to parent thread-groups if this thread group did not have a fatal function provided and was not explicitly provided the FailChannel option.
- A Cancel in this thread-group or in a parent context cancels threads in this and all subordinate thread-groups.
- A Cancel in a subordinate thread-group does not affect this thread-group.
- Wait in this thread-group wait for threads in this and all subordinate thread-groups.
type InvokeResult ¶ added in v0.4.54
type InvokeTimer ¶ added in v0.4.41
type InvokeTimer struct {
// contains filtered or unexported fields
}
InvokeTimer monitors funtion invocations for parallelism and latency
- callback is invoked on exceeding thresholds and reaching a new max
func NewInvokeTimer ¶ added in v0.4.41
func NewInvokeTimer( callback CBFunc, latencyWarningPoint time.Duration, parallelismWarningPoint uint64, timerPeriod time.Duration, g0 GoGen) (invokeTimer *InvokeTimer)
NewInvokeTimer returnds an object alerting of max latency and parallelism
- Do is used for new invocations
func (*InvokeTimer) Do ¶ added in v0.4.41
func (i *InvokeTimer) Do(fn func())
Do invokes fn with alerts on latency and parallelism
- Do is invoked in the goroutine to execute fn
type Invoker ¶ added in v0.4.54
type Invoker struct {
// contains filtered or unexported fields
}
Invoker allows to invoke a function returning error as a function with no return value. Thread Safe
- panics while executing FuncErr are recovered
Thread-safe
func NewInvoker ¶ added in v0.4.54
NewInvoker returns an object that can invoke a function returning error as a function with no return values. Thread-safe
func (*Invoker) Func ¶ added in v0.4.54
func (i *Invoker) Func()
Func invokes the function returning error storing results in its fields
func (*Invoker) InvokeResult ¶ added in v0.4.54
func (i *Invoker) InvokeResult() (invokeResult *InvokeResult)
type Iterator ¶ added in v0.4.33
type Iterator[T any] interface { // Next advances to next item and returns it. // if the next item does exist, value is valid and hasValue is true. // if no next item exists, value is the data type zero-value and hasValue is false. Next() (value T, hasValue bool) // HasNext advances to next item and returns hasValue true if this next item does exists. HasNext() (hasValue bool) // NextValue advances to next item and returns it. // If no next value exists, the data type zero-value is returned. NextValue() (value T) // Same returns the same value again. // If a value does exist, it is returned in value and hasValue is true. // If a value does not exist, the data type zero-value is returned and hasValue is false. // If Next, FindNext or HasNext have not been invoked, Same first advances to the first item. Same() (value T, hasValue bool) // Has returns true if Same() or SameValue will return items. // If Next, FindNext or HasNext have not been invoked, Has first advances to the first item. Has() (hasValue bool) // SameValue returns the same value again. // If a value does not exist, the data type zero-value is returned. // If Next, FindNext or HasNext have not been invoked, SameValue first advances to the first item. SameValue() (value T) // Cancel release resources for this iterator. // Not every iterator requires a Cancel invocation. Cancel() (err error) }
Iterator allows traversal of values. The iterators in parly.iterator are thread-safe and re-entrant, but generally, this depends on the iterator implementation used.
// triple-expression works for Iterator that do not require Cancel for iterator := NewIterator(); iterator.HasNext(); { v := iterator.SameValue() } // conditional expression can be used with all iterators iterator := NewIterator() for iterator.HasNext() { v := iterator.SameValue() } if err = iterator.Cancel(); …
type KeyEnum ¶ added in v0.4.33
type KeyEnum[K constraints.Ordered, T any] interface { IsKey(key K) (isKey bool) // IsKey checks whether key maps to an enumerated value Value(key K) (enum T, err error) // Value looks up an enumerated value by key KeyIterator() (iterator Iterator[K]) // KeyIterator returns an iterator that iterates over all keys in order of definition IsValid(enum T) (isEnumValue bool) // IsValid checks whether value is among enumerated values Key(value T) (key K, err error) // Key gets the key value for an enumerated T value ValueAny(value any) (enum T, err error) // ValueAny attempts to convert any value to a T enumerated value Iterator() (iterator Iterator[T]) // Iterator returns an iterator that iterates over all enumerated values in order of definition Description(enum T) (desc string) // Description gets a descriptive sentence for an enum value StringT(enum T) (s string) // StringT provides a string representation for an enumeration value // Compare compares two T values. // - result is 0 if the two values are considered equal // - result is 1 if value1 is considered greater than value2 // - result is -1 if value1 is considered less than value2 Compare(value1, value2 T) (result int) Name() (s string) // Name returns a short string naming this enumeration fmt.Stringer }
KeyedEnum is an enumeration using a key type K mapping to a value type T.
- T is a unique named type that separates the values of this enumeration from all other values.
- K is a common type, often a single-word string, whose values are unique and maps one-to-one to a T value. K is constraints.Ordered and can be used as a map key.
- The implementation’s stored type may be different from both K and T.
Some benefits with enumerations are:
- unknown, illegal or value duplications are detected
- integral values and their meanings can be printed
- one set of integral values are not confused with another, eg. unix.AF_INET and unix.RTAX_BRD
- Reveals the meaning when used as function arguments and other allowed values can be examined
type Moderator ¶
type Moderator struct {
// contains filtered or unexported fields
}
Moderator invokes functions at a limited level of parallelism. It is a ticketing system
m := NewModerator(20, ctx) m.Do(func() (err error) { // waiting here for a ticket // got a ticket! … return or panic // ticket automatically returned m.String() → waiting: 2(20)
type ModeratorCore ¶ added in v0.4.26
type ModeratorCore struct {
// contains filtered or unexported fields
}
ModeratorCore invokes functions at a limited level of parallelism. ModeratorCore is a ticketing system. ModeratorCore does not have a cancel feature.
m := NewModeratorCore(20, ctx) m.Do(func() (err error) { // waiting here for a ticket // got a ticket! … return or panic // ticket automatically returned m.String() → waiting: 2(20)
func NewModeratorCore ¶ added in v0.4.26
func NewModeratorCore(parallelism uint64) (m *ModeratorCore)
NewModerator creates a new Moderator used to limit parallelism
func (*ModeratorCore) Status ¶ added in v0.4.26
func (m *ModeratorCore) Status() (parallelism, active, waiting uint64)
Status: values may lack integrity
func (*ModeratorCore) String ¶ added in v0.4.26
func (m *ModeratorCore) String() (s string)
func (*ModeratorCore) Ticket ¶ added in v0.4.106
func (m *ModeratorCore) Ticket() (returnTicket func())
Ticket returns a ticket possibly blocking until one is available
- Ticket returns the function for returning the ticket
Usage:
defer moderator.Ticket()()
type MutexWait ¶ added in v0.4.54
type MutexWait struct {
// contains filtered or unexported fields
}
MutexWait is maximum-lightweight observable single-fire Mutex. Thread-Safe
func NewMutexWait ¶ added in v0.4.54
func NewMutexWait() (mutexWait *MutexWait)
NewMutexWait returns a maximum-lightweight observable single-fire Mutex. Thread-Safe
func (*MutexWait) IsUnlocked ¶ added in v0.4.54
IsUnlocked returns whether the MutexWait has fired
type NBChan ¶ added in v0.4.0
type NBChan[T any] struct { perrors.ParlError // thread panics and channel close errors // contains filtered or unexported fields }
NBChan is a non-blocking send channel with trillion-size queues.
- NBChan behaves both like a channel and a thread-safe slice
- — efficiency of sending and receiving multiple items at once
- — ability to wait for items to become available
- NBChan is initialization-free, thread-safe, idempotent and observable with panic-free methods and deferrable medthods
- values are sent to the channel using Send/SendMany that are never blocked by channel send and are panic-free error-free
- values are received from the channel or fetched all or many at once using Get
- — Get wait:DataWaitCh and NBChanNone is highest throughput at lowest cpu load
- — — cost is no channel is sending values, Get must be used
- — — benefit is no thread
- — Get Ch and NBChanAlways is higher throughput than regular thread
- — — cost is thread is always running
- — with regular thread or NBChanAlways:
- — — Ch offers wait with channel receive
- — — DataWaitCh only waits for data available
- NBChan has deferrable, panic-free, observable, idempotent close. The underlying channel is closed when:
- — Close is invoked and the channel is read to end
- — CloseNow is invoked
- NBChan is observable:
- — DidClose indicates whether Close or CloseNow has been invoked
- — IsClosed indicates whether the underlying channel has closed
- — WaitForClose is deferrable and panic-free and waits until the underlying channel has been closed.
- — WaitForCloseCh returns a channel that closes when the underlying channel closes
- NBChan is designed for error-free operation and only has panics and close errrors. All errors can be collected via:
- — CloseNow WaitForClose GetError
- NBChan has contention-separation between Send/SendMany and Get
- NBChan can be used as an error channel where the sending thread does not block from a delayed or missing reader.
Usage:
var errCh parl.NBChan[error] go thread(&errCh) err, ok := <-errCh.Ch() errCh.WaitForClose() errCh.GetError() … func thread(errCh *parl.NBChan[error]) { defer errCh.Close() // non-blocking close effective on send complete var err error defer parl.Recover(parl.Annotation(), &err, errCh.AddErrorProc) errCh.Ch() <- err // non-blocking if err = someFunc(); err != nil { err = perrors.Errorf("someFunc: %w", err) return
func NewNBChan ¶ added in v0.4.0
func NewNBChan[T any](threadType ...NBChanThreadType) (nbChan *NBChan[T])
NewNBChan returns a non-blocking trillion-size buffer channel.
- NewNBChan allows initialization based on an existing channel.
- NBChan does not need initialization and can be used like:
Usage:
var nbChan NBChan[error] go thread(&nbChan)
func (*NBChan[T]) Ch ¶ added in v0.4.0
func (n *NBChan[T]) Ch() (ch <-chan T)
Ch obtains the receive-only channel
- values can be retrieved using this channel or NBChan.Get
func (*NBChan[T]) Close ¶ added in v0.4.0
Close orders the channel to close once pending sends complete.
- Close is thread-safe, non-blocking, error-free and panic-free
- when Close returns, the channel may still be open and have items
- didClose is true if this Close invocation actually did close the channel
- didClose may be false for all invocations if the channel is closed by sendThread
func (*NBChan[T]) CloseNow ¶ added in v0.4.5
CloseNow closes without waiting for sends to complete.
- CloseNow is thread-safe, panic-free, idempotent, deferrable and is designed to not block for long
- CloseNow does not return until the channel is closed and no thread is running
- Upon return, errp and err receive any close or panic errors for this NBChan
- if errp is non-nil, it is updated with error status
func (*NBChan[T]) DataWaitCh ¶ added in v0.4.100
func (n *NBChan[T]) DataWaitCh() (ch <-chan struct{})
func (*NBChan[T]) DidClose ¶ added in v0.4.20
DidClose indicates if Close or CloseNow was invoked
- the channel may remain open until the last item has been read
- NBChan.CloseNow immediately closes the channel discarding onread items
- NBChan.IsClosed checks if the channel is closed
func (*NBChan[T]) Get ¶ added in v0.4.42
Get returns a slice of n or default all available items held by the channel.
- if channel is empty, 0 items are returned
- Get is non-blocking
- n > 0: max this many items
- n == 0 (or <0): all items
- Get is panic-free non-blocking error-free thread-safe
func (*NBChan[T]) IsClosed ¶ added in v0.4.0
IsClosed indicates whether the channel has actually closed.
func (*NBChan[T]) Scavenge ¶ added in v0.4.97
Scavenge attempts to set capacity of the two queues to setCapacity
- Scavenge allows for reducing queue capacity thus reduce memory leaks
- queue capacities are reduced to the setCapacity value, while ensuring enough capacity for current elements
- unused queue elements are set to zero-value to prevent memory leaks
func (*NBChan[T]) Send ¶ added in v0.4.0
func (n *NBChan[T]) Send(value T)
Send sends a single value on the channel
- non-blocking, thread-safe, panic-free and error-free
func (*NBChan[T]) SendMany ¶ added in v0.4.50
func (n *NBChan[T]) SendMany(values []T)
Send sends many values non-blocking, thread-safe, panic-free and error-free on the channel
- if values is length 0 or nil, SendMany only returns count and capacity
func (*NBChan[T]) SetAllocationSize ¶ added in v0.4.100
SetAllocationSize sets the initial element size of the two queues. Thread-safe
- NBChan allocates two queues of size which may be enlarged by item counts
- supports functional chaining
func (*NBChan[T]) SetAlwaysThread ¶ added in v0.4.100
func (*NBChan[T]) SetNoThread ¶ added in v0.4.100
func (n *NBChan[T]) SetNoThread()
func (*NBChan[T]) ThreadStatus ¶ added in v0.4.100
ThreadStatus indicates the current status of a possible thread
func (*NBChan[T]) WaitForClose ¶ added in v0.4.5
WaitForClose blocks until the channel is closed and empty
- if Close is not invoked or the channel is not read to end, WaitForClose blocks indefinitely
- if CloseNow is invoked, WaitForClose is unblocked
- if errp is non-nil, any thread and close errors are appended to it
- a close error will already have been returned by Close
- thread-safe, panic-free, deferrable
func (*NBChan[T]) WaitForCloseCh ¶ added in v0.4.100
func (n *NBChan[T]) WaitForCloseCh() (ch <-chan struct{})
WaitForCloseCh returns a channel that closes when NBChan.Ch closes
- the underlying channel is sending items, this channel is not
type NBChanThreadType ¶ added in v0.4.100
type NBChanThreadType uint8
const ( // NBChanAlways configures NBChan to always have a thread // - benefit: for empty NBChan, Send/SendMany to channel receive is faster due to avoiding thread launch // - cost: a thread is always running instad of only running when NBChan non-empty // - cost: Close or CloseNow must be invoked to shutdown NBChan NBChanAlways NBChanThreadType = iota + 1 // NBChanNone configures no thread. // - benefit: lower cpu // - cost: data can only be received using [NBChan.Get] NBChanNone )
func (NBChanThreadType) String ¶ added in v0.4.100
func (n NBChanThreadType) String() (s string)
type NotifierFunc ¶ added in v0.4.97
type NotifierFunc func(slice pruntime.StackSlice)
type Once ¶ added in v0.4.18
type Once struct {
// contains filtered or unexported fields
}
parl.Once is an observable sync.Once with an alternative DoErr method. Thread-safe
- parl.Once is thread-safe and does not require initialization
- No thread will return from Once.Do or Once.Doerr until once.Do or once.Doerr has completed
- DoErr invokes a function returning error recovering panics
- IsDone returns whether the Once has been executed, atomic performance
- Result returns DoErr outcome, hasValue indicates if values are present. Atomic eprformance
func (*Once) Do ¶ added in v0.4.18
func (o *Once) Do(f func())
Do calls the function if and only if Do or DoErr is being called for the first time for this instance of Once. Thread-safe
- once.Do must execute for happens before guarantee
func (*Once) DoErr ¶ added in v0.4.43
DoErr calls the function if and only if Do or DoErr is being called for the first time for this instance of Once
- didOnce is true if this invocation was the first that did execute f
- isPanic is true if f had panic
- err is the return value from f or a possible panic
- once.Do must execute for happens before guarantee
type OnceWaiter ¶ added in v0.4.29
type OnceWaiter struct {
// contains filtered or unexported fields
}
OnceWaiter allows any number of threads to wait for a single next occurrence.
- the occurrence is trigger in any of two ways:
- — a parent context may be passed in that on cancel triggers the wait
- — the Cancel method is invoked
- Ch returns a channel that sends one item on the occurrence but never closes
- Done returns a channel that closes on the occurrence happens, similar to a context
- Wait awaits the occurrence
- a did-occurer object can be obtained that returns true once the cycle trigs.
- a context can be obtained that cancels on the next trig
- the cycles can be permanently canceled or trigged and rearmed
func NewOnceWaiter ¶ added in v0.4.29
func NewOnceWaiter(ctx context.Context) (onceReceiver *OnceWaiter)
NewOnceWaiter returns a channel that will send one item when the context cancels or immediately if the context was already canceled.
func (*OnceWaiter) Cancel ¶ added in v0.4.29
func (ow *OnceWaiter) Cancel()
Cancel triggers the occurrence
func (*OnceWaiter) Ch ¶ added in v0.4.29
func (ow *OnceWaiter) Ch() (ch <-chan struct{})
Ch returns a channel that will send one item on the occurrence.
- the channel will not send anything else
- the channel never closes.
func (*OnceWaiter) Context ¶ added in v0.4.29
func (cw *OnceWaiter) Context() (ctx context.Context)
Context returns a context that cancels on the occurrence
func (*OnceWaiter) DidOccur ¶ added in v0.4.29
func (ow *OnceWaiter) DidOccur() (didOccur bool)
DidOccur returns true when the occurrence has taken place
func (*OnceWaiter) Done ¶ added in v0.4.29
func (ow *OnceWaiter) Done() (done <-chan struct{})
Done returns a channel that will close on the occurrence.
- Done is similar to the Done method of a context
func (*OnceWaiter) Wait ¶ added in v0.4.29
func (ow *OnceWaiter) Wait()
Wait waits until the ocurrence
type OnceWaiterRO ¶ added in v0.4.29
type OnceWaiterRO struct {
// contains filtered or unexported fields
}
OnceWaiterRO allows any number of threads to wait for a single next occurrence. OnceWaiterRO is a OnceWaiter without the Cancel method
func NewOnceWaiterRO ¶ added in v0.4.29
func NewOnceWaiterRO(onceWaiter *OnceWaiter) (onceWaiterRO *OnceWaiterRO)
NewOnceWaiter returns a channel that will send one item when the context cancels or immediately if the context was already canceled.
func (*OnceWaiterRO) Ch ¶ added in v0.4.29
func (ow *OnceWaiterRO) Ch() (ch <-chan struct{})
func (*OnceWaiterRO) Context ¶ added in v0.4.29
func (ow *OnceWaiterRO) Context() (ctx context.Context)
func (*OnceWaiterRO) DidOccur ¶ added in v0.4.29
func (ow *OnceWaiterRO) DidOccur() (didOccur bool)
func (*OnceWaiterRO) Done ¶ added in v0.4.29
func (ow *OnceWaiterRO) Done() (done <-chan struct{})
func (*OnceWaiterRO) Wait ¶ added in v0.4.29
func (ow *OnceWaiterRO) Wait()
type PemBytes ¶ added in v0.4.26
type PemBytes []byte
PemBytes bytes is 7-bit ascii string representing keys or certificates
type PeriodWaiter ¶ added in v0.4.100
type PeriodWaiter struct {
// contains filtered or unexported fields
}
PeriodWaiter blocks Wait invokers while a HoldWaiters that has not been succeeded by a ReleaseWaiters invocation. Thread-safe
func NewPeriodWaiter ¶ added in v0.4.100
func NewPeriodWaiter() (periodWaiter *PeriodWaiter)
NewPeriodWaiter returns an object that can hold threads periodically. Thread-safe
func (*PeriodWaiter) Count ¶ added in v0.4.100
func (p *PeriodWaiter) Count() (waitingThreads int)
Count returns the number of threads currently in Wait
func (*PeriodWaiter) HoldWaiters ¶ added in v0.4.100
func (p *PeriodWaiter) HoldWaiters()
HoldWaiters causes a thread invoking PeriodWaiter.Wait to wait. Thread-safe
func (*PeriodWaiter) IsHold ¶ added in v0.4.100
func (p *PeriodWaiter) IsHold() (isHold bool)
IsHold returns whether Wait will currently block
func (*PeriodWaiter) ReleaseWaiters ¶ added in v0.4.100
func (p *PeriodWaiter) ReleaseWaiters()
ReleaseWaiters releases any threads blocked in PeriodWaiter.Wait and lets new Wait invokers proceed. Thread-safe
func (*PeriodWaiter) Wait ¶ added in v0.4.100
func (p *PeriodWaiter) Wait()
Wait blocks the thread if a HoldWaiters invocation took place with no ReleaseWaiters succeeding it. Thread-safe
type Periodically ¶ added in v0.4.16
type Periodically struct {
// contains filtered or unexported fields
}
func NewPeriodically ¶ added in v0.4.16
func (*Periodically) Wait ¶ added in v0.4.26
func (p *Periodically) Wait()
type PrintfFunc ¶ added in v0.4.29
PrintfFunc is the signature for a printf-style function. This signature is implemented by:
- parl.Sprintf
- parl.Out parl.Outw parl.Log parl.Logw parl.Console parl.Consolew parl.Info parl.Debug parl.D parl.NoPrint
- plog.(*LogInstance) similar methods
- perrors.Errorf perrors.ErrorfPF
- fmt.Printf fmt.Sprintf fmt.Errorf
- pterm.(*StatusTerminal).Log pterm.(*StatusTerminal).LogTimeStamp
and compatible functions
type PrivateKey ¶ added in v0.4.26
type PrivateKey interface { crypto.Signer // Public() Sign() DER() (privateKeyDer PrivateKeyDer, err error) // untyped key material, both private and public keys DERe() (privateKeyDer PrivateKeyDer) PEM() (pemBytes PemBytes, err error) PEMe() (pemBytes PemBytes) PublicKey() (publicKey PublicKey) Algo() (algo x509.PublicKeyAlgorithm) // validate ensures the private key is present, modeled after rsa.Validate Validate() (err error) }
PrivateKey implements crypto.Signer and can therefore be used as tls.Certificate.PrivateKey
type PrivateKeyDer ¶ added in v0.4.26
type PrivateKeyDer []byte
PublicKeyDer is a binary encoding of a private and public key-pair
type PrivateKeyFactory ¶ added in v0.4.26
type PrivateKeyFactory interface {
NewPrivateKey(algo x509.PublicKeyAlgorithm) (privateKey PrivateKey, err error)
}
type Promise ¶ added in v0.4.60
Promise is a future computed by a separate thread in parallel with the consumer. Thread-Safe
- any number of threads can use IsDone and Wait methods
- the function fn calculating the result must be thread-safe
- — fn execution is in a new thread
- Wait waits for fn to complete and returns its value and error
- IsDone checks whether the value is present
- FutureValue is in a separate type so that it can be sent on a channel
Note: because the future value is computed in a new thread, tracing the sequence of events may prove difficult would the future cause partial deadlock by the resolver being blocked. The difficulty is that there is no continuous stack trace or thread ID showing what initiated the future. Consider using WinOrWaiter mechanic.
type PublicKey ¶ added in v0.4.26
type PublicKey interface { DER() (publicKeyDer PublicKeyDer, err error) DERe() (publicKeyDer PublicKeyDer) PEM() (pemBytes PemBytes, err error) PEMe() (pemBytes PemBytes) Equal(x crypto.PublicKey) (isEqual bool) Algo() (algo x509.PublicKeyAlgorithm) }
PublicKey contains a public key extracted from a KeyPair
type PublicKeyDer ¶ added in v0.4.26
type PublicKeyDer []byte
PublicKeyDer is a binary encoding of a public key
type Rate ¶ added in v0.4.29
type Rate interface { Clone() (rate Rate) Delta() (delta uint64) Duration() (duration time.Duration) HasValue() (hasValue bool) fmt.Stringer }
Rate describes a rate datapoint.
- may be positive or negative
type RateCounterValues ¶ added in v0.4.29
type RateCounterValues interface { CounterValues // Get() GetReset() Value() Running() Max() Rates() (rates map[RateType]float64) }
CounterValues is the consumer interface for a rate counter. The rate counter provides rates over a provided time period in a map of int64 values.
- ValueRate current rate of increase in value
- ValueMaxRate the maxmimum seen rate of increase in value
- ValueRateAverage the average rate of increase in value taken over up to 10 periods
- RunningRate the current rate of change in running, may be negative
- RunningMaxRate the max positive rate of increase seen in running
- RunningMaxDecRate the max rate of decrease in running, a 0 or negative value
- RunningAverage the average of running taken over up to 10 periods
type RateType ¶ added in v0.4.29
type RateType int
const ( ValueRate RateType = iota // current rate of increase in value ValueMaxRate // max seen rate of increase in value ValueRateAverage // average rate of increase in value during last 10 periods RunningRate RunningMaxRate RunningMaxDecRate // accumulated change in running over several intervals // - running value goes up and down RunningAverage NotAValue // NotAValue is an internal stand-in value indicating a value not in use )
type SelectChannel ¶ added in v0.4.53
type SelectChannel struct {
// contains filtered or unexported fields
}
SelectChannel provides a channel that closes upon the next Trig. Thread-safe.
- SelectChannel is designed to be used in an external select statement receiving from contexts, the select-channel and other data-providing channels
- SelectChannel allows a thread waiting in external sleect-statement to be:
- — cancelled via contexts,
- — receive data or
- — be notified of alternative action via the select-channel
- SelectChannel allows many threads to wait until an action is taken by another thread
- SelectChannel does not require initialization
func NewSelectChannel ¶ added in v0.4.53
func NewSelectChannel() (channelWaiter *SelectChannel)
NewSelectChannel returns a thread-safe provider of channels that close upon Trig
func (*SelectChannel) Ch ¶ added in v0.4.53
func (cw *SelectChannel) Ch() (ch <-chan struct{})
Ch provides a context-like channel for a select and this provided channel closes on Trig. Thread-safe
func (*SelectChannel) Trig ¶ added in v0.4.53
func (cw *SelectChannel) Trig()
Trig closes the current channel and initializes a new channel. Thread-safe
type SerialDo ¶
type SerialDo struct {
// contains filtered or unexported fields
}
SerialDo serializes a thunk.
func NewSerialDo ¶
func NewSerialDo( thunk func(at time.Time), eventFn func(event *SerialDoEvent), errFn func(err error), ctx context.Context) (sdo *SerialDo)
NewSerialDo serializes .Do invocations eventFn must be thread-safe. errFn must be thread-safe.
func (*SerialDo) Do ¶
Do invokes the thunk serially if SerialDo is idle, Do launches thunk via a thread if SerialDo is busy, Do makes it pending if SerialDo is already pending, Do does nothing Do returns true if SerialDo state is pending Do is non-blocking and thread-safe
type SerialDoCore ¶ added in v0.4.26
type SerialDoCore struct {
// contains filtered or unexported fields
}
func NewSerialDoCore ¶ added in v0.4.26
func (*SerialDoCore) Do ¶ added in v0.4.26
func (sdo *SerialDoCore) Do(now ...time.Time) (isPending bool, isShutdown bool)
func (*SerialDoCore) Wait ¶ added in v0.4.26
func (sdo *SerialDoCore) Wait(at time.Time)
type SerialDoEvent ¶
type SerialDoEvent struct { ID SerialDoID SerialDoType time.Time *SerialDo }
func NewSerialDoEvent ¶ added in v0.4.26
func NewSerialDoEvent(typ SerialDoType, t time.Time, serialDo *SerialDo) (event *SerialDoEvent)
func (*SerialDoEvent) String ¶ added in v0.4.26
func (e *SerialDoEvent) String() (s string)
type SerialDoID ¶ added in v0.4.26
type SerialDoID string
func (SerialDoID) String ¶ added in v0.4.26
func (id SerialDoID) String() (s string)
type SerialDoType ¶ added in v0.4.26
type SerialDoType uint8
const ( // The SerialDo is invoking thunk from idle, now time SerialDoLaunch SerialDoType = 1 + iota // The SerialDo enqueued a future invocation, request time SerialDoPending // The SerialDo is launching a pending invocation, request time SerialDoPendingLaunch // The SerialDo returned to being idle, time is busy since SerialDoIdle )
func (SerialDoType) IsValid ¶ added in v0.4.26
func (e SerialDoType) IsValid() (isValid bool)
func (SerialDoType) String ¶ added in v0.4.26
func (e SerialDoType) String() (s string)
type ServerFactory ¶ added in v0.3.0
type ServerFactory interface { // Adb connects to an adb adb Android Debug Bridge server on a specified tcp socket Adb(address AdbSocketAddress, ctx context.Context) (server Serverette) // AdbLocalhost connects to an adb Android Debug Bridge server on the local computer AdbLocalhost(ctx context.Context) (server Serverette) }
ServerFactory describes how AdbServer objects are obtained. Such servers may use duifferent protocol implementations from Adbette
type Serverette ¶ added in v0.3.0
type Serverette interface { AdbAdressProvider // AdbSocketAddress() // DeviceSerialList lists serials for the currently online Android devices DeviceSerialList() (serials []AndroidSerial, err error) // DeviceStati lists all serials currently known to the server along with // their current status. // The two slices correspond and are of the same length DeviceStati() (serials []AndroidSerial, stati []AndroidStatus, err error) // TrackDevices emits serial numbers for devices that come online. // serials are sent on the serials channel. // if err is non-nil, set-up of failed. // The errs channel closes when watching stops // Watching is stopped by calling cancel function or when the server’s context terminates TrackDevices() (tracker Trackerette, err error) }
Serverette is a generic representation of an adb server running on a host.
command-line adb: As of Android 12, Android Debug Bridge version 1.0.41 Version 32.0.0-8006631 has the following commands are supported: devices connect disconnect pair forward ppp reverse mdns push pull sync shell emu install install-multiple install-multiple-package uninstall bugreport jdwp logcat disable-verity enable-verity keygen wait-for* get-state get-serialno get-devpath remount reboot sideload root unroot usb tcpip start-server kill-server reconnect attach detach
type ServeretteFactory ¶ added in v0.3.0
type ServeretteFactory interface { // Adb connects to an adb adb Android Debug Bridge server on a specified tcp socket. // address is a string default "localhost:5037" and default port ":5037". // adbetter is a factory for Adbette connections. NewServerette(address AdbSocketAddress, adbetter Adbetter, ctx context.Context) (server Serverette) }
ServeretteFactory is a Server connection factory for Adbette implementations
type SlowDetector ¶ added in v0.4.41
type SlowDetector struct {
// contains filtered or unexported fields
}
SlowDetector measures latency via Start-Stop invocations and prints max latency values above threshold to stderr. Thread-safe
func NewSlowDetector ¶ added in v0.4.41
func NewSlowDetector(label string, slowTyp slowType, printf PrintfFunc, goGen GoGen, threshold ...time.Duration) (slowDetector *SlowDetector)
NewSlowDetector returns a Start-Stop variable detecting slowness
- label is a name for the measured activity, default the code location of caller
- slowTyp is most commonly SlowDefault using a shared thread
- default printf is parl.Log, ie. ouput to stderr
- first optional duration is minimum latency to report, default 100 ms if first optional duration is 0, all max-slowness invocations are printed
- second optional duration is reporting period of non-return, default 1 minute
- output is to stderr
func (*SlowDetector) IsValid ¶ added in v0.4.51
func (sd *SlowDetector) IsValid() (isValid bool)
func (*SlowDetector) Start ¶ added in v0.4.41
func (sd *SlowDetector) Start(label string, value ...time.Time) (slowInvocation SlowInvocation)
func (*SlowDetector) Start0 ¶ added in v0.4.45
func (sd *SlowDetector) Start0() (slowInvocation SlowInvocation)
func (*SlowDetector) Status ¶ added in v0.4.48
func (sd *SlowDetector) Status() (s string)
func (*SlowDetector) Status0 ¶ added in v0.4.48
func (sd *SlowDetector) Status0() (s string)
last-duration / average duration / max duration
type SlowDetectorCore ¶ added in v0.4.44
type SlowDetectorCore struct { ID slowID // contains filtered or unexported fields }
SlowDetectorCore measures latency via Start-Stop invocations
- Thread-Safe and multi-threaded, parallel invocations
- Separate thread measures time of non-returning, hung invocations
func NewSlowDetectorCore ¶ added in v0.4.44
func NewSlowDetectorCore(callback CbSlowDetector, slowTyp slowType, goGen GoGen, threshold ...time.Duration) (slowDetector *SlowDetectorCore)
func (*SlowDetectorCore) Start ¶ added in v0.4.44
func (sd *SlowDetectorCore) Start(invoLabel string, value ...time.Time) (invocation *SlowDetectorInvocation)
Start returns the effective start time for a new timing cycle
- value is optional start time, default time.Now()
type SlowDetectorInvocation ¶ added in v0.4.44
type SlowDetectorInvocation struct {
// contains filtered or unexported fields
}
SlowDetectorInvocation is a container used by SlowDetectorCore
func (*SlowDetectorInvocation) Interval ¶ added in v0.4.48
func (sdi *SlowDetectorInvocation) Interval(label string, t ...time.Time)
Stop ends an invocation part of SlowDetectorCore
func (*SlowDetectorInvocation) Intervals ¶ added in v0.4.56
func (sdi *SlowDetectorInvocation) Intervals() (intervalStr string)
func (*SlowDetectorInvocation) Label ¶ added in v0.4.44
func (sdi *SlowDetectorInvocation) Label() (label string)
Label returns the label for this invocation
func (*SlowDetectorInvocation) Stop ¶ added in v0.4.44
func (sdi *SlowDetectorInvocation) Stop(value ...time.Time)
Stop ends an invocation part of SlowDetectorCore
func (*SlowDetectorInvocation) T0 ¶ added in v0.4.44
func (sdi *SlowDetectorInvocation) T0() (t0 time.Time)
T0 returns the effective time of the invocation of Start
func (*SlowDetectorInvocation) ThreadID ¶ added in v0.4.44
func (sdi *SlowDetectorInvocation) ThreadID() (threadID ThreadID)
ThreadID returns the thread ID dor the thread invoking Start
type SlowDetectorThread ¶ added in v0.4.44
type SlowDetectorThread struct {
// contains filtered or unexported fields
}
func NewSlowDetectorThread ¶ added in v0.4.44
func NewSlowDetectorThread(slowTyp slowType, nonReturnPeriod time.Duration, goGen GoGen) (sdt *SlowDetectorThread)
func (*SlowDetectorThread) Start ¶ added in v0.4.44
func (sdt *SlowDetectorThread) Start(sdi *SlowDetectorInvocation)
func (*SlowDetectorThread) Stop ¶ added in v0.4.44
func (sdt *SlowDetectorThread) Stop(sdi *SlowDetectorInvocation)
type SlowInvocation ¶ added in v0.4.44
type Stack ¶ added in v0.4.20
type Stack interface { ID() ThreadID // the thread ID 1… for the thread requesting the stack trace. main thread has ID 1. Status() ThreadStatus // a word indicating thread status, typically word “running” IsMain() (isMain bool) // true if the thread is the main thread // A list of code locations for this thread. // [0] is the most recent code location, typically the invoker requesting the stack trace. Frames() (frames []Frame) // goFunction is the function that a goroutine launched // - is isMain is true, it is the zero-value // - never nil GoFunction() (goFunction *pruntime.CodeLocation) // the code location of the go statement creating this thread. // - if IsMain true, this field is zero-value, check with CodeLocation.IsSet // - never nil Creator() (creator *pruntime.CodeLocation) // Shorts lists short code locations for all stack frames, most recent first: // Shorts("prepend") → // prepend Thread ID: 1 // prepend main.someFunction()-pruntime.go:84 // prepend main.main()-pruntime.go:52 Shorts(prepend string) (s string) // String is a multi-line stack trace, most recent code location first: // ID: 18 IsMain: false status: running // main.someFunction({0x100dd2616, 0x19}) // pruntime.go:64 // cre: main.main-pruntime.go:53 String() (s string) }
type Statuser ¶ added in v0.3.0
Statuser prints threads that do not react within a specified time frame. This is useful during early multi-threaded design when it is uncertain why work is not progressing. Is it your code or their code? Once the program concludes without hung threads, Tracer is the better tool to identify issues.
type StatuserFactory ¶ added in v0.3.0
type SubGo ¶ added in v0.4.15
type SubGo interface { // Go returns a Go object to be provided as a go statement function argument. Go() (g0 Go) // SubGo returns athread-group whose fatal errors go to Go’s parent. // - both non-fatal and fatal errors in SubGo threads are sent to Go’s parent // like Go.AddError and Go.Done. // - therefore, when a SubGo thread fails, the application will typically exit. // - by awaiting SubGo, Go can delay its exit until SubGo has terminated // - the SubGo thread-group terminates when the its thread exits SubGo(onFirstFatal ...GoFatalCallback) (subGo SubGo) // SubGroup creates a sub-ordinate GoGroup. // - SubGroup fatal and non-fatal errors are sent to the parent GoGroup. // - SubGroup-context initiated Cancel only affect threads in the SubGroup thread-group // - parent-initiated Cancel terminates SubGroup threads // - SubGroup only awaits SubGroup threads // - parent await also awaits SubGroup threads SubGroup(onFirstFatal ...GoFatalCallback) (subGroup SubGroup) // Wait waits for all threads of this thread-group to terminate. Wait() // returns a channel that closes on subGo end similar to Wait WaitCh() (ch <-chan struct{}) // EnableTermination false prevents the SubGo or GoGroup from terminating // even if the number of threads is zero EnableTermination(allowTermination bool) IsEnableTermination() (mayTerminate bool) // Cancel terminates the threads in this and subordinate thread-groups. Cancel() // Context will Cancel when the parent context Cancels. // Subordinate thread-groups do not Cancel this context. Context() (ctx context.Context) // the available data for all threads Threads() (threads []ThreadData) // threads that have been named ordered by name NamedThreads() (threads []ThreadData) // SetDebug enables debug logging on this particular instance SetDebug(debug GoDebug) fmt.Stringer }
type SubGroup ¶ added in v0.4.29
type SubGroup interface { SubGo // Ch returns a receive channel for fatal errors if this SubGo has LocalChannel option. Ch() (ch <-chan GoError) // FirstFatal allows to await or inspect the first thread terminating with error. // it is valid if this SubGo has LocalSubGo or LocalChannel options. // To wait for first fatal error using multiple-semaphore mechanic: // firstFatal := g0.FirstFatal() // for { // select { // case <-firstFatal.Ch(): // … // To inspect first fatal: // if firstFatal.DidOccur() … FirstFatal() (firstFatal *OnceWaiterRO) }
type SyncAdd ¶ added in v0.4.20
type SyncAdd interface {
Add(delta int)
}
SyncWait provides sync.WaitGroup.Add()
type SyncDone ¶ added in v0.4.20
type SyncDone interface {
Done()
}
SyncDone provides sync.WaitGroup.Done()
type SyncWait ¶ added in v0.4.20
type SyncWait interface {
Wait()
}
SyncWait provides sync.WaitGroup.Wait()
type TResult ¶ added in v0.4.60
func NewTResult ¶ added in v0.4.60
RecoverInvocationPanicT invokes resolver, recover panics and populates v
type ThreadData ¶ added in v0.4.43
type ThreadData interface { // threadID is the ID of the running thread assigned by the go runtime // - IsValid method checks if value is present // - zero value is empty string // - .ThreadID().String(): "5" ThreadID() (threadID ThreadID) // createLocation is the code line of the go statement function-call // creating the goroutine thread // - IsSet method checks if value is present // - Create().Short(): "g0.(*SomeType).SomeCode()-thread-data_test.go:73" Create() (createLocation *pruntime.CodeLocation) // Func returns the code line of the function of the running thread. // - IsSet method checks if value is present // - .Func().Short(): "g0.(*SomeType).SomeFunction()-thread-data_test.go:80" Func() (funcLocation *pruntime.CodeLocation) // optional thread-name assigned by consumer // - zero-value: empty string "" for threads that have not been named Name() (label string) // Short returns a short description of the thread "label:threadID" or fmt.Stringer // - "myThreadName:4" // - zero-value: "[empty]" ThreadDataEmpty // - nil value: "threadData:nil" ThreadDataNil Short() (short string) // all non-empty fields: [label]:[threadID]_func:[Func]_cre:[Create] // - "myThreadName:5_func:g0.(*SomeType).SomeFunction()-thread-data_test.go:80_cre:g0.(*SomeType).SomeCode()-thread-data_test.go:73" // - zero-value: "[empty]" ThreadDataEmpty fmt.Stringer }
ThreadData is information about a Go object thread.
- initially, only Create is present
- Name is only present for threads that have been named
type ThreadID ¶ added in v0.4.9
type ThreadID uint64
ThreadID is an opaque type that uniquley identifies a thread, ie. a goroutine.
- goid.GoID obtains ThreadID for the executing thread.
- in runtime.g, goid is uint64
- ThreadID is comparable, ie. can be used as a map key.
- ThreadID is fmt.Stringer
- ThreadID has IsValid method
type ThreadResult ¶ added in v0.4.9
type ThreadResult struct {
Err // Error() string
}
type ThreadStatus ¶ added in v0.4.12
type ThreadStatus string
ThreadStatus indicates the current stat of a thread most often it is "running"
type Timer ¶
type Timer struct { Label string // contains filtered or unexported fields }
Timer is a simple request timer
type TraceGroup ¶ added in v0.4.20
type TraceGroup struct { WaitGroup // contains filtered or unexported fields }
parl.TraceGroup is an observable sync.Waitgroup.
TraceGroup cannot be in parl because WaitAction imports goid
func (*TraceGroup) Add ¶ added in v0.4.20
func (wg *TraceGroup) Add(delta int)
func (*TraceGroup) Done ¶ added in v0.4.20
func (wg *TraceGroup) Done()
func (*TraceGroup) DoneBool ¶ added in v0.4.20
func (wg *TraceGroup) DoneBool() (isZero bool)
func (*TraceGroup) String ¶ added in v0.4.20
func (wg *TraceGroup) String() (s string)
type Tracer ¶ added in v0.3.0
type Tracer interface { // AssignTaskToThread assigns a Thread to a task AssignTaskToThread(threadID ThreadID, task TracerTaskID) (tracer Tracer) // RecordTaskEvent adds an event to the task threadID is currently assigned to. // If threadID is not assigned, a new task is created. RecordTaskEvent(threadID ThreadID, text string) (tracer Tracer) // Records returns the current map of tasks and their events Records(clear bool) (records map[TracerTaskID][]TracerRecord) }
Tracer lists events in terms of tasks rather than per time or thread. A task is executed by threads assigned to it. Threads are uniquely identified by threadID. A task can have zero or one threads assigned at any one time. A thread can be assigned to zero or one tasks. Each task has an ID, a name and a list of events and thread assignments Tracer can record branching in the code and return that for a particular item being processed. For an item processed incorrectly, or when threads hang, Tracer will find unfavorable branching and last known locations.
type TracerFactory ¶ added in v0.3.0
type TracerRecord ¶ added in v0.3.0
type TracerTaskID ¶ added in v0.3.0
type TracerTaskID string
type Trackerette ¶ added in v0.3.0
type Trackerette interface { // Serials emit serial number as online devices become available Serials() (serials <-chan AndroidSerial) // Errs is available once Serials close. It returns any errors Errs() (err error) // Cancel shuts down the Tracker Cancel() }
Trackerette represents a server connection emitting device serial numbers
type UniqueID ¶ added in v0.4.26
UniqueID is an executable-invocation-unique identifier generator. The format is a named-type small-integer numeric string suitable to distinguish multiple instances of a type. The type is ordered and can be converted to string.
Usage:
type MyType string var generator parl.UniqueID[MyType] someID := generator.ID()
type UniqueIDTypedUint64 ¶ added in v0.4.29
UniqueIDTypedUint64 generates integer-based opaque uniquely-typed IDs. Thread-safe.
- Different named-type series have their own unique type and can be told apart.
- The named types are ordered integer-based with String method implementing fmt.Stringer.
Usage:
type T uint64 var generator parl.UniqueIDTypedUint64[T] func (t T) String() string { return generator.StringT(t) } someID := generator.ID()
func (*UniqueIDTypedUint64[T]) ID ¶ added in v0.4.29
func (u *UniqueIDTypedUint64[T]) ID() (uniqueT T)
ID generates a unique ID of integral type. Thread-safe
func (*UniqueIDTypedUint64[T]) StringT ¶ added in v0.4.29
func (u *UniqueIDTypedUint64[T]) StringT(t T) (s string)
"parl.T:2", zero-value t prints "parl.T:0"
type UniqueIDUint64 ¶ added in v0.4.29
type UniqueIDUint64 uint64
UniqueIDUint64 generates executable-invocation-unique uint64 numbers 1… Different series of uint64 from different generators does not have identity, ie. they cannot be told apart. Consider UniqueIDTypedUint64 to have identity.
Usage:
var generator parl.UniqueIDUint64 id := generator.ID()
func (*UniqueIDUint64) ID ¶ added in v0.4.29
func (u *UniqueIDUint64) ID() (uniqueUint64 uint64)
ID generates a unique uint64 1…. thread-safe
func (*UniqueIDUint64) String ¶ added in v0.4.29
func (u *UniqueIDUint64) String() (s string)
type WaitAction ¶ added in v0.4.20
type WaitAction struct { ID ThreadID Loc pruntime.CodeLocation IsDone bool Delta int }
func NewWaitAction ¶ added in v0.4.20
func NewWaitAction(skipFrames int, delta int, isDone bool) (waitAction *WaitAction)
func (*WaitAction) String ¶ added in v0.4.20
func (wa *WaitAction) String() (s string)
type WaitGroup ¶ added in v0.3.0
parl.WaitGroup is like a sync.Waitgroup that can be inspected. The Waiting method returns the number of threads waited for. parl.WaitGroup requires no initialization.
var wg parl.WaitGroup wg.Add(1) … wg.Waiting()
func NewWaitGroup ¶ added in v0.4.62
func NewWaitGroup() (waitGroup *WaitGroup)
type Waitable ¶ added in v0.4.12
type Waitable interface {
Wait() // similar to sync.WaitGroup.Wait()
}
Waitable is the invoker’s Wait part of sync.WaitGroup and other implementations. Waitable is a many-to-many relation. Waitable allows the caller to await exit and free of all invocations.
waitsForLots parl.WaitGroup shutsDownLots parl.OnceChan … = NewSomething(&waitsForLots, &shutsDownLots) go someThread(&waitsForLots, &shutsDownLots) func someThread(Doneable w, context.Context ctx) { defer w.Done() w.Add(2) go somethingElse()
type Waiter ¶ added in v0.4.20
type Waiter interface { WaitedOn WaitingFor }
waiter allows to use any of observable parl.WaitGroup or parl.TraceGroup
type WaitingFor ¶ added in v0.4.20
type WinOrWaiterCore ¶ added in v0.4.29
type WinOrWaiterCore struct {
// contains filtered or unexported fields
}
WinOrWaiter picks a winner thread to carry out some task used by many threads.
- threads in WinOrWait for an idle WinorWaiter may become winners completing the task
- threads in WinOrWait while a calculation is in progress are held waiting using RWLock and atomics until the calculation completes
- the calculation is completed on demand, but only by the first requesting thread
func NewWinOrWaiterCore ¶ added in v0.4.29
func NewWinOrWaiterCore(strategy WinOrWaiterStrategy, calculator func() (err error), ctx ...context.Context) (winOrWaiter *WinOrWaiterCore)
WinOrWaiter returns a semaphore used for completing an on-demand task by the first thread requesting it, and that result shared by subsequent threads held waiting for the result.
- strategy: WinOrWaiterAnyValue WinOrWaiterMustBeLater
- ctx allows foir cancelation of the WinOrWaiter
func (*WinOrWaiterCore) IsCancel ¶ added in v0.4.29
func (ww *WinOrWaiterCore) IsCancel() (isCancel bool)
func (*WinOrWaiterCore) WinOrWait ¶ added in v0.4.29
func (ww *WinOrWaiterCore) WinOrWait() (err error)
WinOrWaiter picks a winner thread to carry out some task used by many threads.
- threads arriving to an idle WinorWaiter are winners that complete the task
- threads arriving to a WinOrWait in progress are held waiting at RWMutex
- the task is completed on demand, but only by the first thread requesting it
type WinOrWaiterStrategy ¶ added in v0.4.41
type WinOrWaiterStrategy uint8
const ( // WinOrWaiterAnyValue causes a thread to accept any calculated value WinOrWaiterAnyValue WinOrWaiterStrategy = iota // WinOrWaiterMustBeLater forces a calculation after the last arriving thread. // WinOrWaiter caclulations are serialized, ie. a new calculation does not start prior to // the conlusion of the previous calulation WinOrWaiterMustBeLater )
func (WinOrWaiterStrategy) IsValid ¶ added in v0.4.50
func (ws WinOrWaiterStrategy) IsValid() (isValid bool)
func (WinOrWaiterStrategy) String ¶ added in v0.4.41
func (ws WinOrWaiterStrategy) String() (s string)
Source Files ¶
- adderror.go
- android-serial.go
- android-status.go
- atomic-bool.go
- atomic-counter.go
- atomic-max-duration.go
- atomic-max.go
- atomic-min.go
- atomic-reference.go
- cancel-context.go
- channel-send.go
- closable-chan.go
- closer.go
- collect-error.go
- cyclic-waiter.go
- debouncer.go
- do-func.go
- echo-moderator.go
- err-ch-wait.go
- err-end-callbacks.go
- err-nil-value.go
- errable.go
- error-string.go
- future.go
- go-error-source.go
- goid.go
- if-adb-devicette.go
- if-adb-serverette.go
- if-adbette.go
- if-counter.go
- if-db.go
- if-dsn.go
- if-enum.go
- if-go.go
- if-iterator.go
- if-moderator.go
- if-pki.go
- if-printf.go
- if-stack.go
- if-statuser.go
- if-tracer.go
- if-waitable.go
- if-watchfs.go
- infallible.go
- invoke-if.go
- invoke-timer-invo.go
- invoke-timer.go
- is-nil.go
- log.go
- moderator-core.go
- moderator.go
- mutex-wait.go
- nb-chan-close.go
- nb-chan-get.go
- nb-chan-logger.go
- nb-chan-scavenge.go
- nb-chan-send.go
- nb-chan-thread.go
- nb-chan-wait-for-close.go
- nb-chan.go
- on-cancel.go
- on-debug.go
- once-waiter-ro.go
- once-waiter.go
- once.go
- parl.go
- period-waiter.go
- periodically.go
- promise.go
- recover-invocation-panic.go
- recover.go
- select-channel.go
- serial-do-core.go
- serial-do-event.go
- serial-do-id.go
- serial-do-type.go
- serial-do.go
- short.go
- slow-detector-core.go
- slow-detector-invocation.go
- slow-detector-thread.go
- slow-detector.go
- sprintf.go
- thread-id.go
- thread-result.go
- timer.go
- trace-group.go
- uintptr.go
- unique-id-typed-uint64.go
- unique-id-uint64.go
- unique-id.go
- wait-action.go
- wait-group.go
- wait.go
- win-or-waiter-core.go
Directories ¶
Path | Synopsis |
---|---|
Datapoint tracks a fluctuating value with average.
|
Datapoint tracks a fluctuating value with average. |
Package errorglue contains non-essential error declarations
|
Package errorglue contains non-essential error declarations |
goid.GoID() provides a unique goroutine identifier.
|
goid.GoID() provides a unique goroutine identifier. |
HaltDetector sends detected Go runtime execution halts on channel ch.
|
HaltDetector sends detected Go runtime execution halts on channel ch. |
AddressFamily contains iana Address Family Numbers such as IP versions 4 and 6 for the Internet.
|
AddressFamily contains iana Address Family Numbers such as IP versions 4 and 6 for the Internet. |
internal
|
|
cyclebreaker
© 2020–present Harald Rudell <harald.rudell@gmail.com> (https://haraldrudell.github.io/haraldrudell/) ISC License
|
© 2020–present Harald Rudell <harald.rudell@gmail.com> (https://haraldrudell.github.io/haraldrudell/) ISC License |
Package ints provide manipulation of integer types.
|
Package ints provide manipulation of integer types. |
SlicePIterator traverses a slice container using pointers to value.
|
SlicePIterator traverses a slice container using pointers to value. |
mains
module
|
|
omaps
module
|
|
Package parlca provides a self-signed certificate authority
|
Package parlca provides a self-signed certificate authority |
Package perrors enrichens error values with string data, stack traces, associated errors, less severe warnings, thread-safe containers and comprehensive error string representations.
|
Package perrors enrichens error values with string data, stack traces, associated errors, less severe warnings, thread-safe containers and comprehensive error string representations. |
EofReader is an empty reader returning EOF.
|
EofReader is an empty reader returning EOF. |
plog provides thread-safe log instances for any writer
|
plog provides thread-safe log instances for any writer |
Ranking is a pointer-identity-to-value map of updatable values traversable by rank.
|
Ranking is a pointer-identity-to-value map of updatable values traversable by rank. |
Package pnet provides IP-related functions with few dependencies beyond the net package
|
Package pnet provides IP-related functions with few dependencies beyond the net package |
Package parlos provides simplified functions related to the os package
|
Package parlos provides simplified functions related to the os package |
Package prand provides a fast and thread-safe random number generation.
|
Package prand provides a fast and thread-safe random number generation. |
process
module
|
|
Package progress provides printable progress reporting for multi-threaded operations
|
Package progress provides printable progress reporting for multi-threaded operations |
Package pruntime provides an interface to the Go standard library’s runtime package using only serializable simple types
|
Package pruntime provides an interface to the Go standard library’s runtime package using only serializable simple types |
OrderedAny is a slice ordered by a function allowing duplicates.
|
OrderedAny is a slice ordered by a function allowing duplicates. |
Package psql augments database/sql
|
Package psql augments database/sql |
pstrings provides FilteredJoin QuoteList StrSliceContains
|
pstrings provides FilteredJoin QuoteList StrSliceContains |
pterm
module
|
|
EpochValue is a timestamp with Thread-Safe atomic access.
|
EpochValue is a timestamp with Thread-Safe atomic access. |
punix has functions to examine unix.Errno errors
|
punix has functions to examine unix.Errno errors |
Set provides a collection of unique elements of a particular type T that are printable, type convertible and have verifiable validity.
|
Set provides a collection of unique elements of a particular type T that are printable, type convertible and have verifiable validity. |
sqliter
module
|
|
Package threadprof provide profiling of threading
|
Package threadprof provide profiling of threading |
tracer has events by task then time rather than time or thread
|
tracer has events by task then time rather than time or thread |
watchfs
module
|
|
yaml
module
|
|
yamler
module
|
|