2020-03-24 07:41:10 +02:00
|
|
|
// 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.
|
|
|
|
|
2019-07-12 00:28:38 +02:00
|
|
|
package key
|
|
|
|
|
|
|
|
import (
|
2020-04-25 01:40:49 +02:00
|
|
|
"fmt"
|
2020-04-30 22:06:00 +02:00
|
|
|
"reflect"
|
2020-04-25 01:40:49 +02:00
|
|
|
|
2019-11-01 20:40:29 +02:00
|
|
|
"go.opentelemetry.io/otel/api/core"
|
2019-07-12 00:28:38 +02:00
|
|
|
)
|
|
|
|
|
2019-10-31 23:55:51 +02:00
|
|
|
// New creates a new key with a passed name.
|
2019-09-19 20:20:02 +02:00
|
|
|
func New(name string) core.Key {
|
2019-10-17 07:49:58 +02:00
|
|
|
return core.Key(name)
|
|
|
|
}
|
|
|
|
|
2019-10-31 23:55:51 +02:00
|
|
|
// Bool creates a new key-value pair with a passed name and a bool
|
|
|
|
// value.
|
2019-10-17 07:49:58 +02:00
|
|
|
func Bool(k string, v bool) core.KeyValue {
|
|
|
|
return New(k).Bool(v)
|
|
|
|
}
|
|
|
|
|
2019-10-31 23:55:51 +02:00
|
|
|
// Int64 creates a new key-value pair with a passed name and an int64
|
|
|
|
// value.
|
2019-10-17 07:49:58 +02:00
|
|
|
func Int64(k string, v int64) core.KeyValue {
|
|
|
|
return New(k).Int64(v)
|
|
|
|
}
|
|
|
|
|
2019-10-31 23:55:51 +02:00
|
|
|
// Uint64 creates a new key-value pair with a passed name and a uint64
|
|
|
|
// value.
|
2019-10-17 07:49:58 +02:00
|
|
|
func Uint64(k string, v uint64) core.KeyValue {
|
|
|
|
return New(k).Uint64(v)
|
|
|
|
}
|
|
|
|
|
2019-10-31 23:55:51 +02:00
|
|
|
// Float64 creates a new key-value pair with a passed name and a float64
|
|
|
|
// value.
|
2019-10-17 07:49:58 +02:00
|
|
|
func Float64(k string, v float64) core.KeyValue {
|
|
|
|
return New(k).Float64(v)
|
|
|
|
}
|
|
|
|
|
2019-10-31 23:55:51 +02:00
|
|
|
// Int32 creates a new key-value pair with a passed name and an int32
|
|
|
|
// value.
|
2019-10-17 07:49:58 +02:00
|
|
|
func Int32(k string, v int32) core.KeyValue {
|
|
|
|
return New(k).Int32(v)
|
|
|
|
}
|
|
|
|
|
2019-10-31 23:55:51 +02:00
|
|
|
// Uint32 creates a new key-value pair with a passed name and a uint32
|
|
|
|
// value.
|
2019-10-17 07:49:58 +02:00
|
|
|
func Uint32(k string, v uint32) core.KeyValue {
|
|
|
|
return New(k).Uint32(v)
|
|
|
|
}
|
|
|
|
|
2019-10-31 23:55:51 +02:00
|
|
|
// Float32 creates a new key-value pair with a passed name and a float32
|
|
|
|
// value.
|
2019-10-17 07:49:58 +02:00
|
|
|
func Float32(k string, v float32) core.KeyValue {
|
|
|
|
return New(k).Float32(v)
|
|
|
|
}
|
|
|
|
|
2019-10-31 23:55:51 +02:00
|
|
|
// String creates a new key-value pair with a passed name and a string
|
|
|
|
// value.
|
2019-10-17 07:49:58 +02:00
|
|
|
func String(k, v string) core.KeyValue {
|
|
|
|
return New(k).String(v)
|
|
|
|
}
|
|
|
|
|
2020-04-25 01:40:49 +02:00
|
|
|
// Stringer creates a new key-value pair with a passed name and a string
|
|
|
|
// value generated by the passed Stringer interface.
|
|
|
|
func Stringer(k string, v fmt.Stringer) core.KeyValue {
|
|
|
|
return New(k).String(v.String())
|
|
|
|
}
|
|
|
|
|
2019-10-31 23:55:51 +02:00
|
|
|
// Int creates a new key-value pair instance with a passed name and
|
|
|
|
// either an int32 or an int64 value, depending on whether the int
|
|
|
|
// type is 32 or 64 bits wide.
|
2019-10-17 07:49:58 +02:00
|
|
|
func Int(k string, v int) core.KeyValue {
|
|
|
|
return New(k).Int(v)
|
|
|
|
}
|
|
|
|
|
2019-10-31 23:55:51 +02:00
|
|
|
// Uint creates a new key-value pair instance with a passed name and
|
|
|
|
// either an uint32 or an uint64 value, depending on whether the uint
|
|
|
|
// type is 32 or 64 bits wide.
|
2019-10-17 07:49:58 +02:00
|
|
|
func Uint(k string, v uint) core.KeyValue {
|
|
|
|
return New(k).Uint(v)
|
2019-07-12 00:28:38 +02:00
|
|
|
}
|
2020-04-25 01:40:49 +02:00
|
|
|
|
|
|
|
// Infer creates a new key-value pair instance with a passed name and
|
|
|
|
// automatic type inference. This is slower, and not type-safe.
|
|
|
|
func Infer(k string, value interface{}) core.KeyValue {
|
2020-04-30 22:06:00 +02:00
|
|
|
if value == nil {
|
|
|
|
return String(k, "<nil>")
|
2020-04-25 01:40:49 +02:00
|
|
|
}
|
2020-04-30 22:06:00 +02:00
|
|
|
|
|
|
|
if stringer, ok := value.(fmt.Stringer); ok {
|
|
|
|
return String(k, stringer.String())
|
|
|
|
}
|
|
|
|
|
|
|
|
rv := reflect.ValueOf(value)
|
|
|
|
|
|
|
|
switch rv.Kind() {
|
|
|
|
case reflect.Bool:
|
|
|
|
return Bool(k, rv.Bool())
|
|
|
|
case reflect.Int, reflect.Int8, reflect.Int16:
|
|
|
|
return Int(k, int(rv.Int()))
|
|
|
|
case reflect.Int32:
|
|
|
|
return Int32(k, int32(rv.Int()))
|
|
|
|
case reflect.Int64:
|
|
|
|
return Int64(k, int64(rv.Int()))
|
|
|
|
case reflect.Uint, reflect.Uint8, reflect.Uint16:
|
|
|
|
return Uint(k, uint(rv.Uint()))
|
|
|
|
case reflect.Uint32:
|
|
|
|
return Uint32(k, uint32(rv.Uint()))
|
|
|
|
case reflect.Uint64, reflect.Uintptr:
|
|
|
|
return Uint64(k, rv.Uint())
|
|
|
|
case reflect.Float32:
|
|
|
|
return Float32(k, float32(rv.Float()))
|
|
|
|
case reflect.Float64:
|
|
|
|
return Float64(k, rv.Float())
|
|
|
|
case reflect.String:
|
|
|
|
return String(k, rv.Interface().(string))
|
|
|
|
}
|
|
|
|
return String(k, fmt.Sprint(rv.Interface()))
|
2020-04-25 01:40:49 +02:00
|
|
|
}
|