From b7197d568f02a0cbc29cc4472300674188238722 Mon Sep 17 00:00:00 2001 From: Tyler Yahn Date: Fri, 16 Oct 2020 17:46:47 -0700 Subject: [PATCH] Update the internal global TextMapPropagator (#1261) * Update the internal global TextMapPropagator Include feedback from a post-merge review of #1258 * Apply feedback * Update api/global/internal/propagator.go Co-authored-by: Steven E. Harris Co-authored-by: Steven E. Harris --- api/global/internal/propagator.go | 28 ++++++++++++---------------- 1 file changed, 12 insertions(+), 16 deletions(-) diff --git a/api/global/internal/propagator.go b/api/global/internal/propagator.go index 706e024a6..05678bb0f 100644 --- a/api/global/internal/propagator.go +++ b/api/global/internal/propagator.go @@ -54,33 +54,29 @@ func (p *textMapPropagator) SetDelegate(delegate otel.TextMapPropagator) { p.mtx.Unlock() } -// HasDelegate returns if a delegate is set for p. -func (p *textMapPropagator) HasDelegate() bool { +// effectiveDelegate returns the current delegate of p if one is set, +// otherwise the default noop TextMapPropagator is returned. This method +// can be called concurrently. +func (p *textMapPropagator) effectiveDelegate() otel.TextMapPropagator { p.mtx.Lock() defer p.mtx.Unlock() - return p.delegate != nil + if p.delegate != nil { + return p.delegate + } + return p.noop } // Inject set cross-cutting concerns from the Context into the carrier. func (p *textMapPropagator) Inject(ctx context.Context, carrier otel.TextMapCarrier) { - if p.HasDelegate() { - p.delegate.Inject(ctx, carrier) - } - p.noop.Inject(ctx, carrier) + p.effectiveDelegate().Inject(ctx, carrier) } // Extract reads cross-cutting concerns from the carrier into a Context. func (p *textMapPropagator) Extract(ctx context.Context, carrier otel.TextMapCarrier) context.Context { - if p.HasDelegate() { - return p.delegate.Extract(ctx, carrier) - } - return p.noop.Extract(ctx, carrier) + return p.effectiveDelegate().Extract(ctx, carrier) } -// Fields returns the keys who's values are set with Inject. +// Fields returns the keys whose values are set with Inject. func (p *textMapPropagator) Fields() []string { - if p.HasDelegate() { - return p.delegate.Fields() - } - return p.noop.Fields() + return p.effectiveDelegate().Fields() }