
    Bvhx                     l   U d Z ddlZddlmZmZ ddlmZ ddlmZ ddl	m
Z
 ddlmZ ddlmZmZmZmZmZmZ dd	lmZ dd
lmZmZmZmZmZmZmZmZmZm Z m!Z!m"Z"m#Z#m$Z$m%Z%m&Z&m'Z'm(Z(m)Z)m*Z*m+Z+m,Z,m-Z- ddl.m/Z/ ddl0m1Z1 ddl2m3Z3  ee4      Z5ee'e)e(e*e+e,e-f   Z6 G d de      Z7 G d de7      Z8 G d de7      Z9e G d d             Z: G d de      Z; G d de;      Z< G d de;      Z= e/       Z>da?ee7   e@d<    e9       ZA	 	 	 	 d(deBdeBdee7   d eeB   d!ee3   d"dfd#ZCde7d$eDd"dfd%ZEde7d"dfd&ZFd"e7fd'ZGy))a  
The OpenTelemetry metrics API  describes the classes used to generate
metrics.

The :class:`.MeterProvider` provides users access to the :class:`.Meter` which in
turn is used to create :class:`.Instrument` objects. The :class:`.Instrument` objects are
used to record measurements.

This module provides abstract (i.e. unimplemented) classes required for
metrics, and a concrete no-op implementation :class:`.NoOpMeter` that allows applications
to use the API package alone without a supporting implementation.

To get a meter, you need to provide the package name from which you are
calling the meter APIs to OpenTelemetry by calling `MeterProvider.get_meter`
with the calling instrumentation name and the version of your package.

The following code shows how to obtain a meter using the global :class:`.MeterProvider`::

    from opentelemetry.metrics import get_meter

    meter = get_meter("example-meter")
    counter = meter.create_counter("example-counter")

.. versionadded:: 1.10.0
    N)ABCabstractmethod)	dataclass)	getLogger)environ)Lock)DictListOptionalSequenceUnioncast)OTEL_PYTHON_METER_PROVIDER)	CallbackTCounterGauge	HistogramNoOpCounter	NoOpGaugeNoOpHistogramNoOpObservableCounterNoOpObservableGaugeNoOpObservableUpDownCounterNoOpUpDownCounterObservableCounterObservableGaugeObservableUpDownCounterUpDownCounter_MetricsHistogramAdvisory_ProxyCounter_ProxyGauge_ProxyHistogram_ProxyObservableCounter_ProxyObservableGauge_ProxyObservableUpDownCounter_ProxyUpDownCounter)Once)_load_provider)
Attributesc                   P    e Zd ZdZe	 	 	 d
dedee   dee   dee   ddf
d	       Zy)MeterProviderz_
    MeterProvider is the entry point of the API. It provides access to `Meter` instances.
    Nnameversion
schema_url
attributesreturnMeterc                      y)aD  Returns a `Meter` for use by the given instrumentation library.

        For any two calls it is undefined whether the same or different
        `Meter` instances are returned, even for different library names.

        This function may return different `Meter` types (e.g. a no-op meter
        vs. a functional meter).

        Args:
            name: The name of the instrumenting module.
                ``__name__`` may not be used as this can result in
                different meter names if the meters are in different files.
                It is better to use a fixed string that can be imported where
                needed and used consistently as the name of the meter.

                This should *not* be the name of the module that is
                instrumented but the name of the module doing the instrumentation.
                E.g., instead of ``"requests"``, use
                ``"opentelemetry.instrumentation.requests"``.

            version: Optional. The version string of the
                instrumenting library.  Usually this should be the same as
                ``importlib.metadata.version(instrumenting_library_name)``.

            schema_url: Optional. Specifies the Schema URL of the emitted telemetry.
            attributes: Optional. Attributes that are associated with the emitted telemetry.
        N selfr,   r-   r.   r/   s        R/RAG/venv/lib/python3.12/site-packages/opentelemetry/metrics/_internal/__init__.py	get_meterzMeterProvider.get_meterg           NNN)	__name__
