o
    Yh;                     @  s  U d Z ddlmZ ddlmZmZ ddlmZ ddlm	Z	m
Z
 ddlmZmZmZ ddlZddlZddlZddlmZ dd	lmZ dd
lmZ er[ddlmZmZmZmZ ddlmZ eddgZ de!d< e Z"de!d< e#dZ$e% Z&d3ddZ'dd Z(G dd de)Z*G dd de*Z+G dd  d e*Z,ed!d"G d#d$ d$e)Z-G d%d& d&e-eZ.G d'd( d(e)Z/G d)d* d*e)Z0G d+d, d,e)Z1G d-d. d.Z2e e"fd/d0Z3e3 Z4	 e4fd1d2Z5dS )4z2
Validation errors, and some surrounding helpers.
    )annotations)defaultdictdeque)pformat)dedentindent)TYPE_CHECKINGAnyClassVarN)define)Unresolvable)_utils)IterableMappingMutableMappingSequence)_typesanyOfoneOfzfrozenset[str]WEAK_MATCHESSTRONG_MATCHESz^[a-zA-Z][a-zA-Z0-9_]*$thingr	   prefixstrc                 C  s   t t| ddd| S )zP
    Format something for an error message as prettily as we currently can.
    H   F)width
sort_dicts)r   r   lstrip)r   r    r   V/var/www/html/Persson_Maskin/env/lib/python3.10/site-packages/jsonschema/exceptions.py_pretty    s   r    c                 C  s2   | dkrt jtjtdd tS tdt d|  )NRefResolutionError   
stacklevelzmodule z has no attribute )warningswarn_RefResolutionError_DEPRECATION_MESSAGEDeprecationWarningAttributeError__name__)namer   r   r   __getattr__'   s   r-   c                
      s   e Zd ZU ded< ded< edddeeeddef
d2 fddZd3ddZd3ddZed4d d!Z	e
d5d#d$Ze
d5d%d&Ze
d3d'd(Z	d6d7d+d,Zd-d. Zd8d0d1Z  ZS )9_ErrorzClassVar[str]!_word_for_schema_in_error_message#_word_for_instance_in_error_messager   Nmessager   	validatorpathIterable[str | int]causeException | Nonevalidator_valuer	   instanceschemaMapping[str, Any] | boolschema_pathparent_Error | Nonetype_checker_types.TypeCheckerreturnNonec                   s   t  |||||||||	|

 || _t| | _| _t|	 | _| _t|| _	| | _
