// Copyright The OpenTelemetry Authors
// SPDX-License-Identifier: Apache-2.0

package metric // import "go.opentelemetry.io/otel/metric"

import 

// MeterConfig contains options for Meters.
type MeterConfig struct {
	instrumentationVersion string
	schemaURL              string
	attrs                  attribute.Set

	// Ensure forward compatibility by explicitly making this not comparable.
	noCmp [0]func() //nolint: unused  // This is indeed used.
}

// InstrumentationVersion returns the version of the library providing
// instrumentation.
func ( MeterConfig) () string {
	return .instrumentationVersion
}

// InstrumentationAttributes returns the attributes associated with the library
// providing instrumentation.
func ( MeterConfig) () attribute.Set {
	return .attrs
}

// SchemaURL is the schema_url of the library providing instrumentation.
func ( MeterConfig) () string {
	return .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) MeterConfig
}

// NewMeterConfig creates a new MeterConfig and applies
// all the given options.
func ( ...MeterOption) MeterConfig {
	var  MeterConfig
	for ,  := range  {
		 = .applyMeter()
	}
	return 
}

type meterOptionFunc func(MeterConfig) MeterConfig

func ( meterOptionFunc) ( MeterConfig) MeterConfig {
	return ()
}

// WithInstrumentationVersion sets the instrumentation version.
func ( string) MeterOption {
	return meterOptionFunc(func( MeterConfig) MeterConfig {
		.instrumentationVersion = 
		return 
	})
}

// WithInstrumentationAttributes sets the instrumentation attributes.
//
// The passed attributes will be de-duplicated.
func ( ...attribute.KeyValue) MeterOption {
	return meterOptionFunc(func( MeterConfig) MeterConfig {
		.attrs = attribute.NewSet(...)
		return 
	})
}

// WithSchemaURL sets the schema URL.
func ( string) MeterOption {
	return meterOptionFunc(func( MeterConfig) MeterConfig {
		.schemaURL = 
		return 
	})
}