Documentation ¶
Index ¶
- Variables
- func MultiError(errors ...error) error
- func NewBackgroundContext(ctx context.Context) context.Context
- func RolledUpErrorMessage(err error) string
- func StringSliceFromRawElement(element bson.RawElement) ([]string, error)
- func StringSliceFromRawValue(name string, val bson.RawValue) ([]string, error)
- func UnwrapError(err error) error
- func WrapError(inner error, message string) error
- func WrapErrorf(inner error, format string, args ...interface{}) error
- type CancellationListener
- type Semaphore
- type WrappedError
Constants ¶
This section is empty.
Variables ¶
var ( // ErrLoadBalancedWithMultipleHosts is returned when loadBalanced=true is specified in a URI with multiple hosts. ErrLoadBalancedWithMultipleHosts = errors.New("loadBalanced cannot be set to true if multiple hosts are specified") // ErrLoadBalancedWithReplicaSet is returned when loadBalanced=true is specified in a URI with the replicaSet option. ErrLoadBalancedWithReplicaSet = errors.New("loadBalanced cannot be set to true if a replica set name is specified") // ErrLoadBalancedWithDirectConnection is returned when loadBalanced=true is specified in a URI with the directConnection option. ErrLoadBalancedWithDirectConnection = errors.New("loadBalanced cannot be set to true if the direct connection option is specified") )
var SetMockServiceID = false
SetMockServiceID enables a mode in which the driver mocks server support for returning a "serviceId" field in "hello" command responses by using the value of "topologyVersion.processId". This is used for testing load balancer support until an upstream service can support running behind a load balancer.
var Version = "local build"
Version is the current version of the driver.
Functions ¶
func MultiError ¶
MultiError combines multiple errors into a single error. If there are no errors, nil is returned. If there is 1 error, it is returned. Otherwise, they are combined.
func NewBackgroundContext ¶ added in v1.5.0
NewBackgroundContext creates a new Context whose behavior matches that of context.Background(), but Value calls are forwarded to the provided ctx parameter. If ctx is nil, context.Background() is returned.
func RolledUpErrorMessage ¶
RolledUpErrorMessage gets a flattened error message.
func StringSliceFromRawElement ¶ added in v1.5.0
func StringSliceFromRawElement(element bson.RawElement) ([]string, error)
StringSliceFromRawElement decodes the provided BSON element into a []string. This internally calls StringSliceFromRawValue on the element's value. The error conditions outlined in that function's documentation apply for this function as well.
func StringSliceFromRawValue ¶ added in v1.5.0
StringSliceFromRawValue decodes the provided BSON value into a []string. This function returns an error if the value is not an array or any of the elements in the array are not strings. The name parameter is used to add context to error messages.
func UnwrapError ¶
UnwrapError attempts to unwrap the error down to its root cause.
func WrapErrorf ¶
WrapErrorf wraps an error with a message.
Types ¶
type CancellationListener ¶ added in v1.5.0
type CancellationListener struct {
// contains filtered or unexported fields
}
CancellationListener listens for context cancellation in a loop until the context expires or the listener is aborted.
func NewCancellationListener ¶ added in v1.5.0
func NewCancellationListener() *CancellationListener
NewCancellationListener constructs a CancellationListener.
func (*CancellationListener) Listen ¶ added in v1.5.0
func (c *CancellationListener) Listen(ctx context.Context, abortFn func())
Listen blocks until the provided context is cancelled or listening is aborted via the StopListening function. If this detects that the context has been cancelled (i.e. ctx.Err() == context.Canceled), the provided callback is called to abort in-progress work. Even if the context expires, this function will block until StopListening is called.
func (*CancellationListener) StopListening ¶ added in v1.5.0
func (c *CancellationListener) StopListening() bool
StopListening stops the in-progress Listen call. This blocks if there is no in-progress Listen call. This function will return true if the provided abort callback was called when listening for cancellation on the previous context.
type Semaphore ¶
type Semaphore struct {
// contains filtered or unexported fields
}
Semaphore is a synchronization primitive that controls access to a common resource.
func NewSemaphore ¶
NewSemaphore creates a new semaphore.
type WrappedError ¶
type WrappedError interface { // Message gets the basic message of the error. Message() string // Inner gets the inner error if one exists. Inner() error }
WrappedError represents an error that contains another error.