| _|| _|| _|| _|| _|
| _|| _|D ]}| |_qAd S N)super__init__r1   r   r3   relative_pathr;   relative_schema_pathlistcontextr5   	__cause__r2   r7   r8   r9   r<   _type_checker)selfr1   r2   r3   r5   rH   r7   r8   r9   r;   r<   r>   error	__class__r   r   rD   7   s4   
z_Error.__init__c                 C  s   d| j j d| jdS )N<: >)rN   r+   r1   rK   r   r   r   __repr__`   s   z_Error.__repr__c                 C  s   | j | j| j| jf}tdd |D r| jS tj| jt	| j
d d d}tj| j| jd}d}td| j d| j d| d	t| j|d
 d| d	t| j|d
 d S )Nc                 s  s    | ]}|t u V  qd S rB   )_unset).0mr   r   r   	<genexpr>g   s    z!_Error.__str__.<locals>.<genexpr>)	containerindices                z            z 

            Failed validating z in z:
                r   z

            On 
            )r2   r7   r8   r9   anyr1   r   format_as_indexr/   rG   rF   r0   rE   r   r    rstrip)rK   essential_for_verboser;   instance_pathr   r   r   r   __str__c   s:   z_Error.__str__otherc                 C  s   | di |  S )Nr   	_contents)clsrd   r   r   r   create_from   s   z_Error.create_fromSequence[str | int]c                 C  2   | j }|d u r
| jS t| j}|t|j |S rB   )r<   rE   r   
extendleftreversedabsolute_pathrK   r<   r3   r   r   r   rm         
z_Error.absolute_pathc                 C  rj   rB   )r<   rF   r   rk   rl   absolute_schema_pathrn   r   r   r   rp      ro   z_Error.absolute_schema_pathc                 C  sp   d}| j D ]0}t|tr|dt| d 7 }qt|r#|d| 7 }q|dddd}|d	| d
 7 }q|S )N$[].\z\\'z\'z['z'])rm   
isinstanceintr   &_JSON_PATH_COMPATIBLE_PROPERTY_PATTERNmatchreplace)rK   r3   elemescaped_elemr   r   r   	json_path   s   


z_Error.json_path_types.TypeChecker | Nonekwargsc                 K  sH   |d ur| j tu r|| _ | D ]\}}t| |tu r!t| || qd S rB   )rJ   rT   itemsgetattrsetattr)rK   r>   r   kvr   r   r   _set   s   z_Error._setc                   s   d} fdd|D S )N)
r1   r5   rH   r2   r7   r3   r;   r8   r9   r<   c                   s   i | ]}|t  |qS r   )r   )rU   attrrR   r   r   
<dictcomp>   s    z$_Error._contents.<locals>.<dictcomp>r   )rK   attrsr   rR   r   rf      s   z_Error._contentsboolc              	     sX   z j d }W n ttfy   Y dS w t|tr! j j|S t fdd|D S )NtypeFc                 3  s     | ]} j  j|V  qd S rB   )rJ   is_typer8   )rU   expected_typerR   r   r   rW      s
    
z'_Error._matches_type.<locals>.<genexpr>)	r9   KeyError	TypeErrorrw   r   rJ   r   r8   r^   )rK   expectedr   rR   r   _matches_type   s   
z_Error._matches_type)r1   r   r2   r   r3   r4   r5   r6   r7   r	   r8   r	   r9   r:   r;   r4   r<   r=   r>   r?   r@   rA   r@   r   )rd   r.   )r@   ri   rB   )r>   r   r   r	   r@   rA   )r@   r   )r+   
__module____qualname____annotations__rT   rD   rS   rc   classmethodrh   propertyrm   rp   r~   r   rf   r   __classcell__r   r   rM   r   r.   2   s8   
 
)
		r.   c                   @     e Zd ZdZdZdZdS )ValidationErrorz:
    An instance was invalid under a provided schema.
    r9   r8   Nr+   r   r   __doc__r/   r0   r   r   r   r   r          r   c                   @  r   )SchemaErrorzB
    A schema was invalid under its corresponding metaschema.
    
metaschemar9   Nr   r   r   r   r   r      r   r   F)slotsc                   @  s0   e Zd ZU dZdZded< dd Zdd	d
ZdS )r'   z&
    A ref could not be resolved.
    zjsonschema.exceptions.RefResolutionError is deprecated as of version 4.18.0. If you wish to catch potential reference resolution errors, directly catch referencing.exceptions.Unresolvable.	Exception_causec                 C  s   | j |j urtS | j|jkS rB   )rN   NotImplementedr   rK   rd   r   r   r   __eq__   s   z_RefResolutionError.__eq__r@   r   c                 C  
   t | jS rB   )r   r   rR   r   r   r   rc         
z_RefResolutionError.__str__Nr   )r+   r   r   r   r(   r   r   rc   r   r   r   r   r'      s   
 r'   c                   @  s>   e Zd ZdddZdd Zdd Zd	d
 Zdd Zdd ZdS )_WrappedReferencingErrorr5   _Unresolvablec                 C  s   t | d| d S )N_wrapped)object__setattr__)rK   r5   r   r   r   rD      s   z!_WrappedReferencingError.__init__c                 C  s4   |j | j u r| j|jkS |j | jj u r| j|kS tS rB   )rN   r   r   r   r   r   r   r      s
   
z_WrappedReferencingError.__eq__c                 C  s   t | j|S rB   )r   r   )rK   r   r   r   r   r-      s   z$_WrappedReferencingError.__getattr__c                 C  r   rB   )hashr   rR   r   r   r   __hash__   r   z!_WrappedReferencingError.__hash__c                 C     d| j dS )Nz<WrappedReferencingError rQ   )r   rR   r   r   r   rS        z!_WrappedReferencingError.__repr__c                 C  s   | j jj d| j  S )NrP   )r   rN   r+   rR   r   r   r   rc     s   z _WrappedReferencingError.__str__N)r5   r   )	r+   r   r   rD   r   r-   r   rS   rc   r   r   r   r   r      s    
r   c                   @  s$   e Zd ZdZdddZddd	Zd
S )UndefinedTypeCheckzN
    A type checker was asked to check a type it did not have registered.
    r   r   r@   rA   c                 C  s
   || _ d S rB   r   )rK   r   r   r   r   rD     r   zUndefinedTypeCheck.__init__c                 C  r   )NzType z  is unknown to this type checkerr   rR   r   r   r   rc     r   zUndefinedTypeCheck.__str__N)r   r   r@   rA   r   r+   r   r   r   rD   rc   r   r   r   r   r   	  s    
r   c                   @  s    e Zd ZdZdd Zdd ZdS )UnknownTypezP
    A validator was asked to validate an instance against an unknown type.
    c                 C  s   || _ || _|| _d S rB   )r   r8   r9   )rK   r   r8   r9   r   r   r   rD     s   
zUnknownType.__init__c              
   C  s:   d}t d| jdt| j|d dt| j|d d S )Nr[   z            Unknown type z, for validator with schema:
                r\   z7

            While checking instance:
                r]   )r   r   r    r9   r8   r`   )rK   r   r   r   r   rc     s   zUnknownType.__str__Nr   r   r   r   r   r     s    r   c                      s*   e Zd ZdZd fdd	Zdd Z  ZS )FormatErrorz%
    Validating a format failed.
    Nc                   s$   t  || || _| | _| _d S rB   )rC   rD   r1   r5   rI   )rK   r1   r5   rM   r   r   rD   2  s   zFormatError.__init__c                 C     | j S rB   )r1   rR   r   r   r   rc   7  s   zFormatError.__str__rB   )r+   r   r   r   rD   rc   r   r   r   rM   r   r   -  s    r   c                   @  s`   e Zd ZdZeZddddZdd	d
Zdd ZdddZ	dd Z
dd Zdd Zedd ZdS )	ErrorTreezF
    ErrorTrees make it easier to check which validations failed.
    r   errorsIterable[ValidationError]c                 C  sL   i | _ t| j| _|D ]}| }|jD ]}|| }q||j |j< |j|_qd S rB   )r   r   rN   rf   r3   r2   r8   	_instance)rK   r   rL   rY   elementr   r   r   rD   B  s   


zErrorTree.__init__index	str | intc                 C  s
   || j v S )zC
        Check whether ``instance[index]`` has any errors.
        re   rK   r   r   r   r   __contains__N     
zErrorTree.__contains__c                 C  s&   | j tur|| vr| j |  | j| S )aQ  
        Retrieve the child tree one level down at the given ``index``.

        If the index is not in the instance that this tree corresponds
        to and is not known by this tree, whatever error would be raised
        by ``instance.__getitem__`` will be propagated (usually this is
        some subclass of `LookupError`.
        )r   rT   rf   r   r   r   r   __getitem__T  s   	

zErrorTree.__getitem__valuec                 C  s   t jdtdd || j|< dS )a  
        Add an error to the tree at the given ``index``.

        .. deprecated:: v4.20.0

            Setting items on an `ErrorTree` is deprecated without replacement.
            To populate a tree, provide all of its sub-errors when you
            construct the tree.
        z8ErrorTree.__setitem__ is deprecated without replacement.r"   r#   N)r%   r&   r)   rf   )rK   r   r   r   r   r   __setitem__a  s   
zErrorTree.__setitem__c                 C  r   )zY
        Iterate (non-recursively) over the indices in the instance with errors.
        )iterrf   rR   r   r   r   __iter__r  r   zErrorTree.__iter__c                 C  r   )z,
        Return the `total_errors`.
        )total_errorsrR   r   r   r   __len__x  s   zErrorTree.__len__c                 C  s4   t | }|dkr
dnd}d| jj d| d| dS )N   rL   r   rO   z (z total z)>)lenrN   r+   )rK   totalr   r   r   r   rS   ~  s   zErrorTree.__repr__c                 C  s&   t dd | j D }t| j| S )zT
        The total number of errors in the entire tree, including children.
        c                 s  s    | ]	\}}t |V  qd S rB   )r   )rU   _treer   r   r   rW     s    z)ErrorTree.total_errors.<locals>.<genexpr>)sumrf   r   r   r   )rK   child_errorsr   r   r   r     s   zErrorTree.total_errorsN)r   )r   r   )r   r   )r   r   r   r   )r+   r   r   r   rT   r   rD   r   r   r   r   r   rS   r   r   r   r   r   r   r   ;  s    

r   c                   s    fdd}|S )a{  
    Create a key function that can be used to sort errors by relevance.

    Arguments:
        weak (set):
            a collection of validation keywords to consider to be
            "weak".  If there are two errors at the same level of the
            instance and one is in the set of weak validation keywords,
            the other error will take priority. By default, :kw:`anyOf`
            and :kw:`oneOf` are considered weak keywords and will be
            superseded by other same-level validation errors.

        strong (set):
            a collection of validation keywords to consider to be
            "strong"

    c                   s,   | j }t| j | j|v| v |   fS rB   )r2   r   r3   r   )rL   r2   strongweakr   r   	relevance  s   
zby_relevance.<locals>.relevancer   )r   r   r   r   r   r   by_relevance  s   
r   c                 C  sl   t | |dd}|du rdS |jr4tjd|j|d}t|dkr-||d ||d kr-|S |d }|js|S )a  
    Try to find an error that appears to be the best match among given errors.

    In general, errors that are higher up in the instance (i.e. for which
    `ValidationError.path` is shorter) are considered better matches,
    since they indicate "more" is wrong with the instance.

    If the resulting match is either :kw:`oneOf` or :kw:`anyOf`, the
    *opposite* assumption is made -- i.e. the deepest error is picked,
    since these keywords only need to match once, and any other errors
    may not be relevant.

    Arguments:
        errors (collections.abc.Iterable):

            the errors to select from. Do not provide a mixture of
            errors from different validation attempts (i.e. from
            different instances or schemas), since it won't produce
            sensical output.

        key (collections.abc.Callable):

            the key to use when sorting errors. See `relevance` and
            transitively `by_relevance` for more details (the default is
            to sort with the defaults of that function). Changing the
            default is only useful if you want to change the function
            that rates errors but still want the error context descent
            done by this function.

    Returns:
        the best matching error, or ``None`` if the iterable was empty

    .. note::

        This function is a heuristic. Its return value may change for a given
        set of inputs from version to version if better heuristics are added.

    N)keydefaultr"   )r   r   r   )maxrH   heapq	nsmallestr   )r   r   bestsmallestr   r   r   
best_match  s   '$r   )r   r	   r   r   )6r   
__future__r   collectionsr   r   pprintr   textwrapr   r   typingr   r	   r
   r   rer%   r   r   referencing.exceptionsr   r   
jsonschemar   collections.abcr   r   r   r   r   	frozensetr   r   r   compilery   UnsetrT   r    r-   r   r.   r   r   r'   r   r   r   r   r   r   r   r   r   r   r   r   <module>   sH    

 		Q 