From 70116e886d0d05eddf00a3ff2bcfd768f7348b63 Mon Sep 17 00:00:00 2001 From: Alexey Orlenko Date: Mon, 25 Nov 2024 17:28:40 +0100 Subject: [PATCH] Get rid of Arc, channel is already refcounted --- libs/telemetry/src/capturing/ng/exporter.rs | 32 ++++++++++----------- 1 file changed, 15 insertions(+), 17 deletions(-) diff --git a/libs/telemetry/src/capturing/ng/exporter.rs b/libs/telemetry/src/capturing/ng/exporter.rs index c49cb72d25d..0b8337ed6f5 100644 --- a/libs/telemetry/src/capturing/ng/exporter.rs +++ b/libs/telemetry/src/capturing/ng/exporter.rs @@ -110,8 +110,17 @@ pub struct CaptureSettings { targets: BitFlags, } +enum Message { + StartCapturing(RequestId), + StopCapturing(RequestId, oneshot::Sender>), + AddSpan(RequestId, CollectedSpan), + AddEvent(RequestId, CollectedEvent), +} + #[derive(Clone)] -pub struct Exporter(Arc); +pub struct Exporter { + tx: UnboundedSender, +} impl Debug for Exporter { fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result { @@ -125,17 +134,6 @@ impl Default for Exporter { } } -struct Inner { - tx: UnboundedSender, -} - -enum Message { - StartCapturing(RequestId), - StopCapturing(RequestId, oneshot::Sender>), - AddSpan(RequestId, CollectedSpan), - AddEvent(RequestId, CollectedEvent), -} - impl Exporter { pub fn new() -> Self { let (tx, mut rx) = mpsc::unbounded_channel(); @@ -168,28 +166,28 @@ impl Exporter { } }); - Self(Arc::new(Inner { tx })) + Self { tx } } pub async fn start_capturing(&self) -> RequestId { let request_id = RequestId::next(); - _ = self.0.tx.send(Message::StartCapturing(request_id)); + _ = self.tx.send(Message::StartCapturing(request_id)); request_id } pub async fn stop_capturing(&self, request_id: RequestId) -> Option { let (tx, rx) = oneshot::channel(); - _ = self.0.tx.send(Message::StopCapturing(request_id, tx)); + _ = self.tx.send(Message::StopCapturing(request_id, tx)); rx.await.expect("capturer task dropped the sender") } } impl Collector for Exporter { fn add_span(&self, trace: RequestId, span: CollectedSpan) { - _ = self.0.tx.send(Message::AddSpan(trace, span)); + _ = self.tx.send(Message::AddSpan(trace, span)); } fn add_event(&self, trace: RequestId, event: CollectedEvent) { - _ = self.0.tx.send(Message::AddEvent(trace, event)); + _ = self.tx.send(Message::AddEvent(trace, event)); } }