o
    /ga0                     @   s  d dl T d dlT d dlT d dlT d dlT d dlT dZzd dlT dZW n e	y-   dZY nw ddl
Z
d@ddZefd	d
ZefddZefddZefddZdd Zdd Zdd Zdd Zdd Zdd Zdd Zdd  Zdedddddfd!d"Zdeddddddddddfd#d$Zdefd%d&Zdedddddddddddddfd'd(Zdefd)d*Zd@d+d,Zd@d-d.Z ddefd/d0Z!ddefd1d2Z"d@d3d4Z#d@d5d6Z$efd7d8Z%efd9d:Z&G d;d< d<e'Z(G d=d> d>e(d?Z)dS )A   )*z6.0TF    Nc                 C   s   | d u ri S d S N )Zsettingsr   r   1usr/lib/python3.10/site-packages/yaml/__init__.pywarnings   s   r   c                 c   L    || }z|  r| V  |  s
W |  dS W |  dS |  w )z9
    Scan a YAML stream and produce scanning tokens.
    N)Zcheck_token	get_tokendisposestreamLoaderloaderr   r   r   scan      

r   c                 c   r   )z9
    Parse a YAML stream and produce parsing events.
    N)Zcheck_eventZ	get_eventr
   r   r   r   r   parse(   r   r   c                 C   &   || }z	|  W |  S |  w )zj
    Parse the first YAML document in a stream
    and produce the corresponding representation tree.
    )Zget_single_noder
   r   r   r   r   compose3      r   c                 c   r   )zb
    Parse all YAML documents in a stream
    and produce corresponding representation trees.
    N)Z
check_nodeZget_noder
   r   r   r   r   compose_all>      

r   c                 C   r   )zd
    Parse the first YAML document in a stream
    and produce the corresponding Python object.
    )Zget_single_datar
   r   r   r   r   loadJ   r   r   c                 c   r   )z\
    Parse all YAML documents in a stream
    and produce corresponding Python objects.
    N)Z
check_dataget_datar
   r   r   r   r   load_allU   r   r   c                 C   
   t | tS )z
    Parse the first YAML document in a stream
    and produce the corresponding Python object.

    Resolve all tags except those known to be
    unsafe on untrusted input.
    )r   
FullLoaderr   r   r   r   	full_loada      
r   c                 C   r   )z
    Parse all YAML documents in a stream
    and produce corresponding Python objects.

    Resolve all tags except those known to be
    unsafe on untrusted input.
    )r   r   r   r   r   r   full_load_allk   r   r   c                 C   r   )z
    Parse the first YAML document in a stream
    and produce the corresponding Python object.

    Resolve only basic YAML tags. This is known
    to be safe for untrusted input.
    )r   
SafeLoaderr   r   r   r   	safe_loadu   r   r!   c                 C   r   )z
    Parse all YAML documents in a stream
    and produce corresponding Python objects.

    Resolve only basic YAML tags. This is known
    to be safe for untrusted input.
    )r   r    r   r   r   r   safe_load_all   r   r"   c                 C   r   )z
    Parse the first YAML document in a stream
    and produce the corresponding Python object.

    Resolve all tags, even those known to be
    unsafe on untrusted input.
    )r   UnsafeLoaderr   r   r   r   unsafe_load   r   r$   c                 C   r   )z
    Parse all YAML documents in a stream
    and produce corresponding Python objects.

    Resolve all tags, even those known to be
    unsafe on untrusted input.
    )r   r#   r   r   r   r   unsafe_load_all   r   r%   c                 C   sh   d}|du rt  }|j}|||||||d}	z| D ]}
|	|
 qW |	  n|	  w |r2| S dS )zl
    Emit YAML parsing events into a stream.
    If stream is None, return the produced string instead.
    N)	canonicalindentwidthallow_unicode
line_break)ioStringIOgetvalueemitr
   )eventsr   Dumperr&   r'   r(   r)   r*   r-   dumpereventr   r   r   r.      s   
r.   c                 C   s   d}|du r|du rt  }nt  }|j}|||||||||||	|
d}z|  | D ]}|| q,|  W |  n|  w |rH| S dS )z
    Serialize a sequence of representation trees into a YAML stream.
    If stream is None, return the produced string instead.
    N)
r&   r'   r(   r)   r*   encodingversiontagsexplicit_startexplicit_end)r+   r,   BytesIOr-   open	serializecloser
   )nodesr   r0   r&   r'   r(   r)   r*   r3   r6   r7   r4   r5   r-   r1   noder   r   r   serialize_all   s(   	


r>   c                 K      t | g|fd|i|S )zx
    Serialize a representation tree into a YAML stream.
    If stream is None, return the produced string instead.
    r0   )r>   )r=   r   r0   kwdsr   r   r   r:         r:   c                 C   s   d}|du r|
