Update dependencies
This commit is contained in:
28
vendor/tailscale.com/util/set/handle.go
generated
vendored
Normal file
28
vendor/tailscale.com/util/set/handle.go
generated
vendored
Normal file
@@ -0,0 +1,28 @@
|
||||
// Copyright (c) Tailscale Inc & AUTHORS
|
||||
// SPDX-License-Identifier: BSD-3-Clause
|
||||
|
||||
package set
|
||||
|
||||
// HandleSet is a set of T.
|
||||
//
|
||||
// It is not safe for concurrent use.
|
||||
type HandleSet[T any] map[Handle]T
|
||||
|
||||
// Handle is an opaque comparable value that's used as the map key in a
|
||||
// HandleSet. The only way to get one is to call HandleSet.Add.
|
||||
type Handle struct {
|
||||
v *byte
|
||||
}
|
||||
|
||||
// Add adds the element (map value) e to the set.
|
||||
//
|
||||
// It returns the handle (map key) with which e can be removed, using a map
|
||||
// delete.
|
||||
func (s *HandleSet[T]) Add(e T) Handle {
|
||||
h := Handle{new(byte)}
|
||||
if *s == nil {
|
||||
*s = make(HandleSet[T])
|
||||
}
|
||||
(*s)[h] = e
|
||||
return h
|
||||
}
|
||||
94
vendor/tailscale.com/util/set/set.go
generated
vendored
Normal file
94
vendor/tailscale.com/util/set/set.go
generated
vendored
Normal file
@@ -0,0 +1,94 @@
|
||||
// Copyright (c) Tailscale Inc & AUTHORS
|
||||
// SPDX-License-Identifier: BSD-3-Clause
|
||||
|
||||
// Package set contains set types.
|
||||
package set
|
||||
|
||||
import (
|
||||
"encoding/json"
|
||||
"maps"
|
||||
)
|
||||
|
||||
// Set is a set of T.
|
||||
type Set[T comparable] map[T]struct{}
|
||||
|
||||
// SetOf returns a new set constructed from the elements in slice.
|
||||
func SetOf[T comparable](slice []T) Set[T] {
|
||||
return Of(slice...)
|
||||
}
|
||||
|
||||
// Of returns a new set constructed from the elements in slice.
|
||||
func Of[T comparable](slice ...T) Set[T] {
|
||||
s := make(Set[T])
|
||||
s.AddSlice(slice)
|
||||
return s
|
||||
}
|
||||
|
||||
// Clone returns a new set cloned from the elements in s.
|
||||
func (s Set[T]) Clone() Set[T] {
|
||||
return maps.Clone(s)
|
||||
}
|
||||
|
||||
// Add adds e to s.
|
||||
func (s Set[T]) Add(e T) { s[e] = struct{}{} }
|
||||
|
||||
// AddSlice adds each element of es to s.
|
||||
func (s Set[T]) AddSlice(es []T) {
|
||||
for _, e := range es {
|
||||
s.Add(e)
|
||||
}
|
||||
}
|
||||
|
||||
// AddSet adds each element of es to s.
|
||||
func (s Set[T]) AddSet(es Set[T]) {
|
||||
for e := range es {
|
||||
s.Add(e)
|
||||
}
|
||||
}
|
||||
|
||||
// Make lazily initializes the map pointed to by s to be non-nil.
|
||||
func (s *Set[T]) Make() {
|
||||
if *s == nil {
|
||||
*s = make(Set[T])
|
||||
}
|
||||
}
|
||||
|
||||
// Slice returns the elements of the set as a slice. The elements will not be
|
||||
// in any particular order.
|
||||
func (s Set[T]) Slice() []T {
|
||||
es := make([]T, 0, s.Len())
|
||||
for k := range s {
|
||||
es = append(es, k)
|
||||
}
|
||||
return es
|
||||
}
|
||||
|
||||
// Delete removes e from the set.
|
||||
func (s Set[T]) Delete(e T) { delete(s, e) }
|
||||
|
||||
// Contains reports whether s contains e.
|
||||
func (s Set[T]) Contains(e T) bool {
|
||||
_, ok := s[e]
|
||||
return ok
|
||||
}
|
||||
|
||||
// Len reports the number of items in s.
|
||||
func (s Set[T]) Len() int { return len(s) }
|
||||
|
||||
// Equal reports whether s is equal to other.
|
||||
func (s Set[T]) Equal(other Set[T]) bool {
|
||||
return maps.Equal(s, other)
|
||||
}
|
||||
|
||||
func (s Set[T]) MarshalJSON() ([]byte, error) {
|
||||
return json.Marshal(s.Slice())
|
||||
}
|
||||
|
||||
func (s *Set[T]) UnmarshalJSON(buf []byte) error {
|
||||
var ss []T
|
||||
if err := json.Unmarshal(buf, &ss); err != nil {
|
||||
return err
|
||||
}
|
||||
*s = SetOf(ss)
|
||||
return nil
|
||||
}
|
||||
73
vendor/tailscale.com/util/set/slice.go
generated
vendored
Normal file
73
vendor/tailscale.com/util/set/slice.go
generated
vendored
Normal file
@@ -0,0 +1,73 @@
|
||||
// Copyright (c) Tailscale Inc & AUTHORS
|
||||
// SPDX-License-Identifier: BSD-3-Clause
|
||||
|
||||
package set
|
||||
|
||||
import (
|
||||
"slices"
|
||||
|
||||
"tailscale.com/types/views"
|
||||
)
|
||||
|
||||
// Slice is a set of elements tracked in a slice of unique elements.
|
||||
type Slice[T comparable] struct {
|
||||
slice []T
|
||||
set map[T]bool // nil until/unless slice is large enough
|
||||
}
|
||||
|
||||
// Slice returns a view of the underlying slice.
|
||||
// The elements are in order of insertion.
|
||||
// The returned value is only valid until ss is modified again.
|
||||
func (ss *Slice[T]) Slice() views.Slice[T] { return views.SliceOf(ss.slice) }
|
||||
|
||||
// Len returns the number of elements in the set.
|
||||
func (ss *Slice[T]) Len() int { return len(ss.slice) }
|
||||
|
||||
// Contains reports whether v is in the set.
|
||||
// The amortized cost is O(1).
|
||||
func (ss *Slice[T]) Contains(v T) bool {
|
||||
if ss.set != nil {
|
||||
return ss.set[v]
|
||||
}
|
||||
return slices.Index(ss.slice, v) != -1
|
||||
}
|
||||
|
||||
// Remove removes v from the set.
|
||||
// The cost is O(n).
|
||||
func (ss *Slice[T]) Remove(v T) {
|
||||
if ss.set != nil {
|
||||
if !ss.set[v] {
|
||||
return
|
||||
}
|
||||
delete(ss.set, v)
|
||||
}
|
||||
if ix := slices.Index(ss.slice, v); ix != -1 {
|
||||
ss.slice = append(ss.slice[:ix], ss.slice[ix+1:]...)
|
||||
}
|
||||
}
|
||||
|
||||
// Add adds each element in vs to the set.
|
||||
// The amortized cost is O(1) per element.
|
||||
func (ss *Slice[T]) Add(vs ...T) {
|
||||
for _, v := range vs {
|
||||
if ss.Contains(v) {
|
||||
continue
|
||||
}
|
||||
ss.slice = append(ss.slice, v)
|
||||
if ss.set != nil {
|
||||
ss.set[v] = true
|
||||
} else if len(ss.slice) > 8 {
|
||||
ss.set = make(map[T]bool, len(ss.slice))
|
||||
for _, v := range ss.slice {
|
||||
ss.set[v] = true
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
// AddSlice adds all elements in vs to the set.
|
||||
func (ss *Slice[T]) AddSlice(vs views.Slice[T]) {
|
||||
for i := range vs.Len() {
|
||||
ss.Add(vs.At(i))
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user