mirror of
https://github.com/golang/go
synced 2024-11-18 12:54:44 -07:00
a90b7300be
Instead of tagging events with their type, instead we infer the type from the label pattern. The standard event creators all have a matching test that returns true if the the labels pattern matches the ones that would be built by the creator. Spans and logs already have a unique label pattern, other event types required a special label marker. This makes the system much more extensible, and also cleans up some the API. Change-Id: I1fbc9ec07aa84ead6c12bbd5ca65b13b605bfa4a Reviewed-on: https://go-review.googlesource.com/c/tools/+/229242 Run-TryBot: Ian Cottrell <iancottrell@google.com> TryBot-Result: Gobot Gobot <gobot@golang.org> Reviewed-by: Emmanuel Odeke <emm.odeke@gmail.com>
128 lines
4.4 KiB
Go
128 lines
4.4 KiB
Go
// 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 event
|
|
|
|
import (
|
|
"context"
|
|
|
|
"golang.org/x/tools/internal/event/core"
|
|
"golang.org/x/tools/internal/event/keys"
|
|
"golang.org/x/tools/internal/event/label"
|
|
)
|
|
|
|
// Exporter is a function that handles events.
|
|
// It may return a modified context and event.
|
|
type Exporter func(context.Context, core.Event, label.Map) context.Context
|
|
|
|
// SetExporter sets the global exporter function that handles all events.
|
|
// The exporter is called synchronously from the event call site, so it should
|
|
// return quickly so as not to hold up user code.
|
|
func SetExporter(e Exporter) {
|
|
core.SetExporter(core.Exporter(e))
|
|
}
|
|
|
|
// Log takes a message and a label list and combines them into a single event
|
|
// before delivering them to the exporter.
|
|
func Log(ctx context.Context, message string, labels ...label.Label) {
|
|
core.Export(ctx, core.MakeEvent([3]label.Label{
|
|
keys.Msg.Of(message),
|
|
}, labels))
|
|
}
|
|
|
|
// IsLog returns true if the event was built by the Log function.
|
|
// It is intended to be used in exporters to identify the semantics of the
|
|
// event when deciding what to do with it.
|
|
func IsLog(ev core.Event) bool {
|
|
return ev.Label(0).Key() == keys.Msg
|
|
}
|
|
|
|
// Error takes a message and a label list and combines them into a single event
|
|
// before delivering them to the exporter. It captures the error in the
|
|
// delivered event.
|
|
func Error(ctx context.Context, message string, err error, labels ...label.Label) {
|
|
core.Export(ctx, core.MakeEvent([3]label.Label{
|
|
keys.Msg.Of(message),
|
|
keys.Err.Of(err),
|
|
}, labels))
|
|
}
|
|
|
|
// IsError returns true if the event was built by the Error function.
|
|
// It is intended to be used in exporters to identify the semantics of the
|
|
// event when deciding what to do with it.
|
|
func IsError(ev core.Event) bool {
|
|
return ev.Label(0).Key() == keys.Msg &&
|
|
ev.Label(1).Key() == keys.Err
|
|
}
|
|
|
|
// Metric sends a label event to the exporter with the supplied labels.
|
|
func Metric(ctx context.Context, labels ...label.Label) {
|
|
core.Export(ctx, core.MakeEvent([3]label.Label{
|
|
keys.Metric.New(),
|
|
}, labels))
|
|
}
|
|
|
|
// IsMetric returns true if the event was built by the Metric function.
|
|
// It is intended to be used in exporters to identify the semantics of the
|
|
// event when deciding what to do with it.
|
|
func IsMetric(ev core.Event) bool {
|
|
return ev.Label(0).Key() == keys.Metric
|
|
}
|
|
|
|
// Label sends a label event to the exporter with the supplied labels.
|
|
func Label(ctx context.Context, labels ...label.Label) context.Context {
|
|
return core.Export(ctx, core.MakeEvent([3]label.Label{
|
|
keys.Label.New(),
|
|
}, labels))
|
|
}
|
|
|
|
// IsLabel returns true if the event was built by the Label function.
|
|
// It is intended to be used in exporters to identify the semantics of the
|
|
// event when deciding what to do with it.
|
|
func IsLabel(ev core.Event) bool {
|
|
return ev.Label(0).Key() == keys.Label
|
|
}
|
|
|
|
// Start sends a span start event with the supplied label list to the exporter.
|
|
// It also returns a function that will end the span, which should normally be
|
|
// deferred.
|
|
func Start(ctx context.Context, name string, labels ...label.Label) (context.Context, func()) {
|
|
return core.ExportPair(ctx,
|
|
core.MakeEvent([3]label.Label{
|
|
keys.Start.Of(name),
|
|
}, labels),
|
|
core.MakeEvent([3]label.Label{
|
|
keys.End.New(),
|
|
}, nil))
|
|
}
|
|
|
|
// IsStart returns true if the event was built by the Start function.
|
|
// It is intended to be used in exporters to identify the semantics of the
|
|
// event when deciding what to do with it.
|
|
func IsStart(ev core.Event) bool {
|
|
return ev.Label(0).Key() == keys.Start
|
|
}
|
|
|
|
// IsEnd returns true if the event was built by the End function.
|
|
// It is intended to be used in exporters to identify the semantics of the
|
|
// event when deciding what to do with it.
|
|
func IsEnd(ev core.Event) bool {
|
|
return ev.Label(0).Key() == keys.End
|
|
}
|
|
|
|
// 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 core.Export(ctx, core.MakeEvent([3]label.Label{
|
|
keys.Detach.New(),
|
|
}, nil))
|
|
}
|
|
|
|
// IsDetach returns true if the event was built by the Detach function.
|
|
// It is intended to be used in exporters to identify the semantics of the
|
|
// event when deciding what to do with it.
|
|
func IsDetach(ev core.Event) bool {
|
|
return ev.Label(0).Key() == keys.Detach
|
|
}
|