diff --git a/src/encoding.rs b/src/encoding.rs index 663b2c7..41af457 100644 --- a/src/encoding.rs +++ b/src/encoding.rs @@ -43,7 +43,7 @@ macro_rules! for_both { pub trait EncodeMetric { /// Encode the given instance in the OpenMetrics text encoding. // TODO: Lifetimes on MetricEncoder needed? - fn encode(&self, encoder: MetricEncoder) -> Result<(), std::fmt::Error>; + fn encode(&self, encoder: &mut MetricEncoder) -> Result<(), std::fmt::Error>; /// The OpenMetrics metric type of the instance. // One can not use [`TypedMetric`] directly, as associated constants are not @@ -52,7 +52,7 @@ pub trait EncodeMetric { } impl EncodeMetric for Box { - fn encode(&self, encoder: MetricEncoder) -> Result<(), std::fmt::Error> { + fn encode(&self, encoder: &mut MetricEncoder) -> Result<(), std::fmt::Error> { self.deref().encode(encoder) } diff --git a/src/encoding/text.rs b/src/encoding/text.rs index c18a459..ca44aa9 100644 --- a/src/encoding/text.rs +++ b/src/encoding/text.rs @@ -1080,13 +1080,13 @@ mod tests { mut encoder: crate::encoding::DescriptorEncoder, ) -> Result<(), std::fmt::Error> { let counter = crate::metrics::counter::ConstCounter::new(42u64); - let metric_encoder = encoder.encode_descriptor( + let mut metric_encoder = encoder.encode_descriptor( &self.name, "some help", None, counter.metric_type(), )?; - counter.encode(metric_encoder)?; + counter.encode(&mut metric_encoder)?; Ok(()) } } diff --git a/src/metrics/counter.rs b/src/metrics/counter.rs index 7016c36..2be9ebd 100644 --- a/src/metrics/counter.rs +++ b/src/metrics/counter.rs @@ -203,7 +203,7 @@ where N: crate::encoding::EncodeCounterValue, A: Atomic, { - fn encode(&self, mut encoder: MetricEncoder) -> Result<(), std::fmt::Error> { + fn encode(&self, encoder: &mut MetricEncoder) -> Result<(), std::fmt::Error> { encoder.encode_counter::(&self.get(), None) } @@ -235,7 +235,7 @@ impl EncodeMetric for ConstCounter where N: crate::encoding::EncodeCounterValue, { - fn encode(&self, mut encoder: MetricEncoder) -> Result<(), std::fmt::Error> { + fn encode(&self, encoder: &mut MetricEncoder) -> Result<(), std::fmt::Error> { encoder.encode_counter::(&self.value, None) } diff --git a/src/metrics/exemplar.rs b/src/metrics/exemplar.rs index e61f4d5..77d2f9c 100644 --- a/src/metrics/exemplar.rs +++ b/src/metrics/exemplar.rs @@ -155,7 +155,7 @@ where N: EncodeCounterValue + EncodeExemplarValue + Clone, A: counter::Atomic, { - fn encode(&self, mut encoder: MetricEncoder) -> Result<(), std::fmt::Error> { + fn encode(&self, encoder: &mut MetricEncoder) -> Result<(), std::fmt::Error> { let (value, exemplar) = self.get(); encoder.encode_counter(&value, exemplar.as_ref()) } @@ -267,7 +267,7 @@ impl HistogramWithExemplars { } impl EncodeMetric for HistogramWithExemplars { - fn encode(&self, mut encoder: MetricEncoder) -> Result<(), std::fmt::Error> { + fn encode(&self, encoder: &mut MetricEncoder) -> Result<(), std::fmt::Error> { let inner = self.inner(); let (sum, count, buckets) = inner.histogram.get(); encoder.encode_histogram(sum, count, &buckets, Some(&inner.exemplars)) diff --git a/src/metrics/family.rs b/src/metrics/family.rs index 2f23b19..05512d7 100644 --- a/src/metrics/family.rs +++ b/src/metrics/family.rs @@ -312,11 +312,11 @@ where M: EncodeMetric + TypedMetric, C: MetricConstructor, { - fn encode(&self, mut encoder: MetricEncoder) -> Result<(), std::fmt::Error> { + fn encode(&self, encoder: &mut MetricEncoder) -> Result<(), std::fmt::Error> { let guard = self.read(); for (label_set, m) in guard.iter() { - let encoder = encoder.encode_family(label_set)?; - m.encode(encoder)?; + let mut encoder = encoder.encode_family(label_set)?; + m.encode(&mut encoder)?; } Ok(()) } diff --git a/src/metrics/gauge.rs b/src/metrics/gauge.rs index abbc8ce..6a788f4 100644 --- a/src/metrics/gauge.rs +++ b/src/metrics/gauge.rs @@ -346,7 +346,7 @@ where N: EncodeGaugeValue, A: Atomic, { - fn encode(&self, mut encoder: MetricEncoder) -> Result<(), std::fmt::Error> { + fn encode(&self, encoder: &mut MetricEncoder) -> Result<(), std::fmt::Error> { encoder.encode_gauge(&self.get()) } fn metric_type(&self) -> MetricType { @@ -377,7 +377,7 @@ impl EncodeMetric for ConstGauge where N: EncodeGaugeValue, { - fn encode(&self, mut encoder: MetricEncoder) -> Result<(), std::fmt::Error> { + fn encode(&self, encoder: &mut MetricEncoder) -> Result<(), std::fmt::Error> { encoder.encode_gauge(&self.value) } diff --git a/src/metrics/histogram.rs b/src/metrics/histogram.rs index 1e418ad..4488c61 100644 --- a/src/metrics/histogram.rs +++ b/src/metrics/histogram.rs @@ -131,7 +131,7 @@ pub fn linear_buckets(start: f64, width: f64, length: u16) -> impl Iterator Result<(), std::fmt::Error> { + fn encode(&self, encoder: &mut MetricEncoder) -> Result<(), std::fmt::Error> { let (sum, count, buckets) = self.get(); encoder.encode_histogram::(sum, count, &buckets, None) } diff --git a/src/metrics/info.rs b/src/metrics/info.rs index 6ab127c..e9ae28b 100644 --- a/src/metrics/info.rs +++ b/src/metrics/info.rs @@ -33,7 +33,7 @@ impl EncodeMetric for Info where S: Clone + std::hash::Hash + Eq + EncodeLabelSet, { - fn encode(&self, mut encoder: MetricEncoder) -> Result<(), std::fmt::Error> { + fn encode(&self, encoder: &mut MetricEncoder) -> Result<(), std::fmt::Error> { encoder.encode_info(&self.0) } diff --git a/src/registry.rs b/src/registry.rs index c7dec3b..77653e2 100644 --- a/src/registry.rs +++ b/src/registry.rs @@ -290,13 +290,13 @@ impl Registry { for (descriptor, metric) in self.metrics.iter() { let mut descriptor_encoder = encoder.with_prefix_and_labels(self.prefix.as_ref(), &self.labels); - let metric_encoder = descriptor_encoder.encode_descriptor( + let mut metric_encoder = descriptor_encoder.encode_descriptor( &descriptor.name, &descriptor.help, descriptor.unit.as_ref(), EncodeMetric::metric_type(metric.as_ref()), )?; - metric.encode(metric_encoder)?; + metric.encode(&mut metric_encoder)?; } for collector in self.collectors.iter() {