gtsocial-umbx

Unnamed repository; edit this file 'description' to name the repository.
Log | Files | Refs | README | LICENSE

event.go (4464B)


      1 // Copyright 2019 The Go Authors. All rights reserved.
      2 // Use of this source code is governed by a BSD-style
      3 // license that can be found in the LICENSE file.
      4 
      5 package event
      6 
      7 import (
      8 	"context"
      9 
     10 	"golang.org/x/tools/internal/event/core"
     11 	"golang.org/x/tools/internal/event/keys"
     12 	"golang.org/x/tools/internal/event/label"
     13 )
     14 
     15 // Exporter is a function that handles events.
     16 // It may return a modified context and event.
     17 type Exporter func(context.Context, core.Event, label.Map) context.Context
     18 
     19 // SetExporter sets the global exporter function that handles all events.
     20 // The exporter is called synchronously from the event call site, so it should
     21 // return quickly so as not to hold up user code.
     22 func SetExporter(e Exporter) {
     23 	core.SetExporter(core.Exporter(e))
     24 }
     25 
     26 // Log takes a message and a label list and combines them into a single event
     27 // before delivering them to the exporter.
     28 func Log(ctx context.Context, message string, labels ...label.Label) {
     29 	core.Export(ctx, core.MakeEvent([3]label.Label{
     30 		keys.Msg.Of(message),
     31 	}, labels))
     32 }
     33 
     34 // IsLog returns true if the event was built by the Log function.
     35 // It is intended to be used in exporters to identify the semantics of the
     36 // event when deciding what to do with it.
     37 func IsLog(ev core.Event) bool {
     38 	return ev.Label(0).Key() == keys.Msg
     39 }
     40 
     41 // Error takes a message and a label list and combines them into a single event
     42 // before delivering them to the exporter. It captures the error in the
     43 // delivered event.
     44 func Error(ctx context.Context, message string, err error, labels ...label.Label) {
     45 	core.Export(ctx, core.MakeEvent([3]label.Label{
     46 		keys.Msg.Of(message),
     47 		keys.Err.Of(err),
     48 	}, labels))
     49 }
     50 
     51 // IsError returns true if the event was built by the Error function.
     52 // It is intended to be used in exporters to identify the semantics of the
     53 // event when deciding what to do with it.
     54 func IsError(ev core.Event) bool {
     55 	return ev.Label(0).Key() == keys.Msg &&
     56 		ev.Label(1).Key() == keys.Err
     57 }
     58 
     59 // Metric sends a label event to the exporter with the supplied labels.
     60 func Metric(ctx context.Context, labels ...label.Label) {
     61 	core.Export(ctx, core.MakeEvent([3]label.Label{
     62 		keys.Metric.New(),
     63 	}, labels))
     64 }
     65 
     66 // IsMetric returns true if the event was built by the Metric function.
     67 // It is intended to be used in exporters to identify the semantics of the
     68 // event when deciding what to do with it.
     69 func IsMetric(ev core.Event) bool {
     70 	return ev.Label(0).Key() == keys.Metric
     71 }
     72 
     73 // Label sends a label event to the exporter with the supplied labels.
     74 func Label(ctx context.Context, labels ...label.Label) context.Context {
     75 	return core.Export(ctx, core.MakeEvent([3]label.Label{
     76 		keys.Label.New(),
     77 	}, labels))
     78 }
     79 
     80 // IsLabel returns true if the event was built by the Label function.
     81 // It is intended to be used in exporters to identify the semantics of the
     82 // event when deciding what to do with it.
     83 func IsLabel(ev core.Event) bool {
     84 	return ev.Label(0).Key() == keys.Label
     85 }
     86 
     87 // Start sends a span start event with the supplied label list to the exporter.
     88 // It also returns a function that will end the span, which should normally be
     89 // deferred.
     90 func Start(ctx context.Context, name string, labels ...label.Label) (context.Context, func()) {
     91 	return core.ExportPair(ctx,
     92 		core.MakeEvent([3]label.Label{
     93 			keys.Start.Of(name),
     94 		}, labels),
     95 		core.MakeEvent([3]label.Label{
     96 			keys.End.New(),
     97 		}, nil))
     98 }
     99 
    100 // IsStart returns true if the event was built by the Start function.
    101 // It is intended to be used in exporters to identify the semantics of the
    102 // event when deciding what to do with it.
    103 func IsStart(ev core.Event) bool {
    104 	return ev.Label(0).Key() == keys.Start
    105 }
    106 
    107 // IsEnd returns true if the event was built by the End function.
    108 // It is intended to be used in exporters to identify the semantics of the
    109 // event when deciding what to do with it.
    110 func IsEnd(ev core.Event) bool {
    111 	return ev.Label(0).Key() == keys.End
    112 }
    113 
    114 // Detach returns a context without an associated span.
    115 // This allows the creation of spans that are not children of the current span.
    116 func Detach(ctx context.Context) context.Context {
    117 	return core.Export(ctx, core.MakeEvent([3]label.Label{
    118 		keys.Detach.New(),
    119 	}, nil))
    120 }
    121 
    122 // IsDetach returns true if the event was built by the Detach function.
    123 // It is intended to be used in exporters to identify the semantics of the
    124 // event when deciding what to do with it.
    125 func IsDetach(ev core.Event) bool {
    126 	return ev.Label(0).Key() == keys.Detach
    127 }