du rt  }nt  }|j}|||||||||	|
|||||d}z|  | D ]}|| q/|  W |  n|  w |rK| S dS )z
    Serialize a sequence of Python objects into a YAML stream.
    If stream is None, return the produced string instead.
    N)default_styledefault_flow_styler&   r'   r(   r)   r*   r3   r4   r5   r6   r7   	sort_keys)r+   r,   r8   r-   r9   Z	representr;   r
   )	documentsr   r0   rB   rC   r&   r'   r(   r)   r*   r3   r6   r7   r4   r5   rD   r-   r1   datar   r   r   dump_all   s,   


rG   c                 K   r?   )zr
    Serialize a Python object into a YAML stream.
    If stream is None, return the produced string instead.
    r0   )rG   )rF   r   r0   r@   r   r   r   dump   rA   rH   c                 K   s   t | |fdti|S )z
    Serialize a sequence of Python objects into a YAML stream.
    Produce only basic YAML tags.
    If stream is None, return the produced string instead.
    r0   rG   Z
SafeDumper)rE   r   r@   r   r   r   safe_dump_all   s   rJ   c                 K   s   t | g|fdti|S )z
    Serialize a Python object into a YAML stream.
    Produce only basic YAML tags.
    If stream is None, return the produced string instead.
    r0   rI   )rF   r   r@   r   r   r   	safe_dump  s   rK   c                 C   Z   |du rt j| || t j| || t j| || n|| || || || dS )z
    Add an implicit scalar detector.
    If an implicit scalar value matches the given regexp,
    the corresponding tag is assigned to the scalar.
    first is a sequence of possible initial characters or None.
    N)r   r   add_implicit_resolverr   r#   )tagregexpfirstr   r0   r   r   r   rM     s   rM   c                 C   rL   )z
    Add a path based resolver for the given tag.
    A path is a list of keys that forms a path
    to a node in the representation tree.
    Keys can be string values, integers, or None.
    N)r   r   add_path_resolverr   r#   )rN   pathkindr   r0   r   r   r   rQ     s   rQ   c                 C   F   |du rt j| | t j| | t j| | dS || | dS )z
    Add a constructor for the given tag.
    Constructor is a function that accepts a Loader instance
    and a node object and produces the corresponding Python object.
    N)r   r   add_constructorr   r#   )rN   constructorr   r   r   r   rU   .  s
   rU   c                 C   rT   )a  
    Add a multi-constructor for the given tag prefix.
    Multi-constructor is called for a node if its tag starts with tag_prefix.
    Multi-constructor accepts a Loader instance, a tag suffix,
    and a node object and produces the corresponding Python object.
    N)r   r   add_multi_constructorr   r#   )Z
tag_prefixZmulti_constructorr   r   r   r   rW   ;  s
   rW   c                 C      | | | dS )z
    Add a representer for the given type.
    Representer is a function accepting a Dumper instance
    and an instance of the given data type
    and producing the corresponding representation node.
    N)add_representer)	data_typeZrepresenterr0   r   r   r   rY   I     rY   c                 C   rX   )z
    Add a representer for the given type.
    Multi-representer is a function accepting a Dumper instance
    and an instance of the given data type or subtype
    and producing the corresponding representation node.
    N)add_multi_representer)rZ   Zmulti_representerr0   r   r   r   r\   R  r[   r\   c                       s    e Zd ZdZ fddZ  ZS )YAMLObjectMetaclassz'
    The metaclass for YAMLObject.
    c                    s   t t| ||| d|v r<|d d ur>t| jtr)| jD ]
}|| j| j qn	| j| j| j | j	
| | j d S d S d S )Nyaml_tag)superr]   __init__
isinstanceyaml_loaderlistrU   r^   	from_yamlyaml_dumperrY   to_yaml)clsnamebasesr@   r   	__class__r   r   r`   _  s   
zYAMLObjectMetaclass.__init__)__name__
__module____qualname____doc__r`   __classcell__r   r   rj   r   r]   [  s    r]   c                   @   sB   e Zd ZdZdZeeegZe	Z
dZdZedd Zedd ZdS )
YAMLObjectza
    An object that can dump itself to a YAML stream
    and load itself from a YAML stream.
    r   Nc                 C   s   | || S )zC
        Convert a representation node to a Python object.
        )Zconstruct_yaml_object)rg   r   r=   r   r   r   rd   x  s   zYAMLObject.from_yamlc                 C   s   |j | j|| | jdS )zC
        Convert a Python object to a representation node.
        )Z
flow_style)Zrepresent_yaml_objectr^   yaml_flow_style)rg   r1   rF   r   r   r   rf     s   zYAMLObject.to_yaml)rl   rm   rn   ro   	__slots__r   r   r#   rb   r0   re   r^   rr   classmethodrd   rf   r   r   r   r   rq   j  s    

rq   )	metaclassr   )*errortokensr/   r<   r   r1   __version__ZcyamlZ__with_libyaml__ImportErrorr+   r   r   r   r   r   r   r   r   r   r   r!   r"   r$   r%   r0   r.   r>   r:   rG   rH   rJ   rK   rM   rQ   rU   rW   rY   r\   typer]   rq   r   r   r   r   <module>   st   









!




		