__module____qualname____doc__r   strr   r)   r7   r3   r9   r6   r+   r+   b   sc      "&$(+/!! #! SM	!
 Z(! 
! !r9   r+   c                   F    e Zd ZdZ	 	 	 d
dedee   dee   dee   ddf
d	Zy)NoOpMeterProviderzQThe default MeterProvider used when no MeterProvider implementation is available.Nr,   r-   r.   r/   r0   r1   c                     t        |||      S )zReturns a NoOpMeter.r-   r.   )	NoOpMeterr4   s        r6   r7   zNoOpMeterProvider.get_meter   s     w:FFr9   r:   )r;   r<   r=   r>   r?   r   r)   r7   r3   r9   r6   rA   rA      sX    [
 "&$(+/GG #G SM	G
 Z(G 
Gr9   rA   c                   Z    e Zd ZddZ	 	 	 ddedee   dee   dee   ddf
d	Zd
eddfdZ	y)_ProxyMeterProviderr0   Nc                 >    t               | _        g | _        d | _        y N)r   _lock_meters_real_meter_providerr5   s    r6   __init__z_ProxyMeterProvider.__init__   s    V
*,=A!r9   r,   r-   r.   r/   r1   c                     | j                   5  | j                  &| j                  j                  |||      cd d d        S t        |||      }| j                  j                  |       |cd d d        S # 1 sw Y   y xY wNrC   )rI   rK   r7   _ProxyMeterrJ   append)r5   r,   r-   r.   r/   meters         r6   r7   z_ProxyMeterProvider.get_meter   sh     ZZ((400::': Z  g*MELL& ZZs   )A4 *A44A=meter_providerc                     | j                   5  || _        | j                  D ]  }|j                  |        	 d d d        y # 1 sw Y   y xY wrH   )rI   rK   rJ   on_set_meter_provider)r5   rS   rR   s      r6   rU   z)_ProxyMeterProvider.on_set_meter_provider   s7    ZZ(6D%++N; & ZZs   *AA
r0   Nr:   )
r;   r<   r=   rM   r?   r   r)   r7   r+   rU   r3   r9   r6   rF   rF      sh    B "&$(+/ # SM	
 Z( 
"<M <d <r9   rF   c                   <    e Zd ZU eed<   eed<   eed<   ee   ed<   y)_InstrumentRegistrationStatusinstrument_idalready_registeredconflictcurrent_advisoryN)r;   r<   r=   r?   __annotations__boolr   r   r3   r9   r6   rX   rX      s    N899r9   rX   c                   B    e Zd ZdZ	 	 ddedee   dee   ddf fdZedefd       Zedee   fd	       Z	edee   fd
       Z
	 ddededededee   defdZededededededdfd       Ze	 	 ddedededefd       Ze	 	 ddedededefd       Ze	 	 	 d dedeee      dededef
d       Ze	 	 ddddedededeee      def
d       Z	 	 ddedededefdZe	 	 	 d dedeee      dededef
d       Z e	 	 	 d dedeee      dedede!f
d       Z" xZ#S )!r1   zHandles instrument creation.

    This class provides methods for creating instruments which are then
    used to produce measurements.
    Nr,   r-   r.   r0   c                 x    t         |           || _        || _        || _        i | _        t               | _        y rH   )superrM   _name_version_schema_url_instrument_idsr   _instrument_ids_lockr5   r,   r-   r.   	__class__s       r6   rM   zMeter.__init__   s?     	
%  	 %)F!r9   c                     | j                   S )z7
        The name of the instrumenting module.
        )rb   rL   s    r6   r,   z
Meter.name   s    
 zzr9   c                     | j                   S )zB
        The version string of the instrumenting library.
        )rc   rL   s    r6   r-   zMeter.version   s    
 }}r9   c                     | j                   S )zC
        Specifies the Schema URL of the emitted telemetry
        )rd   rL   s    r6   r.   zMeter.schema_url   s    
 r9   type_unitdescriptionadvisoryc                 L   dj                  |j                         j                         |j                  ||g      }d}d}d}	| j                  5  || j
                  v }|r| j
                  |   }	|	|k7  }n|| j
                  |<   ddd       t        ||||	      S # 1 sw Y   xY w)a  
        Register an instrument with the name, type, unit and description as
        identifying keys and the advisory as value.

        Returns a tuple. The first value is the instrument id.
        The second value is an `_InstrumentRegistrationStatus` where
        `already_registered` is `True` if the instrument has been registered
        already.
        If `conflict` is set to True the `current_advisory` attribute contains
        the registered instrument advisory.
        ,FN)rY   rZ   r[   r\   )joinstriplowerr;   rf   re   rX   )
