2019-01-12 04:58:27 +00:00
|
|
|
/*
|
|
|
|
Copyright 2018 The Kubernetes Authors.
|
|
|
|
|
|
|
|
Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
you may not use this file except in compliance with the License.
|
|
|
|
You may obtain a copy of the License at
|
|
|
|
|
|
|
|
http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
|
|
|
|
Unless required by applicable law or agreed to in writing, software
|
|
|
|
distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
See the License for the specific language governing permissions and
|
|
|
|
limitations under the License.
|
|
|
|
*/
|
|
|
|
|
|
|
|
package pointer
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
|
|
|
"reflect"
|
|
|
|
)
|
|
|
|
|
|
|
|
// AllPtrFieldsNil tests whether all pointer fields in a struct are nil. This is useful when,
|
|
|
|
// for example, an API struct is handled by plugins which need to distinguish
|
|
|
|
// "no plugin accepted this spec" from "this spec is empty".
|
|
|
|
//
|
|
|
|
// This function is only valid for structs and pointers to structs. Any other
|
|
|
|
// type will cause a panic. Passing a typed nil pointer will return true.
|
|
|
|
func AllPtrFieldsNil(obj interface{}) bool {
|
|
|
|
v := reflect.ValueOf(obj)
|
|
|
|
if !v.IsValid() {
|
|
|
|
panic(fmt.Sprintf("reflect.ValueOf() produced a non-valid Value for %#v", obj))
|
|
|
|
}
|
|
|
|
if v.Kind() == reflect.Ptr {
|
|
|
|
if v.IsNil() {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
v = v.Elem()
|
|
|
|
}
|
|
|
|
for i := 0; i < v.NumField(); i++ {
|
|
|
|
if v.Field(i).Kind() == reflect.Ptr && !v.Field(i).IsNil() {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
|
2021-09-16 19:59:58 +00:00
|
|
|
// Int returns a pointer to an int
|
|
|
|
func Int(i int) *int {
|
|
|
|
return &i
|
|
|
|
}
|
|
|
|
|
|
|
|
var IntPtr = Int // for back-compat
|
|
|
|
|
|
|
|
// IntDeref dereferences the int ptr and returns it if not nil, or else
|
|
|
|
// returns def.
|
|
|
|
func IntDeref(ptr *int, def int) int {
|
|
|
|
if ptr != nil {
|
|
|
|
return *ptr
|
|
|
|
}
|
|
|
|
return def
|
|
|
|
}
|
|
|
|
|
|
|
|
var IntPtrDerefOr = IntDeref // for back-compat
|
|
|
|
|
2021-07-02 08:43:15 +00:00
|
|
|
// Int32 returns a pointer to an int32.
|
|
|
|
func Int32(i int32) *int32 {
|
2019-01-12 04:58:27 +00:00
|
|
|
return &i
|
|
|
|
}
|
|
|
|
|
2021-07-02 08:43:15 +00:00
|
|
|
var Int32Ptr = Int32 // for back-compat
|
|
|
|
|
|
|
|
// Int32Deref dereferences the int32 ptr and returns it if not nil, or else
|
|
|
|
// returns def.
|
|
|
|
func Int32Deref(ptr *int32, def int32) int32 {
|
2020-12-01 01:06:26 +00:00
|
|
|
if ptr != nil {
|
|
|
|
return *ptr
|
|
|
|
}
|
|
|
|
return def
|
|
|
|
}
|
|
|
|
|
2021-07-02 08:43:15 +00:00
|
|
|
var Int32PtrDerefOr = Int32Deref // for back-compat
|
|
|
|
|
|
|
|
// Int32Equal returns true if both arguments are nil or both arguments
|
|
|
|
// dereference to the same value.
|
|
|
|
func Int32Equal(a, b *int32) bool {
|
|
|
|
if (a == nil) != (b == nil) {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
if a == nil {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
return *a == *b
|
|
|
|
}
|
|
|
|
|
|
|
|
// Int64 returns a pointer to an int64.
|
|
|
|
func Int64(i int64) *int64 {
|
2019-01-12 04:58:27 +00:00
|
|
|
return &i
|
|
|
|
}
|
|
|
|
|
2021-07-02 08:43:15 +00:00
|
|
|
var Int64Ptr = Int64 // for back-compat
|
|
|
|
|
|
|
|
// Int64Deref dereferences the int64 ptr and returns it if not nil, or else
|
|
|
|
// returns def.
|
|
|
|
func Int64Deref(ptr *int64, def int64) int64 {
|
2019-01-12 04:58:27 +00:00
|
|
|
if ptr != nil {
|
|
|
|
return *ptr
|
|
|
|
}
|
|
|
|
return def
|
|
|
|
}
|
|
|
|
|
2021-07-02 08:43:15 +00:00
|
|
|
var Int64PtrDerefOr = Int64Deref // for back-compat
|
|
|
|
|
|
|
|
// Int64Equal returns true if both arguments are nil or both arguments
|
|
|
|
// dereference to the same value.
|
|
|
|
func Int64Equal(a, b *int64) bool {
|
|
|
|
if (a == nil) != (b == nil) {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
if a == nil {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
return *a == *b
|
|
|
|
}
|
|
|
|
|
|
|
|
// Bool returns a pointer to a bool.
|
|
|
|
func Bool(b bool) *bool {
|
2019-01-12 04:58:27 +00:00
|
|
|
return &b
|
|
|
|
}
|
|
|
|
|
2021-07-02 08:43:15 +00:00
|
|
|
var BoolPtr = Bool // for back-compat
|
|
|
|
|
|
|
|
// BoolDeref dereferences the bool ptr and returns it if not nil, or else
|
|
|
|
// returns def.
|
|
|
|
func BoolDeref(ptr *bool, def bool) bool {
|
2020-12-01 01:06:26 +00:00
|
|
|
if ptr != nil {
|
|
|
|
return *ptr
|
|
|
|
}
|
|
|
|
return def
|
|
|
|
}
|
|
|
|
|
2021-07-02 08:43:15 +00:00
|
|
|
var BoolPtrDerefOr = BoolDeref // for back-compat
|
|
|
|
|
|
|
|
// BoolEqual returns true if both arguments are nil or both arguments
|
|
|
|
// dereference to the same value.
|
|
|
|
func BoolEqual(a, b *bool) bool {
|
|
|
|
if (a == nil) != (b == nil) {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
if a == nil {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
return *a == *b
|
|
|
|
}
|
|
|
|
|
|
|
|
// String returns a pointer to a string.
|
|
|
|
func String(s string) *string {
|
2019-01-12 04:58:27 +00:00
|
|
|
return &s
|
|
|
|
}
|
2019-04-07 17:07:55 +00:00
|
|
|
|
2021-07-02 08:43:15 +00:00
|
|
|
var StringPtr = String // for back-compat
|
|
|
|
|
|
|
|
// StringDeref dereferences the string ptr and returns it if not nil, or else
|
|
|
|
// returns def.
|
|
|
|
func StringDeref(ptr *string, def string) string {
|
2020-12-01 01:06:26 +00:00
|
|
|
if ptr != nil {
|
|
|
|
return *ptr
|
|
|
|
}
|
|
|
|
return def
|
|
|
|
}
|
|
|
|
|
2021-07-02 08:43:15 +00:00
|
|
|
var StringPtrDerefOr = StringDeref // for back-compat
|
|
|
|
|
|
|
|
// StringEqual returns true if both arguments are nil or both arguments
|
|
|
|
// dereference to the same value.
|
|
|
|
func StringEqual(a, b *string) bool {
|
|
|
|
if (a == nil) != (b == nil) {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
if a == nil {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
return *a == *b
|
|
|
|
}
|
|
|
|
|
|
|
|
// Float32 returns a pointer to the a float32.
|
|
|
|
func Float32(i float32) *float32 {
|
2019-04-07 17:07:55 +00:00
|
|
|
return &i
|
|
|
|
}
|
|
|
|
|
2021-07-02 08:43:15 +00:00
|
|
|
var Float32Ptr = Float32
|
|
|
|
|
|
|
|
// Float32Deref dereferences the float32 ptr and returns it if not nil, or else
|
|
|
|
// returns def.
|
|
|
|
func Float32Deref(ptr *float32, def float32) float32 {
|
2020-12-01 01:06:26 +00:00
|
|
|
if ptr != nil {
|
|
|
|
return *ptr
|
|
|
|
}
|
|
|
|
return def
|
|
|
|
}
|
|
|
|
|
2021-07-02 08:43:15 +00:00
|
|
|
var Float32PtrDerefOr = Float32Deref // for back-compat
|
|
|
|
|
|
|
|
// Float32Equal returns true if both arguments are nil or both arguments
|
|
|
|
// dereference to the same value.
|
|
|
|
func Float32Equal(a, b *float32) bool {
|
|
|
|
if (a == nil) != (b == nil) {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
if a == nil {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
return *a == *b
|
|
|
|
}
|
|
|
|
|
|
|
|
// Float64 returns a pointer to the a float64.
|
|
|
|
func Float64(i float64) *float64 {
|
2019-04-07 17:07:55 +00:00
|
|
|
return &i
|
|
|
|
}
|
2020-12-01 01:06:26 +00:00
|
|
|
|
2021-07-02 08:43:15 +00:00
|
|
|
var Float64Ptr = Float64
|
|
|
|
|
|
|
|
// Float64Deref dereferences the float64 ptr and returns it if not nil, or else
|
|
|
|
// returns def.
|
|
|
|
func Float64Deref(ptr *float64, def float64) float64 {
|
2020-12-01 01:06:26 +00:00
|
|
|
if ptr != nil {
|
|
|
|
return *ptr
|
|
|
|
}
|
|
|
|
return def
|
|
|
|
}
|
2021-07-02 08:43:15 +00:00
|
|
|
|
|
|
|
var Float64PtrDerefOr = Float64Deref // for back-compat
|
|
|
|
|
|
|
|
// Float64Equal returns true if both arguments are nil or both arguments
|
|
|
|
// dereference to the same value.
|
|
|
|
func Float64Equal(a, b *float64) bool {
|
|
|
|
if (a == nil) != (b == nil) {
|
|
|
|
return false
|
|
|
|
}
|
|
|
|
if a == nil {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
return *a == *b
|
|
|
|
}
|