forked from ReactiveX/RxGo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathtypes.go
80 lines (70 loc) · 2.9 KB
/
types.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
package rxgo
import "context"
type (
operatorOptions struct {
stop func()
resetIterable func(Iterable)
}
// Comparator defines a func that returns an int:
// - 0 if two elements are equals
// - A negative value if the first argument is less than the second
// - A positive value if the first argument is greater than the second
Comparator func(interface{}, interface{}) int
// ItemToObservable defines a function that computes an observable from an item.
ItemToObservable func(Item) Observable
// ErrorToObservable defines a function that transforms an observable from an error.
ErrorToObservable func(error) Observable
// Func defines a function that computes a value from an input value.
Func func(context.Context, interface{}) (interface{}, error)
// Func2 defines a function that computes a value from two input values.
Func2 func(context.Context, interface{}, interface{}) (interface{}, error)
// FuncN defines a function that computes a value from N input values.
FuncN func(...interface{}) interface{}
// ErrorFunc defines a function that computes a value from an error.
ErrorFunc func(error) interface{}
// Predicate defines a func that returns a bool from an input value.
Predicate func(interface{}) bool
// Marshaller defines a marshaller type (interface{} to []byte).
Marshaller func(interface{}) ([]byte, error)
// Unmarshaller defines an unmarshaller type ([]byte to interface).
Unmarshaller func([]byte, interface{}) error
// Producer defines a producer implementation.
Producer func(ctx context.Context, next chan<- Item)
// Supplier defines a function that supplies a result from nothing.
Supplier func(ctx context.Context) Item
// Disposed is a notification channel indicating when an Observable is closed.
Disposed <-chan struct{}
// Disposable is a function to be called in order to dispose a subscription.
Disposable context.CancelFunc
// NextFunc handles a next item in a stream.
NextFunc func(interface{})
// ErrFunc handles an error in a stream.
ErrFunc func(error)
// CompletedFunc handles the end of a stream.
CompletedFunc func()
)
// BackpressureStrategy is the backpressure strategy type.
type BackpressureStrategy uint32
const (
// Block blocks until the channel is available.
Block BackpressureStrategy = iota
// Drop drops the message.
Drop
)
// OnErrorStrategy is the Observable error strategy.
type OnErrorStrategy uint32
const (
// StopOnError is the default error strategy.
// An operator will stop processing items on error.
StopOnError OnErrorStrategy = iota
// ContinueOnError means an operator will continue processing items after an error.
ContinueOnError
)
// ObservationStrategy defines the strategy to consume from an Observable.
type ObservationStrategy uint32
const (
// Lazy is the default observation strategy, when an Observer subscribes.
Lazy ObservationStrategy = iota
// Eager means consuming as soon as the Observable is created.
Eager
)