r5   r,   rl   rm   rn   ro   rY   rZ   r[   r\   s
             r6   _register_instrumentzMeter._register_instrument   s    ( ZZ\!5>>4E
 #&&!.$2F2F!F!#'#7#7#F +x76>$$]3 ' -'1-	
 	
 '&s   5BB#instrumentation_typestatusc                 L    t         j                  d| ||||j                         y )NzAn instrument with name %s, type %s, unit %s and description %s has been created already with a different advisory value %s and will be used instead.)_loggerwarningr\   )r,   rv   rm   rn   rw   s        r6   %_log_instrument_registration_conflictz+Meter._log_instrument_registration_conflict  s-     	D  ##		
r9   c                      y)aR  Creates a `Counter` instrument

        Args:
            name: The name of the instrument to be created
            unit: The unit for observations this instrument reports. For
                example, ``By`` for bytes. UCUM units are recommended.
            description: A description for this instrument and what it measures.
        Nr3   r5   r,   rm   rn   s       r6   create_counterzMeter.create_counter*  r8   r9   c                      y)aY  Creates an `UpDownCounter` instrument

        Args:
            name: The name of the instrument to be created
            unit: The unit for observations this instrument reports. For
                example, ``By`` for bytes. UCUM units are recommended.
            description: A description for this instrument and what it measures.
        Nr3   r}   s       r6   create_up_down_counterzMeter.create_up_down_counter:  r8   r9   	callbacksc                      y)a  Creates an `ObservableCounter` instrument

        An observable counter observes a monotonically increasing count by calling provided
        callbacks which accept a :class:`~opentelemetry.metrics.CallbackOptions` and return
        multiple :class:`~opentelemetry.metrics.Observation`.

        For example, an observable counter could be used to report system CPU
        time periodically. Here is a basic implementation::

            def cpu_time_callback(options: CallbackOptions) -> Iterable[Observation]:
                observations = []
                with open("/proc/stat") as procstat:
                    procstat.readline()  # skip the first line
                    for line in procstat:
                        if not line.startswith("cpu"): break
                        cpu, *states = line.split()
                        observations.append(Observation(int(states[0]) // 100, {"cpu": cpu, "state": "user"}))
                        observations.append(Observation(int(states[1]) // 100, {"cpu": cpu, "state": "nice"}))
                        observations.append(Observation(int(states[2]) // 100, {"cpu": cpu, "state": "system"}))
                        # ... other states
                return observations

            meter.create_observable_counter(
                "system.cpu.time",
                callbacks=[cpu_time_callback],
                unit="s",
                description="CPU time"
            )

        To reduce memory usage, you can use generator callbacks instead of
        building the full list::

            def cpu_time_callback(options: CallbackOptions) -> Iterable[Observation]:
                with open("/proc/stat") as procstat:
                    procstat.readline()  # skip the first line
                    for line in procstat:
                        if not line.startswith("cpu"): break
                        cpu, *states = line.split()
                        yield Observation(int(states[0]) // 100, {"cpu": cpu, "state": "user"})
                        yield Observation(int(states[1]) // 100, {"cpu": cpu, "state": "nice"})
                        # ... other states

        Alternatively, you can pass a sequence of generators directly instead of a sequence of
        callbacks, which each should return iterables of :class:`~opentelemetry.metrics.Observation`::

            def cpu_time_callback(states_to_include: set[str]) -> Iterable[Iterable[Observation]]:
                # accept options sent in from OpenTelemetry
                options = yield
                while True:
                    observations = []
                    with open("/proc/stat") as procstat:
                        procstat.readline()  # skip the first line
                        for line in procstat:
                            if not line.startswith("cpu"): break
                            cpu, *states = line.split()
                            if "user" in states_to_include:
                                observations.append(Observation(int(states[0]) // 100, {"cpu": cpu, "state": "user"}))
                            if "nice" in states_to_include:
                                observations.append(Observation(int(states[1]) // 100, {"cpu": cpu, "state": "nice"}))
                            # ... other states
                    # yield the observations and receive the options for next iteration
                    options = yield observations

            meter.create_observable_counter(
                "system.cpu.time",
                callbacks=[cpu_time_callback({"user", "system"})],
                unit="s",
                description="CPU time"
            )

        The :class:`~opentelemetry.metrics.CallbackOptions` contain a timeout which the
        callback should respect. For example if the callback does asynchronous work, like
        making HTTP requests, it should respect the timeout::

            def scrape_http_callback(options: CallbackOptions) -> Iterable[Observation]:
                r = requests.get('http://scrapethis.com', timeout=options.timeout_millis / 10**3)
                for value in r.json():
                    yield Observation(value)

        Args:
            name: The name of the instrument to be created
            callbacks: A sequence of callbacks that return an iterable of
                :class:`~opentelemetry.metrics.Observation`. Alternatively, can be a sequence of generators that each
                yields iterables of :class:`~opentelemetry.metrics.Observation`.
            unit: The unit for observations this instrument reports. For
                example, ``By`` for bytes. UCUM units are recommended.
            description: A description for this instrument and what it measures.
        Nr3   r5   r,   r   rm   rn   s        r6   create_observable_counterzMeter.create_observable_counterJ  r8   r9   #explicit_bucket_boundaries_advisoryr   c                     y)ar  Creates a :class:`~opentelemetry.metrics.Histogram` instrument

        Args:
            name: The name of the instrument to be created
            unit: The unit for observations this instrument reports. For
                example, ``By`` for bytes. UCUM units are recommended.
            description: A description for this instrument and what it measures.
        Nr3   )r5   r,   rm   rn   r   s        r6   create_histogramzMeter.create_histogram  r8   r9   c                 .    t        j                  d       y)aR  Creates a ``Gauge`` instrument

        Args:
            name: The name of the instrument to be created
            unit: The unit for observations this instrument reports. For
                example, ``By`` for bytes. UCUM units are recommended.
            description: A description for this instrument and what it measures.
        z5create_gauge() is not implemented and will be a no-opN)warningswarnr}   s       r6   create_gaugezMeter.create_gauge  s     	MNr9   c                      y)aZ  Creates an `ObservableGauge` instrument

        Args:
            name: The name of the instrument to be created
            callbacks: A sequence of callbacks that return an iterable of
                :class:`~opentelemetry.metrics.Observation`. Alternatively, can be a generator that yields iterables
                of :class:`~opentelemetry.metrics.Observation`.
            unit: The unit for observations this instrument reports. For
                example, ``By`` for bytes. UCUM units are recommended.
            description: A description for this instrument and what it measures.
        Nr3   r   s        r6   create_observable_gaugezMeter.create_observable_gauge  r8   r9   c                      y)ab  Creates an `ObservableUpDownCounter` instrument

        Args:
            name: The name of the instrument to be created
            callbacks: A sequence of callbacks that return an iterable of
                :class:`~opentelemetry.metrics.Observation`. Alternatively, can be a generator that yields iterables
                of :class:`~opentelemetry.metrics.Observation`.
            unit: The unit for observations this instrument reports. For
                example, ``By`` for bytes. UCUM units are recommended.
            description: A description for this instrument and what it measures.
        Nr3   r   s        r6   !create_observable_up_down_counterz'Meter.create_observable_up_down_counter  r8   r9   NNrH    r   Nr   r   )$r;   r<   r=   r>   r?   r   rM   propertyr,   r-   r.   typer   rX   ru   staticmethodr{   r   r   r~   r   r   r   r   r   r   floatr   r   r   r   r   r   r   r   __classcell__rh   s   @r6   r1   r1      sc    "&$(	++ #+ SM	+
 
+ c   #    HSM     9=*
*
 *
 	*

 *
 45*
 
'*
X 

!
 
 	

 .
 

 
$  	  	
 
   	  	
 
   48^^ HY/0^ 	^
 ^ 
^ ^@  	 JN  	 .6huo-F 
 ( 	OO O 	O
 
O   48 HY/0 	
  
 &  48 HY/0 	
  
! r9   r1   c                   p    e Zd Z	 	 ddedee   dee   ddf fdZdeddfdZ	 	 dded	ed
edefdZ		 	 dded	ed
ede
fdZ	 	 	 ddedeee      d	ed
edef
dZ	 	 dddded	ed
edeee      def
dZ	 	 dded	ed
edefdZ	 	 	 ddedeee      d	ed
edef
dZ	 	 	 ddedeee      d	ed
edef
dZ xZS )rP   Nr,   r-   r.   r0   c                 d    t         |   |||       t               | _        g | _        d | _        y rO   )ra   rM   r   rI   _instruments_real_meterrg   s       r6   rM   z_ProxyMeter.__init__  s2     	w:FV
57,0r9   rS   c                     |j                  | j                  | j                  | j                        }| j                  5  || _        | j                  D ]  }|j                  |        	 ddd       y# 1 sw Y   yxY w)zCalled when a real meter provider is set on the creating _ProxyMeterProvider

        Creates a real backing meter for this instance and notifies all created
        instruments so they can create real backing instruments.
        N)r7   rb   rc   rd   rI   r   r   on_meter_set)r5   rS   
