审查视图

vendor/go.opentelemetry.io/otel/label/key.go 5.1 KB
tangxvhui authored
1 2 3 4 5 6 7 8 9 10 11 12 13 14
// Copyright The OpenTelemetry 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.
唐旭辉 authored
15
package label // import "go.opentelemetry.io/otel/label"
tangxvhui authored
16 17 18 19 20 21 22 23

// Key represents the key part in key-value pairs. It's a string. The
// allowed character set in the key depends on the use of the key.
type Key string

// Bool creates a KeyValue instance with a BOOL Value.
//
// If creating both key and a bool value at the same time, then
唐旭辉 authored
24
// instead of calling Key(name).Bool(value) consider using a
tangxvhui authored
25 26 27 28 29
// convenience function provided by the api/key package -
// key.Bool(name, value).
func (k Key) Bool(v bool) KeyValue {
	return KeyValue{
		Key:   k,
唐旭辉 authored
30
		Value: BoolValue(v),
tangxvhui authored
31 32 33 34 35 36
	}
}

// Int64 creates a KeyValue instance with an INT64 Value.
//
// If creating both key and an int64 value at the same time, then
唐旭辉 authored
37
// instead of calling Key(name).Int64(value) consider using a
tangxvhui authored
38 39 40 41 42
// convenience function provided by the api/key package -
// key.Int64(name, value).
func (k Key) Int64(v int64) KeyValue {
	return KeyValue{
		Key:   k,
唐旭辉 authored
43
		Value: Int64Value(v),
tangxvhui authored
44 45 46 47 48 49
	}
}

// Uint64 creates a KeyValue instance with a UINT64 Value.
//
// If creating both key and a uint64 value at the same time, then
唐旭辉 authored
50
// instead of calling Key(name).Uint64(value) consider using a
tangxvhui authored
51 52 53 54 55
// convenience function provided by the api/key package -
// key.Uint64(name, value).
func (k Key) Uint64(v uint64) KeyValue {
	return KeyValue{
		Key:   k,
唐旭辉 authored
56
		Value: Uint64Value(v),
tangxvhui authored
57 58 59 60 61 62
	}
}

// Float64 creates a KeyValue instance with a FLOAT64 Value.
//
// If creating both key and a float64 value at the same time, then
唐旭辉 authored
63
// instead of calling Key(name).Float64(value) consider using a
tangxvhui authored
64 65 66 67 68
// convenience function provided by the api/key package -
// key.Float64(name, value).
func (k Key) Float64(v float64) KeyValue {
	return KeyValue{
		Key:   k,
唐旭辉 authored
69
		Value: Float64Value(v),
tangxvhui authored
70 71 72 73 74 75
	}
}

// Int32 creates a KeyValue instance with an INT32 Value.
//
// If creating both key and an int32 value at the same time, then
唐旭辉 authored
76
// instead of calling Key(name).Int32(value) consider using a
tangxvhui authored
77 78 79 80 81
// convenience function provided by the api/key package -
// key.Int32(name, value).
func (k Key) Int32(v int32) KeyValue {
	return KeyValue{
		Key:   k,
唐旭辉 authored
82
		Value: Int32Value(v),
tangxvhui authored
83 84 85 86 87 88
	}
}

// Uint32 creates a KeyValue instance with a UINT32 Value.
//
// If creating both key and a uint32 value at the same time, then
唐旭辉 authored
89
// instead of calling Key(name).Uint32(value) consider using a
tangxvhui authored
90 91 92 93 94
// convenience function provided by the api/key package -
// key.Uint32(name, value).
func (k Key) Uint32(v uint32) KeyValue {
	return KeyValue{
		Key:   k,
唐旭辉 authored
95
		Value: Uint32Value(v),
tangxvhui authored
96 97 98 99 100 101
	}
}

// Float32 creates a KeyValue instance with a FLOAT32 Value.
//
// If creating both key and a float32 value at the same time, then
唐旭辉 authored
102
// instead of calling Key(name).Float32(value) consider using a
tangxvhui authored
103 104 105 106 107
// convenience function provided by the api/key package -
// key.Float32(name, value).
func (k Key) Float32(v float32) KeyValue {
	return KeyValue{
		Key:   k,
唐旭辉 authored
108
		Value: Float32Value(v),
tangxvhui authored
109 110 111 112 113 114
	}
}

// String creates a KeyValue instance with a STRING Value.
//
// If creating both key and a string value at the same time, then
唐旭辉 authored
115
// instead of calling Key(name).String(value) consider using a
tangxvhui authored
116 117 118 119 120
// convenience function provided by the api/key package -
// key.String(name, value).
func (k Key) String(v string) KeyValue {
	return KeyValue{
		Key:   k,
唐旭辉 authored
121
		Value: StringValue(v),
tangxvhui authored
122 123 124 125 126 127 128
	}
}

// Int creates a KeyValue instance with either an INT32 or an INT64
// Value, depending on whether the int type is 32 or 64 bits wide.
//
// If creating both key and an int value at the same time, then
唐旭辉 authored
129
// instead of calling Key(name).Int(value) consider using a
tangxvhui authored
130 131 132 133 134
// convenience function provided by the api/key package -
// key.Int(name, value).
func (k Key) Int(v int) KeyValue {
	return KeyValue{
		Key:   k,
唐旭辉 authored
135
		Value: IntValue(v),
tangxvhui authored
136 137 138 139 140 141 142
	}
}

// Uint creates a KeyValue instance with either a UINT32 or a UINT64
// Value, depending on whether the uint type is 32 or 64 bits wide.
//
// If creating both key and a uint value at the same time, then
唐旭辉 authored
143
// instead of calling Key(name).Uint(value) consider using a
tangxvhui authored
144 145 146 147 148
// convenience function provided by the api/key package -
// key.Uint(name, value).
func (k Key) Uint(v uint) KeyValue {
	return KeyValue{
		Key:   k,
唐旭辉 authored
149
		Value: UintValue(v),
tangxvhui authored
150 151 152 153 154 155 156
	}
}

// Defined returns true for non-empty keys.
func (k Key) Defined() bool {
	return len(k) != 0
}
唐旭辉 authored
157 158 159 160 161 162 163 164 165 166 167 168 169

// Array creates a KeyValue instance with a ARRAY Value.
//
// If creating both key and a array value at the same time, then
// instead of calling Key(name).String(value) consider using a
// convenience function provided by the api/key package -
// key.Array(name, value).
func (k Key) Array(v interface{}) KeyValue {
	return KeyValue{
		Key:   k,
		Value: ArrayValue(v),
	}
}