mirror of
				https://gitea.com/Lydanne/buildx.git
				synced 2025-11-04 10:03:42 +08:00 
			
		
		
		
	
		
			
				
	
	
		
			125 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			125 lines
		
	
	
		
			3.4 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
// Copyright The OpenTelemetry Authors
 | 
						|
//
 | 
						|
// Licensed under the Apache License, Version 2.0 (the "License");
 | 
						|
// you may not use this file except in compliance with the License.
 | 
						|
// You may obtain a copy of the License at
 | 
						|
//
 | 
						|
//     http://www.apache.org/licenses/LICENSE-2.0
 | 
						|
//
 | 
						|
// Unless required by applicable law or agreed to in writing, software
 | 
						|
// distributed under the License is distributed on an "AS IS" BASIS,
 | 
						|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | 
						|
// See the License for the specific language governing permissions and
 | 
						|
// limitations under the License.
 | 
						|
 | 
						|
package metric // import "go.opentelemetry.io/otel/metric"
 | 
						|
 | 
						|
import (
 | 
						|
	"go.opentelemetry.io/otel/metric/unit"
 | 
						|
)
 | 
						|
 | 
						|
// InstrumentConfig contains options for metric instrument descriptors.
 | 
						|
type InstrumentConfig struct {
 | 
						|
	description string
 | 
						|
	unit        unit.Unit
 | 
						|
}
 | 
						|
 | 
						|
// Description describes the instrument in human-readable terms.
 | 
						|
func (cfg InstrumentConfig) Description() string {
 | 
						|
	return cfg.description
 | 
						|
}
 | 
						|
 | 
						|
// Unit describes the measurement unit for a instrument.
 | 
						|
func (cfg InstrumentConfig) Unit() unit.Unit {
 | 
						|
	return cfg.unit
 | 
						|
}
 | 
						|
 | 
						|
// InstrumentOption is an interface for applying metric instrument options.
 | 
						|
type InstrumentOption interface {
 | 
						|
	// ApplyMeter is used to set a InstrumentOption value of a
 | 
						|
	// InstrumentConfig.
 | 
						|
	applyInstrument(*InstrumentConfig)
 | 
						|
}
 | 
						|
 | 
						|
// NewInstrumentConfig creates a new InstrumentConfig
 | 
						|
// and applies all the given options.
 | 
						|
func NewInstrumentConfig(opts ...InstrumentOption) InstrumentConfig {
 | 
						|
	var config InstrumentConfig
 | 
						|
	for _, o := range opts {
 | 
						|
		o.applyInstrument(&config)
 | 
						|
	}
 | 
						|
	return config
 | 
						|
}
 | 
						|
 | 
						|
type instrumentOptionFunc func(*InstrumentConfig)
 | 
						|
 | 
						|
func (fn instrumentOptionFunc) applyInstrument(cfg *InstrumentConfig) {
 | 
						|
	fn(cfg)
 | 
						|
}
 | 
						|
 | 
						|
// WithDescription applies provided description.
 | 
						|
func WithDescription(desc string) InstrumentOption {
 | 
						|
	return instrumentOptionFunc(func(cfg *InstrumentConfig) {
 | 
						|
		cfg.description = desc
 | 
						|
	})
 | 
						|
}
 | 
						|
 | 
						|
// WithUnit applies provided unit.
 | 
						|
func WithUnit(unit unit.Unit) InstrumentOption {
 | 
						|
	return instrumentOptionFunc(func(cfg *InstrumentConfig) {
 | 
						|
		cfg.unit = unit
 | 
						|
	})
 | 
						|
}
 | 
						|
 | 
						|
// MeterConfig contains options for Meters.
 | 
						|
type MeterConfig struct {
 | 
						|
	instrumentationVersion string
 | 
						|
	schemaURL              string
 | 
						|
}
 | 
						|
 | 
						|
// InstrumentationVersion is the version of the library providing instrumentation.
 | 
						|
func (cfg MeterConfig) InstrumentationVersion() string {
 | 
						|
	return cfg.instrumentationVersion
 | 
						|
}
 | 
						|
 | 
						|
// SchemaURL is the schema_url of the library providing instrumentation.
 | 
						|
func (cfg MeterConfig) SchemaURL() string {
 | 
						|
	return cfg.schemaURL
 | 
						|
}
 | 
						|
 | 
						|
// MeterOption is an interface for applying Meter options.
 | 
						|
type MeterOption interface {
 | 
						|
	// ApplyMeter is used to set a MeterOption value of a MeterConfig.
 | 
						|
	applyMeter(*MeterConfig)
 | 
						|
}
 | 
						|
 | 
						|
// NewMeterConfig creates a new MeterConfig and applies
 | 
						|
// all the given options.
 | 
						|
func NewMeterConfig(opts ...MeterOption) MeterConfig {
 | 
						|
	var config MeterConfig
 | 
						|
	for _, o := range opts {
 | 
						|
		o.applyMeter(&config)
 | 
						|
	}
 | 
						|
	return config
 | 
						|
}
 | 
						|
 | 
						|
type meterOptionFunc func(*MeterConfig)
 | 
						|
 | 
						|
func (fn meterOptionFunc) applyMeter(cfg *MeterConfig) {
 | 
						|
	fn(cfg)
 | 
						|
}
 | 
						|
 | 
						|
// WithInstrumentationVersion sets the instrumentation version.
 | 
						|
func WithInstrumentationVersion(version string) MeterOption {
 | 
						|
	return meterOptionFunc(func(config *MeterConfig) {
 | 
						|
		config.instrumentationVersion = version
 | 
						|
	})
 | 
						|
}
 | 
						|
 | 
						|
// WithSchemaURL sets the schema URL.
 | 
						|
func WithSchemaURL(schemaURL string) MeterOption {
 | 
						|
	return meterOptionFunc(func(config *MeterConfig) {
 | 
						|
		config.schemaURL = schemaURL
 | 
						|
	})
 | 
						|
}
 |