123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127 |
- // 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
- }
|