Documentation ¶
Index ¶
- type ImmSet
- func (s ImmSet[T]) AsSlice() []T
- func (s ImmSet[T]) Delete(xs ...T) ImmSet[T]
- func (s ImmSet[T]) Difference(s2 ImmSet[T]) ImmSet[T]
- func (s ImmSet[T]) Equal(s2 ImmSet[T]) bool
- func (s ImmSet[T]) Has(x T) bool
- func (s ImmSet[T]) Insert(xs ...T) ImmSet[T]
- func (s ImmSet[T]) Len() int
- func (s *ImmSet[T]) MarshalJSON() ([]byte, error)
- func (s ImmSet[T]) Union(s2 ImmSet[T]) ImmSet[T]
- func (s *ImmSet[T]) UnmarshalJSON(data []byte) error
- type RingBuffer
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
This section is empty.
Types ¶
type ImmSet ¶ added in v1.16.0
type ImmSet[T any] struct { // contains filtered or unexported fields }
ImmSet is an immutable set optimized for a smallish (1-1000) set of items. Implemented as a sorted slice.
func NewImmSetFunc ¶ added in v1.16.0
func (ImmSet[T]) AsSlice ¶ added in v1.16.0
func (s ImmSet[T]) AsSlice() []T
AsSlice returns the underlying slice stored in the immutable set. The caller is NOT allowed to modify the slice.
func (ImmSet[T]) Difference ¶ added in v1.16.0
func (*ImmSet[T]) MarshalJSON ¶
func (*ImmSet[T]) UnmarshalJSON ¶
type RingBuffer ¶ added in v0.15.7
type RingBuffer struct {
// contains filtered or unexported fields
}
RingBuffer is a generic ring buffer implementation that contains sequential data (i.e. such as time ordered data). RingBuffer is implemented using slices. From testing, this should be fast than linked-list implementations, and also allows for efficient indexing of ordered data.
func NewRingBuffer ¶ added in v0.15.7
func NewRingBuffer(bufferSize int) *RingBuffer
NewRingBuffer constructs a new ring buffer for a given buffer size.
func (*RingBuffer) Add ¶ added in v0.15.7
func (eb *RingBuffer) Add(e interface{})
Add adds an element to the buffer.
func (*RingBuffer) Compact ¶ added in v0.15.7
func (eb *RingBuffer) Compact(isValid func(interface{}) bool)
Compact clears out invalidated elements in the buffer. This may require copying the entire buffer. It is assumed that if buffer[i] is invalid then every entry [0...i-1] is also not valid.
func (*RingBuffer) Iterate ¶ added in v0.15.7
func (eb *RingBuffer) Iterate(callback func(interface{}))
Iterate is a convenience function over IterateValid that iterates all elements in the buffer.
func (*RingBuffer) IterateValid ¶ added in v0.15.7
func (eb *RingBuffer) IterateValid(isValid func(interface{}) bool, callback func(interface{}))
IterateValid calls the callback on each element of the buffer, starting with the first element in the buffer that satisfies "isValid".
func (*RingBuffer) Size ¶ added in v0.15.7
func (eb *RingBuffer) Size() int
Size returns the size of the buffer.