| // Copyright 2019 The Go Authors. All rights reserved. |
| // Use of this source code is governed by a BSD-style |
| // license that can be found in the LICENSE file. |
| |
| // Package trace adds support for telemetry tracing. |
| package trace |
| |
| import ( |
| "context" |
| "time" |
| |
| "golang.org/x/tools/internal/telemetry" |
| "golang.org/x/tools/internal/telemetry/export" |
| "golang.org/x/tools/internal/telemetry/tag" |
| ) |
| |
| func StartSpan(ctx context.Context, name string, tags ...telemetry.Tag) (context.Context, func()) { |
| start := time.Now() |
| span := &telemetry.Span{Name: name} |
| if parent := telemetry.GetSpan(ctx); parent != nil { |
| span.ID.TraceID = parent.ID.TraceID |
| span.ParentID = parent.ID.SpanID |
| } else { |
| span.ID.TraceID = telemetry.NewTraceID() |
| } |
| span.ID.SpanID = telemetry.NewSpanID() |
| ctx = telemetry.WithSpan(ctx, span) |
| if len(tags) > 0 { |
| ctx = tag.With(ctx, tags...) |
| } |
| export.StartSpan(ctx, span, start) |
| return ctx, func() { export.FinishSpan(ctx, span, time.Now()) } |
| } |
| |
| // Detach returns a context without an associated span. |
| // This allows the creation of spans that are not children of the current span. |
| func Detach(ctx context.Context) context.Context { |
| return telemetry.WithSpan(ctx, nil) |
| } |