mirror of https://github.com/tailscale/tailscale/
util/cmpx: add package with cmp-like things from future Go releases
Updates #8296 Signed-off-by: Brad Fitzpatrick <bradfitz@tailscale.com>raggi/tsdebugger
parent
1c4a047ad0
commit
12f8c98823
@ -0,0 +1,22 @@
|
||||
// Copyright (c) Tailscale Inc & AUTHORS
|
||||
// SPDX-License-Identifier: BSD-3-Clause
|
||||
|
||||
// Package cmpx has code that will likely land in a future version of Go, but
|
||||
// we want sooner.
|
||||
package cmpx
|
||||
|
||||
// Or returns the first non-zero element of list, or else returns the zero T.
|
||||
//
|
||||
// This is the proposal from
|
||||
// https://github.com/golang/go/issues/60204#issuecomment-1581245334.
|
||||
func Or[T comparable](list ...T) T {
|
||||
// TODO(bradfitz): remove the comparable constraint so we can use this
|
||||
// with funcs too and use reflect to see whether they're non-zero? 🤷♂️
|
||||
var zero T
|
||||
for _, v := range list {
|
||||
if v != zero {
|
||||
return v
|
||||
}
|
||||
}
|
||||
return zero
|
||||
}
|
@ -0,0 +1,24 @@
|
||||
// Copyright (c) Tailscale Inc & AUTHORS
|
||||
// SPDX-License-Identifier: BSD-3-Clause
|
||||
|
||||
package cmpx
|
||||
|
||||
import "testing"
|
||||
|
||||
func TestOr(t *testing.T) {
|
||||
if g, w := Or[string](), ""; g != w {
|
||||
t.Errorf("got %v; want %v", g, w)
|
||||
}
|
||||
if g, w := Or[int](), 0; g != w {
|
||||
t.Errorf("got %v; want %v", g, w)
|
||||
}
|
||||
if g, w := Or("", "foo", "bar"), "foo"; g != w {
|
||||
t.Errorf("got %v; want %v", g, w)
|
||||
}
|
||||
if g, w := Or("foo", "bar"), "foo"; g != w {
|
||||
t.Errorf("got %v; want %v", g, w)
|
||||
}
|
||||
if g, w := Or("", "", "bar"), "bar"; g != w {
|
||||
t.Errorf("got %v; want %v", g, w)
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue