mirror of https://github.com/tailscale/tailscale/
util/cmpx: delete now that we're using Go 1.22
Updates #11058 Change-Id: I09dea8e86f03ec148b715efca339eab8b1f0f644 Signed-off-by: Brad Fitzpatrick <bradfitz@tailscale.com>pull/11066/head
parent
5ea071186e
commit
2bd3c1474b
@ -1,22 +0,0 @@
|
|||||||
// 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
|
|
||||||
}
|
|
@ -1,24 +0,0 @@
|
|||||||
// 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