From 4a0e16ff2e028d66b66e9389aa297f6c7be644ba Mon Sep 17 00:00:00 2001 From: Eliza Weisman Date: Fri, 27 Aug 2021 11:38:32 -0700 Subject: [PATCH] subscriber: fix `Context`'s `LookupSpan` method feature flagging (#1525) The `layer::Context` type has additional methods that require the inner subscriber to implement `LookupSpan`. These currently are only present when the `registry` feature flag is enabled. However, this isn't actually necessary --- the `LookupSpan` trait always exists, and doesn't require the `registry` feature flag; that feature flag only controls whether the `Registry` _type_, a concrete implementation of `LookupSpan`, is enabled. This branch removes the `cfg` attributes from these methods. --- tracing-subscriber/src/layer.rs | 30 ++++--------------- tracing-subscriber/src/registry/extensions.rs | 1 + 2 files changed, 6 insertions(+), 25 deletions(-) diff --git a/tracing-subscriber/src/layer.rs b/tracing-subscriber/src/layer.rs index 64ad93cedb..f04d07c793 100644 --- a/tracing-subscriber/src/layer.rs +++ b/tracing-subscriber/src/layer.rs @@ -7,7 +7,8 @@ use tracing_core::{ }; #[cfg(feature = "registry")] -use crate::registry::{self, LookupSpan, Registry, SpanRef}; +use crate::registry::Registry; +use crate::registry::{self, LookupSpan, SpanRef}; use std::{any::TypeId, marker::PhantomData}; /// A composable handler for `tracing` events. @@ -577,15 +578,12 @@ pub struct Identity { /// /// [stored data]: ../registry/struct.SpanRef.html /// [`Context::scope`]: struct.Context.html#method.scope -#[cfg(feature = "registry")] -#[cfg_attr(docsrs, doc(cfg(feature = "registry")))] #[deprecated(note = "renamed to crate::registry::ScopeFromRoot", since = "0.2.19")] #[derive(Debug)] pub struct Scope<'a, L>(std::iter::Flatten>>) where L: LookupSpan<'a>; -#[cfg(feature = "registry")] #[allow(deprecated)] impl<'a, L> Iterator for Scope<'a, L> where @@ -915,8 +913,6 @@ where } } -#[cfg(feature = "registry")] -#[cfg_attr(docsrs, doc(cfg(feature = "registry")))] impl<'a, L, S> LookupSpan<'a> for Layered where S: Subscriber + LookupSpan<'a>, @@ -1062,8 +1058,6 @@ where /// declaration for details. /// #[inline] - #[cfg(feature = "registry")] - #[cfg_attr(docsrs, doc(cfg(feature = "registry")))] pub fn event_span(&self, event: &Event<'_>) -> Option> where S: for<'lookup> LookupSpan<'lookup>, @@ -1082,8 +1076,6 @@ where /// If this returns `None`, then no span exists for that ID (either it has /// closed or the ID is invalid). #[inline] - #[cfg(feature = "registry")] - #[cfg_attr(docsrs, doc(cfg(feature = "registry")))] pub fn metadata(&self, id: &span::Id) -> Option<&'static Metadata<'static>> where S: for<'lookup> LookupSpan<'lookup>, @@ -1107,8 +1099,6 @@ where /// /// [stored data]: ../registry/struct.SpanRef.html #[inline] - #[cfg(feature = "registry")] - #[cfg_attr(docsrs, doc(cfg(feature = "registry")))] pub fn span(&self, id: &span::Id) -> Option> where S: for<'lookup> LookupSpan<'lookup>, @@ -1126,8 +1116,6 @@ where /// declaration for details. /// #[inline] - #[cfg(feature = "registry")] - #[cfg_attr(docsrs, doc(cfg(feature = "registry")))] pub fn exists(&self, id: &span::Id) -> bool where S: for<'lookup> LookupSpan<'lookup>, @@ -1150,8 +1138,6 @@ where /// /// [stored data]: ../registry/struct.SpanRef.html #[inline] - #[cfg(feature = "registry")] - #[cfg_attr(docsrs, doc(cfg(feature = "registry")))] pub fn lookup_current(&self) -> Option> where S: for<'lookup> LookupSpan<'lookup>, @@ -1183,8 +1169,6 @@ where /// /// /// [stored data]: ../registry/struct.SpanRef.html - #[cfg(feature = "registry")] - #[cfg_attr(docsrs, doc(cfg(feature = "registry")))] #[deprecated( note = "equivalent to `self.current_span().id().and_then(|id| self.span_scope(id).from_root())` but consider passing an explicit ID instead of relying on the contextual span", since = "0.2.19" @@ -1192,7 +1176,7 @@ where #[allow(deprecated)] pub fn scope(&self) -> Scope<'_, S> where - S: for<'lookup> registry::LookupSpan<'lookup>, + S: for<'lookup> LookupSpan<'lookup>, { Scope( self.lookup_current() @@ -1231,11 +1215,9 @@ where /// /// /// [stored data]: ../registry/struct.SpanRef.html - #[cfg(feature = "registry")] - #[cfg_attr(docsrs, doc(cfg(feature = "registry")))] pub fn span_scope(&self, id: &span::Id) -> Option> where - S: for<'lookup> registry::LookupSpan<'lookup>, + S: for<'lookup> LookupSpan<'lookup>, { Some(self.span(id)?.scope()) } @@ -1261,11 +1243,9 @@ where /// /// /// [stored data]: ../registry/struct.SpanRef.html - #[cfg(feature = "registry")] - #[cfg_attr(docsrs, doc(cfg(feature = "registry")))] pub fn event_scope(&self, event: &Event<'_>) -> Option> where - S: for<'lookup> registry::LookupSpan<'lookup>, + S: for<'lookup> LookupSpan<'lookup>, { Some(self.event_span(event)?.scope()) } diff --git a/tracing-subscriber/src/registry/extensions.rs b/tracing-subscriber/src/registry/extensions.rs index ecac177bff..640e1a433e 100644 --- a/tracing-subscriber/src/registry/extensions.rs +++ b/tracing-subscriber/src/registry/extensions.rs @@ -124,6 +124,7 @@ impl ExtensionsInner { /// Create an empty `Extensions`. #[cfg(any(test, feature = "registry"))] #[inline] + #[cfg(any(test, feature = "registry"))] pub(crate) fn new() -> ExtensionsInner { ExtensionsInner { map: AnyMap::default(),