real_meter
instruments       r6   rU   z!_ProxyMeter.on_set_meter_provider  sd     $--JJt'7'7

 ZZ)D #//
''
3 0	 ZZs   *A22A;rm   rn   c                     | j                   5  | j                  r&| j                  j                  |||      cd d d        S t        |||      }| j                  j                  |       |cd d d        S # 1 sw Y   y xY wrH   )rI   r   r~   r    r   rQ   r5   r,   rm   rn   proxys        r6   r~   z_ProxyMeter.create_counter  sd     ZZ''66tT;O Z "$k:E$$U+ ZZ   )A3 )A33A<c                     | j                   5  | j                  r&| j                  j                  |||      cd d d        S t        |||      }| j                  j                  |       |cd d d        S # 1 sw Y   y xY wrH   )rI   r   r   r&   r   rQ   r   s        r6   r   z"_ProxyMeter.create_up_down_counter   sg     ZZ''>>$ Z
 (dK@E$$U+ ZZr   r   c                    | j                   5  | j                  r'| j                  j                  ||||      cd d d        S t        ||||      }| j                  j                  |       |cd d d        S # 1 sw Y   y xY wNrm   rn   )rI   r   r   r#   r   rQ   r5   r,   r   rm   rn   r   s         r6   r   z%_ProxyMeter.create_observable_counter/  sp     ZZ''AA)T; Z
 ,idE $$U+ ZZ   *A6+A66A?r   r   c                   | j                   5  | j                  r(| j                  j                  ||||      cd d d        S t        ||||      }| j                  j                  |       |cd d d        S # 1 sw Y   y xY w)Nr   )rI   r   r   r"   r   rQ   )r5   r,   rm   rn   r   r   s         r6   r   z_ProxyMeter.create_histogramA  sy     ZZ''888[	 9  Z $dK)LE $$U+ ZZs   +A6*A66A?c                     | j                   5  | j                  r&| j                  j                  |||      cd d d        S t        |||      }| j                  j                  |       |cd d d        S # 1 sw Y   y xY wrH   )rI   r   r   r!   r   rQ   r   s        r6   r   z_ProxyMeter.create_gaugeW  sd     ZZ''44T4M Z  dK8E$$U+ ZZr   c                    | j                   5  | j                  r'| j                  j                  ||||      cd d d        S t        ||||      }| j                  j                  |       |cd d d        S # 1 sw Y   y xY wr   )rI   r   r   r$   r   rQ   r   s         r6   r   z#_ProxyMeter.create_observable_gauged  sp     ZZ''??)T; Z
 *idE $$U+ ZZr   c                    | j                   5  | j                  r'| j                  j                  ||||      cd d d        S t        ||||      }| j                  j                  |       |cd d d        S # 1 sw Y   y xY wr   )rI   r   r   r%   r   rQ   r   s         r6   r   z-_ProxyMeter.create_observable_up_down_counterv  ss     ZZ''II	 Z 2idE $$U+ ZZr   r   r   r   )r;   r<   r=   r?   r   rM   r+   rU   r   r~   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   s   @r6   rP   rP     s    "&$(		1	1 #	1 SM		1
 
	14M 4d 4( 	  	
 
  	  	
 
$ 48 HY/0 	
  
* 	 JN  	 .6huo-F 
2 	  	
 
  48 HY/0 	
  
* 48 HY/0 	
  
!r9   rP   c                   .   e Zd ZdZ	 	 ddedededefdZ	 	 ddedededefdZ	 	 ddededede	fdZ
	 	 	 dded
eee      dededef
dZ	 	 dd	ddedededeee      def
dZ	 	 	 dded
eee      dededef
dZ	 	 	 dded
eee      dededef
dZy	)rD   zeThe default Meter used when no Meter implementation is available.

    All operations are no-op.
    r,   rm   rn   r0   c                     | j                  |t        ||      }|j                  r#| j                  |t        j
                  |||       t        |||      S )zReturns a no-op Counter.r   )ru   r   r[   r{   r   r;   r5   r,   rm   rn   rw   s        r6   r~   zNoOpMeter.create_counter  sZ     **+t[
 ??66   4dDDr9   c                     | j                  |t        ||      }|j                  r#| j                  |t        j
                  |||       t        |||      S )zReturns a no-op Gauge.r   )ru   r   r[   r{   r   r;   r   s        r6   r   zNoOpMeter.create_gauge  sS     **4D+N??66 DkBBr9   c                     | j                  |t        ||      }|j                  r#| j                  |t        j
                  |||       t        |||      S )zReturns a no-op UpDownCounter.r   )ru   r   r[   r{   r   r;   r   s        r6   r   z NoOpMeter.create_up_down_counter  s[     **#T;
 ??66&& !DkJJr9   Nr   c                     | j                  |t        ||      }|j                  r#| j                  |t        j
                  |||       t        ||||      S )z"Returns a no-op ObservableCounter.r   )ru   r   r[   r{   r   r;   r5   r,   r   rm   rn   rw   s         r6   r   z#NoOpMeter.create_observable_counter  se     **'{
 ??66!** %#	
 	
r9   r   r   c          	          | j                  |t        ||t        |            }|j                  r#| j	                  |t
        j                  |||       t        ||||      S )zReturns a no-op Histogram.)explicit_bucket_boundaries)rm   rn   r   )ru   r   r   r[   r{   r   r;   )r5   r,   rm   rn   r   rw   s         r6   r   zNoOpMeter.create_histogram  sr     **%+N
 ??66"" #0S	
 	
r9   c                     | j                  |t        ||      }|j                  r#| j                  |t        j
                  |||       t        ||||      S )z Returns a no-op ObservableGauge.r   )ru   r   r[   r{   r   r;   r   s         r6   r   z!NoOpMeter.create_observable_gauge  se     **%t[
 ??66(( ##	
 	
r9   c                     | j                  |t        ||      }|j                  r#| j                  |t        j
                  |||       t        ||||      S )z(Returns a no-op ObservableUpDownCounter.r   )ru   r   r[   r{   r   r;   r   s         r6   r   z+NoOpMeter.create_observable_up_down_counter"  se     **-t[
 ??66'00 +#	
 	
r9   r   r   )r;   r<   r=   r>   r?   r   r~   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r3   r9   r6   rD   rD     s    	EE E 	E
 
E0 	CC C 	C
 
C* 	KK K 	K
 
K. 48

 HY/0
 	

 
 

: 	
 JN

 
 	
 .6huo-F
 

H 48

 HY/0
 	

 
 

: 48

 HY/0
 	

 
 
!
r9   rD   _METER_PROVIDERr,   r-   rS   r.   r/   r0   c                 B    |
t               }|j                  | |||      S )zReturns a `Meter` for use by the given instrumentation library.

    This function is a convenience wrapper for
    `opentelemetry.metrics.MeterProvider.get_meter`.

    If meter_provider is omitted the current configured one is used.
    )get_meter_providerr7   )r,   r-   rS   r.   r/   s        r6   r7   r7   B  s)     +-##D':zJJr9   logc                 r     d fd}t         j                  |      }|r|st        j                  d       y y y )Nc                  4     a t        j                          y rH   )r   _PROXY_METER_PROVIDERrU   rS   s   r6   set_mpz#_set_meter_provider.<locals>.set_mpV  s    ( 	33NCr9   z2Overriding of current MeterProvider is not allowedrV   )_METER_PROVIDER_SET_ONCEdo_oncery   rz   )rS   r   r   did_sets   `   r6   _set_meter_providerr   U  s4    D '..v6G
