mirror of
				https://github.com/go-gitea/gitea.git
				synced 2025-11-03 08:02:36 +09:00 
			
		
		
		
	* change to new code location * vendor * tagged version v0.2.0 * gitea-vet v0.2.1 Co-authored-by: techknowlogick <techknowlogick@gitea.io>
		
			
				
	
	
		
			128 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
			
		
		
	
	
			128 lines
		
	
	
		
			4.4 KiB
		
	
	
	
		
			Go
		
	
	
	
		
			Vendored
		
	
	
	
// 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
 | 
						|
}
 |