diff options
author | OpenShift Merge Robot <openshift-merge-robot@users.noreply.github.com> | 2021-04-12 12:19:22 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-04-12 12:19:22 +0200 |
commit | 0ee1da50f5e221383c236ccee258cb7592ccabd6 (patch) | |
tree | 08b3798ab08a621920eff4d1f6a3a5f940d3a944 /vendor/github.com/google/go-cmp/cmp/export_unsafe.go | |
parent | 669311d8d8a8881571ccc81ce48b9202b15b9def (diff) | |
parent | 14375f35ee00c16327edcd0f5883cc66810fc7db (diff) | |
download | podman-0ee1da50f5e221383c236ccee258cb7592ccabd6.tar.gz podman-0ee1da50f5e221383c236ccee258cb7592ccabd6.tar.bz2 podman-0ee1da50f5e221383c236ccee258cb7592ccabd6.zip |
Merge pull request #9981 from containers/dependabot/go_modules/k8s.io/api-0.21.0
Bump k8s.io/api from 0.20.5 to 0.21.0
Diffstat (limited to 'vendor/github.com/google/go-cmp/cmp/export_unsafe.go')
-rw-r--r-- | vendor/github.com/google/go-cmp/cmp/export_unsafe.go | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/vendor/github.com/google/go-cmp/cmp/export_unsafe.go b/vendor/github.com/google/go-cmp/cmp/export_unsafe.go new file mode 100644 index 000000000..21eb54858 --- /dev/null +++ b/vendor/github.com/google/go-cmp/cmp/export_unsafe.go @@ -0,0 +1,35 @@ +// Copyright 2017, 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. + +// +build !purego + +package cmp + +import ( + "reflect" + "unsafe" +) + +const supportExporters = true + +// retrieveUnexportedField uses unsafe to forcibly retrieve any field from +// a struct such that the value has read-write permissions. +// +// The parent struct, v, must be addressable, while f must be a StructField +// describing the field to retrieve. If addr is false, +// then the returned value will be shallowed copied to be non-addressable. +func retrieveUnexportedField(v reflect.Value, f reflect.StructField, addr bool) reflect.Value { + ve := reflect.NewAt(f.Type, unsafe.Pointer(uintptr(unsafe.Pointer(v.UnsafeAddr()))+f.Offset)).Elem() + if !addr { + // A field is addressable if and only if the struct is addressable. + // If the original parent value was not addressable, shallow copy the + // value to make it non-addressable to avoid leaking an implementation + // detail of how forcibly exporting a field works. + if ve.Kind() == reflect.Interface && ve.IsNil() { + return reflect.Zero(f.Type) + } + return reflect.ValueOf(ve.Interface()).Convert(f.Type) + } + return ve +} |