7LM sr9   c                     t        | d       y)zSets the current global :class:`~.MeterProvider` object.

    This can only be done once, a warning will be logged if any further attempt
    is made.
    Tr   N)r   r   s    r6   set_meter_providerr   c  s     D1r9   c                      t         /t        t        vrt        S t	        t        d      } t        | d       t        dt               S )z8Gets the current global :class:`~.MeterProvider` object.rS   Fr   r+   )r   r   r   r   r(   r   r   r   s    r6   r   r   l  sC     %W4(((6&(8)
 	N6 11r9   )r   NNN)Hr>   r   abcr   r   dataclassesr   loggingr   osr   	threadingr   typingr	   r
   r   r   r   r   #opentelemetry.environment_variablesr   *opentelemetry.metrics._internal.instrumentr   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r   r    r!   r"   r#   r$   r%   r&   opentelemetry.util._oncer'   opentelemetry.util._providersr(   opentelemetry.util.typesr)   r;   ry   _ProxyInstrumentTr+   rA   rF   rX   r1   rP   rD   r   r   r]   r   r?   r7   r^   r   r   r   r3   r9   r6   <module>r      s  "4  # !    > > J      2 * 8 H
 ! 'C 'TG G<- << : : :sC sl	S% Sln
 n
b  6 +/-( /+- 
 .2 $'+K
KK ]+K 	K
 $K K&N ND NT N2} 2 22M 2r9   