Package-Level Type Names (total 4, in which 2 are exported)
/* sort exporteds by: | */
Group represents a class of work and forms a namespace in
which units of work can be executed with duplicate suppression.
// lazily initialized
// protects m
Do executes and returns the results of the given function, making
sure that only one execution is in-flight for a given key at a
time. If a duplicate comes in, the duplicate caller waits for the
original to complete and receives the same results.
The return value shared indicates whether v was given to multiple callers.
DoChan is like Do but returns a channel that will receive the
results when they are ready.
The returned channel will not be closed.
Forget tells the singleflight to forget about a key. Future calls
to Do for this key will call the function rather than waiting for
an earlier call to complete.
doCall handles the single call for a key.
call is an in-flight or completed singleflight.Do call
chans[]chan<- Result
These fields are read and written with the singleflight
mutex held before the WaitGroup is done, and are read but
not written after the WaitGroup is done.
errerror
forgotten indicates whether Forget was called with this call's key
while the call was still in flight.
These fields are written once before the WaitGroup is done
and are only read after the WaitGroup is done.
wgsync.WaitGroup
func (*Group).doCall(c *call, key string, fn func() (interface{}, error))
A panicError is an arbitrary value recovered from a panic
with the stack trace during the execution of given function.
stack[]bytevalueinterface{}
Error implements error interface.
*panicError : error
Package-Level Functions (only one, which is unexported)