// Copyright The OpenTelemetry Authors // SPDX-License-Identifier: Apache-2.0 // Code generated by "internal/cmd/pdatagen/main.go". DO NOT EDIT. // To regenerate this file run "make genpdata". package internal import ( "fmt" "sync" otlpmetrics "go.opentelemetry.io/collector/pdata/internal/data/protogen/metrics/v1" "go.opentelemetry.io/collector/pdata/internal/json" "go.opentelemetry.io/collector/pdata/internal/proto" ) var ( protoPoolHistogram = sync.Pool{ New: func() any { return &otlpmetrics.Histogram{} }, } ) func NewOrigHistogram() *otlpmetrics.Histogram { if !UseProtoPooling.IsEnabled() { return &otlpmetrics.Histogram{} } return protoPoolHistogram.Get().(*otlpmetrics.Histogram) } func DeleteOrigHistogram(orig *otlpmetrics.Histogram, nullable bool) { if orig == nil { return } if !UseProtoPooling.IsEnabled() { orig.Reset() return } for i := range orig.DataPoints { DeleteOrigHistogramDataPoint(orig.DataPoints[i], true) } orig.Reset() if nullable { protoPoolHistogram.Put(orig) } } func CopyOrigHistogram(dest, src *otlpmetrics.Histogram) { // If copying to same object, just return. if src == dest { return } dest.DataPoints = CopyOrigHistogramDataPointSlice(dest.DataPoints, src.DataPoints) dest.AggregationTemporality = src.AggregationTemporality } func GenTestOrigHistogram() *otlpmetrics.Histogram { orig := NewOrigHistogram() orig.DataPoints = GenerateOrigTestHistogramDataPointSlice() orig.AggregationTemporality = otlpmetrics.AggregationTemporality(1) return orig } // MarshalJSONOrig marshals all properties from the current struct to the destination stream. func MarshalJSONOrigHistogram(orig *otlpmetrics.Histogram, dest *json.Stream) { dest.WriteObjectStart() if len(orig.DataPoints) > 0 { dest.WriteObjectField("dataPoints") dest.WriteArrayStart() MarshalJSONOrigHistogramDataPoint(orig.DataPoints[0], dest) for i := 1; i < len(orig.DataPoints); i++ { dest.WriteMore() MarshalJSONOrigHistogramDataPoint(orig.DataPoints[i], dest) } dest.WriteArrayEnd() } if int32(orig.AggregationTemporality) != 0 { dest.WriteObjectField("aggregationTemporality") dest.WriteInt32(int32(orig.AggregationTemporality)) } dest.WriteObjectEnd() } // UnmarshalJSONOrigHistogram unmarshals all properties from the current struct from the source iterator. func UnmarshalJSONOrigHistogram(orig *otlpmetrics.Histogram, iter *json.Iterator) { for f := iter.ReadObject(); f != ""; f = iter.ReadObject() { switch f { case "dataPoints", "data_points": for iter.ReadArray() { orig.DataPoints = append(orig.DataPoints, NewOrigHistogramDataPoint()) UnmarshalJSONOrigHistogramDataPoint(orig.DataPoints[len(orig.DataPoints)-1], iter) } case "aggregationTemporality", "aggregation_temporality": orig.AggregationTemporality = otlpmetrics.AggregationTemporality(iter.ReadEnumValue(otlpmetrics.AggregationTemporality_value)) default: iter.Skip() } } } func SizeProtoOrigHistogram(orig *otlpmetrics.Histogram) int { var n int var l int _ = l for i := range orig.DataPoints { l = SizeProtoOrigHistogramDataPoint(orig.DataPoints[i]) n += 1 + proto.Sov(uint64(l)) + l } if orig.AggregationTemporality != 0 { n += 1 + proto.Sov(uint64(orig.AggregationTemporality)) } return n } func MarshalProtoOrigHistogram(orig *otlpmetrics.Histogram, buf []byte) int { pos := len(buf) var l int _ = l for i := len(orig.DataPoints) - 1; i >= 0; i-- { l = MarshalProtoOrigHistogramDataPoint(orig.DataPoints[i], buf[:pos]) pos -= l pos = proto.EncodeVarint(buf, pos, uint64(l)) pos-- buf[pos] = 0xa } if orig.AggregationTemporality != 0 { pos = proto.EncodeVarint(buf, pos, uint64(orig.AggregationTemporality)) pos-- buf[pos] = 0x10 } return len(buf) - pos } func UnmarshalProtoOrigHistogram(orig *otlpmetrics.Histogram, buf []byte) error { var err error var fieldNum int32 var wireType proto.WireType l := len(buf) pos := 0 for pos < l { // If in a group parsing, move to the next tag. fieldNum, wireType, pos, err = proto.ConsumeTag(buf, pos) if err != nil { return err } switch fieldNum { case 1: if wireType != proto.WireTypeLen { return fmt.Errorf("proto: wrong wireType = %d for field DataPoints", wireType) } var length int length, pos, err = proto.ConsumeLen(buf, pos) if err != nil { return err } startPos := pos - length orig.DataPoints = append(orig.DataPoints, NewOrigHistogramDataPoint()) err = UnmarshalProtoOrigHistogramDataPoint(orig.DataPoints[len(orig.DataPoints)-1], buf[startPos:pos]) if err != nil { return err } case 2: if wireType != proto.WireTypeVarint { return fmt.Errorf("proto: wrong wireType = %d for field AggregationTemporality", wireType) } var num uint64 num, pos, err = proto.ConsumeVarint(buf, pos) if err != nil { return err } orig.AggregationTemporality = otlpmetrics.AggregationTemporality(num) default: pos, err = proto.ConsumeUnknown(buf, pos, wireType) if err != nil { return err } } } return nil }