// Copyright 2020 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. package metrics import ( "math" "unsafe" ) // ValueKind is a tag for a metric [Value] which indicates its type. type ValueKind int const ( // KindBad indicates that the Value has no type and should not be used. KindBad ValueKind = iota // KindUint64 indicates that the type of the Value is a uint64. KindUint64 // KindFloat64 indicates that the type of the Value is a float64. KindFloat64 // KindFloat64Histogram indicates that the type of the Value is a *Float64Histogram. KindFloat64Histogram ) // Value represents a metric value returned by the runtime. type Value struct { kind ValueKind scalar uint64 // contains scalar values for scalar Kinds. pointer unsafe.Pointer // contains non-scalar values. } // Kind returns the tag representing the kind of value this is. func (v Value) Kind() ValueKind { return v.kind } // Uint64 returns the internal uint64 value for the metric. // // If v.Kind() != KindUint64, this method panics. func (v Value) Uint64() uint64 { if v.kind != KindUint64 { panic("called Uint64 on non-uint64 metric value") } return v.scalar } // Float64 returns the internal float64 value for the metric. // // If v.Kind() != KindFloat64, this method panics. func (v Value) Float64() float64 { if v.kind != KindFloat64 { panic("called Float64 on non-float64 metric value") } return math.Float64frombits(v.scalar) } // Float64Histogram returns the internal *Float64Histogram value for the metric. // // If v.Kind() != KindFloat64Histogram, this method panics. func (v Value) Float64Histogram() *Float64Histogram { if v.kind != KindFloat64Histogram { panic("called Float64Histogram on non-Float64Histogram metric value") } return (*Float64Histogram)(v.pointer) }