mirror of
https://github.com/protocolbuffers/protobuf-go.git
synced 2025-01-17 01:12:51 +00:00
d55639e713
Package set provides simple set data structures for uint64 and string types. High-level API: type Set(T {}) xxx func (Set) Len() int func (Set) Has(T) bool func (Set) Set(T) func (Set) Clear(T) These data structures are useful for implementing required fields efficiently or ensuring that protobuf identifiers do not conflict. Change-Id: If846630a9034909a43121b3e0f6720275f4b7aaf Reviewed-on: https://go-review.googlesource.com/128898 Reviewed-by: Chris Manghane <cmang@golang.org>
74 lines
1.5 KiB
Go
74 lines
1.5 KiB
Go
// Copyright 2018 The Go Authors. All rights reserved.
|
|
// Use of this source code is governed by a BSD-style
|
|
// license that can be found in the LICENSE file.
|
|
|
|
package set
|
|
|
|
import "math/bits"
|
|
|
|
// Int32s represents a set of integers within the range of 0..31.
|
|
type Int32s uint32
|
|
|
|
func (bs *Int32s) Len() int {
|
|
return bits.OnesCount32(uint32(*bs))
|
|
}
|
|
func (bs *Int32s) Has(n uint64) bool {
|
|
return uint32(*bs)&(uint32(1)<<n) > 0
|
|
}
|
|
func (bs *Int32s) Set(n uint64) {
|
|
*(*uint32)(bs) |= uint32(1) << n
|
|
}
|
|
func (bs *Int32s) Clear(n uint64) {
|
|
*(*uint32)(bs) &^= uint32(1) << n
|
|
}
|
|
|
|
// Int64s represents a set of integers within the range of 0..63.
|
|
type Int64s uint64
|
|
|
|
func (bs *Int64s) Len() int {
|
|
return bits.OnesCount64(uint64(*bs))
|
|
}
|
|
func (bs *Int64s) Has(n uint64) bool {
|
|
return uint64(*bs)&(uint64(1)<<n) > 0
|
|
}
|
|
func (bs *Int64s) Set(n uint64) {
|
|
*(*uint64)(bs) |= uint64(1) << n
|
|
}
|
|
func (bs *Int64s) Clear(n uint64) {
|
|
*(*uint64)(bs) &^= uint64(1) << n
|
|
}
|
|
|
|
// Ints represents a set of integers within the range of 0..math.MaxUint64.
|
|
type Ints struct {
|
|
lo Int64s
|
|
hi map[uint64]struct{}
|
|
}
|
|
|
|
func (bs *Ints) Len() int {
|
|
return bs.lo.Len() + len(bs.hi)
|
|
}
|
|
func (bs *Ints) Has(n uint64) bool {
|
|
if n < 64 {
|
|
return bs.lo.Has(n)
|
|
}
|
|
_, ok := bs.hi[n]
|
|
return ok
|
|
}
|
|
func (bs *Ints) Set(n uint64) {
|
|
if n < 64 {
|
|
bs.lo.Set(n)
|
|
return
|
|
}
|
|
if bs.hi == nil {
|
|
bs.hi = make(map[uint64]struct{})
|
|
}
|
|
bs.hi[n] = struct{}{}
|
|
}
|
|
func (bs *Ints) Clear(n uint64) {
|
|
if n < 64 {
|
|
bs.lo.Clear(n)
|
|
return
|
|
}
|
|
delete(bs.hi, n)
|
|
}
|