HEX
Server: Apache/2.4.58 (Ubuntu)
System: Linux ns3133907 6.8.0-86-generic #87-Ubuntu SMP PREEMPT_DYNAMIC Mon Sep 22 18:03:36 UTC 2025 x86_64
User: cssnetorguk (1024)
PHP: 8.2.28
Disabled: NONE
Upload Files
File: //lib/python3/dist-packages/__pycache__/jsonpatch.cpython-312.pyc
�

M`�p��l�dZddlmZddlZddlZddlZddlZddlZ	ddlm	Z	ddlm
Z
mZdZdZ	ddlmZmZdZd	Zd
ZdZej4dk\reefZGd
�de�ZGd�de�ZGd�de�Z Gd�dee!�Z"d�Z#ejHejJe#��Z&de
fd�Z'e
fd�Z(Gd�de)�Z*Gd�de*�Z+Gd�de*�Z,Gd �d!e*�Z-Gd"�d#e*�Z.Gd$�d%e*�Z/Gd&�d'e*�Z0Gd(�d)e)�Z1Gd*�d+e)�Z2d,�Z3y#e
$reZ	Y��wxYw#e
$r
ddlmZmZeZY��wxYw)-z Apply JSON-Patches (RFC 6902) �)�unicode_literalsN)�MappingProxyType)�JsonPointer�JsonPointerException�)�MutableMapping�MutableSequenceu Stefan Kögl <stefan@skoegl.net>z1.32z0https://github.com/stefankoegl/python-json-patchzModified BSD License)�rc��eZdZdZy)�JsonPatchExceptionzBase Json Patch exceptionN��__name__�
__module__�__qualname__�__doc__���+/usr/lib/python3/dist-packages/jsonpatch.pyrrJ���#rrc��eZdZdZy)�InvalidJsonPatchz, Raised if an invalid JSON Patch is created Nr
rrrrrNs��6rrc��eZdZdZy)�JsonPatchConflicta
Raised if patch could not be applied due to conflict situation such as:
    - attempt to add object key when it already exists;
    - attempt to operate with nonexistence object key;
    - attempt to insert value to array at position beyond its size;
    - etc.
    Nr
rrrrrRs��rrc��eZdZdZy)�JsonPatchTestFailedz A Test operation failed Nr
rrrrrrrc��tjt�}|D]\}}||j|��t	d�|j�D��S)z'Convert duplicate keys values to lists.c3�PK�|]\}}|t|�dk(r|dn|f��� y�w)rrN)�len)�.0�key�valuess   r�	<genexpr>zmultidict.<locals>.<genexpr>fs4�����
�C��

�3�v�;�!�+�f�Q�i��8��s�$&)�collections�defaultdict�list�append�dict�items)�
ordered_pairs�mdictr �values    r�	multidictr,_s]��
�#�#�D�)�E�#�!�
��U�
�c�
���%� �!���!�;�;�=���r)�object_pairs_hookFc��t|t�rtj||��}n
t||��}|j	||�S)a�Apply list of patches to specified json document.

    :param doc: Document object.
    :type doc: dict

    :param patch: JSON patch as list of dicts or raw JSON-encoded string.
    :type patch: list or str

    :param in_place: While :const:`True` patch will modify target document.
                     By default patch will be applied to document copy.
    :type in_place: bool

    :param pointer_cls: JSON pointer class to use.
    :type pointer_cls: Type[JsonPointer]

    :return: Patched document object.
    :rtype: dict

    >>> doc = {'foo': 'bar'}
    >>> patch = [{'op': 'add', 'path': '/baz', 'value': 'qux'}]
    >>> other = apply_patch(doc, patch)
    >>> doc is not other
    True
    >>> other == {'foo': 'bar', 'baz': 'qux'}
    True
    >>> patch = [{'op': 'add', 'path': '/baz', 'value': 'qux'}]
    >>> apply_patch(doc, patch, in_place=True) == {'foo': 'bar', 'baz': 'qux'}
    True
    >>> doc == other
    True
    ��pointer_cls)�
isinstance�
basestring�	JsonPatch�from_string�apply)�doc�patch�in_placer0s    r�apply_patchr9rsA��B�%��$��%�%�e��%�E���%�[�9���;�;�s�H�%�%rc�2�tj|||��S)a!Generates patch by comparing two document objects. Actually is
    a proxy to :meth:`JsonPatch.from_diff` method.

    :param src: Data source document object.
    :type src: dict

    :param dst: Data source document object.
    :type dst: dict

    :param pointer_cls: JSON pointer class to use.
    :type pointer_cls: Type[JsonPointer]

    >>> src = {'foo': 'bar', 'numbers': [1, 3, 4, 8]}
    >>> dst = {'baz': 'qux', 'numbers': [1, 4, 7]}
    >>> patch = make_patch(src, dst)
    >>> new = patch.apply(src)
    >>> new == dst
    True
    r/)r3�	from_diff)�src�dstr0s   r�
make_patchr>�s��*���s�C�[��A�Arc�v�eZdZdZefd�Zd�Zd�Zd�Zd�Z	e
d��Ze
d��Zejd	��Zy
)�PatchOperationz'A single operation inside a JSON Patch.c�d�||_|jd�std��t|d|j�r&|dj|_|d|_||_y|d|_	|j|j
�|_||_y#t$r}td��d}~wwxYw)N�pathz#Operation must have a 'path' memberzInvalid 'path')	r0�__contains__rr1rB�location�pointer�	TypeError�	operation)�selfrGr0�exs    r�__init__zPatchOperation.__init__�s���&����%�%�f�-�"�#H�I�I��i��'��)9�)9�:�%�f�-�2�2�D�M�$�V�,�D�L�#���
&�f�-�D�M�
9�#�/�/��
�
�>���#�����
9�&�'7�8�8��
9�s�. B�	B/�B*�*B/c��td��)zGAbstract method that applies a patch operation to the specified object.z%should implement the patch operation.)�NotImplementedError)rH�objs  rr5zPatchOperation.apply�s��!�"I�J�Jrc�Z�tt|jj���S�N)�hash�	frozensetrGr(�rHs r�__hash__zPatchOperation.__hash__�s���I�d�n�n�2�2�4�5�6�6rc�V�t|t�sy|j|jk(S�NF)r1r@rG�rH�others  r�__eq__zPatchOperation.__eq__�s"���%��0���~�~����0�0rc��||k(SrOrrVs  r�__ne__zPatchOperation.__ne__�����5�=�!�!rc�R�dj|jjdd�S)N�/���)�joinrE�partsrRs rrBzPatchOperation.path�s"���x�x����*�*�3�B�/�0�0rc��	t|jjd�S#t$r|jjdcYSwxYw)Nr^)�intrEr`�
ValueErrorrRs rr zPatchOperation.key�sE��	*��t�|�|�)�)�"�-�.�.���	*��<�<�%�%�b�)�)�	*�s�!$�"A	�A	c��t|�|jjd<|jj|_|j|j
d<y)Nr^rB)�strrEr`rBrDrG)rHr+s  rr zPatchOperation.key�s=��!$�U�������2�����)�)��
�!%������v�rN)rrrrrrJr5rSrXrZ�propertyrBr �setterrrrr@r@�sb��1�.9�#�$K�7�1�
"��1��1��*��*�	�Z�Z�/��/rr@c�"�eZdZdZd�Zd�Zd�Zy)�RemoveOperationz/Removes an object property or an array element.c��|jj|�\}}	||=|S#ttf$r!}dj	|�}t|��d}~wwxYw)Nz(can't remove a non-existent object '{0}')rE�to_last�KeyError�
IndexError�formatr)rHrM�subobj�partrI�msgs      rr5zRemoveOperation.apply�s_���|�|�+�+�C�0����	)��t��
�
��	�*�%�	)�<�C�C�D�I�C�#�C�(�(��	)�s�%�A�A�Ac�z�|j|k(r+|j|k\r|xjdz
c_|S|dz}|S�Nr�rBr �rHrBr s   r�_on_undo_removezRemoveOperation._on_undo_remove�s=���9�9����x�x�3�����A�
���
��q����
rc�z�|j|k(r+|j|kDr|xjdzc_|S|dz}|Srsrtrus   r�_on_undo_addzRemoveOperation._on_undo_add��=���9�9����x�x�#�~����A�
���
��q����
rN�rrrrr5rvrxrrrriri�s��9���rric�"�eZdZdZd�Zd�Zd�Zy)�AddOperationz,Adds an object property or an array element.c��	|jd}|jj	|�\}}t|t�rJ|dk(r|j|�|S|t|�kDs|dkrtd��|j||�|St|t�r
|�|}|S|||<|S|�#tdjt|����tdj|j|���#t$r}td��d}~wwxYw)Nr+�/The operation does not contain a 'value' member�-rzcan't insert outside of list�invalid document type {0}�2unable to fully resolve json pointer {0}, part {1})rGrlrrErkr1r	r&rr�insertrrFrn�typerD)rHrMr+rIrorps      rr5zAddOperation.apply	s#��	C��N�N�7�+�E�
�|�|�+�+�C�0�����f�o�.��s�{��
�
�e�$�&�
�#��F��#�t�a�x�'�(F�G�G��
�
�d�E�*��
����
/��|����
� %��t���
�	�|�� ;� B� B�4��<� P�Q�Q�'�(\�(c�(c�dh�dq�dq�sw�(x�y�y��5�	C�"�A�C�
C��	C�s�C0�0	D	�9D�D	c�z�|j|k(r+|j|kDr|xjdz
c_|S|dz
}|Srsrtrus   rrvzAddOperation._on_undo_remove)ryrc�z�|j|k(r+|j|kDr|xjdzc_|S|dz
}|Srsrtrus   rrxzAddOperation._on_undo_add1ryrNrzrrrr|r|s��6��@�rr|c�"�eZdZdZd�Zd�Zd�Zy)�ReplaceOperationz?Replaces an object property or an array element by a new value.c��	|jd}|jj	|�\}}|�|S|dk(rtd��t|t�r|t|�k\s|dkr�td��t|t�r ||vrfdj|�}t|��|�#tdjt|����td	j|j|���|||<|S#t$r}td��d}~wwxYw)
Nr+r~rz7'path' with '-' can't be applied to 'replace' operationrzcan't replace outside of listz)can't replace a non-existent object '{0}'r�r�)rGrlrrErkr1r	rrrrnrFr�rD)rHrMr+rIrorprqs       rr5zReplaceOperation.apply=s��	C��N�N�7�+�E�
�|�|�+�+�C�0�����<��L��3�;�"�#\�]�]��f�o�.��s�6�{�"�d�Q�h�'�(G�H�H�
���
/��6�!�A�H�H��N��'��,�,��|�� ;� B� B�4��<� P�Q�Q�'�(\�(c�(c�dh�dq�dq�sw�(x�y�y���t���
��7�	C�"�A�C�
C��	C�s�C2�2	D�;D�Dc��|SrOrrus   rrvz ReplaceOperation._on_undo_remove]����
rc��|SrOrrus   rrxzReplaceOperation._on_undo_add`r�rNrzrrrr�r�:s��I��@�rr�c�f�eZdZdZd�Zed��Zed��Zejd��Zd�Z	d�Z
y)	�
MoveOperationz?Moves an object property or an array element to a new location.c���	t|jd|j�r|jd}n|j|jd�}|j|�\}}	||}|j|k(r|St|t�r&|jj|�rtd��td|jdd�|j��j|�}td|j|d�|j��j|�}|S#t$r}t	d��d}~wwxYw#ttf$r}tt|���d}~wwxYw)	N�from�.The operation does not contain a 'from' memberz*Cannot move values into their own children�remove��oprBr/�add�r�rBr+)r1rGr0rlrrkrmrrerEr�containsrir5r|rD�rHrM�from_ptrrIrorpr+s       rr5zMoveOperation.applygsg��	B��$�.�.��0�$�2B�2B�C��>�>�&�1���+�+�D�N�N�6�,B�C��
 �'�'��,����	-��4�L�E�
�<�<�8�#��J��f�n�-����%�%�h�/�#�$P�Q�Q����N�N�6�*�
��'�'�)�*/��s��	�
���M�M��
��'�'�	)�*/��s��		��
��;�	B�"�@�B�
B��	B���*�%�	-�#�C��G�,�,��	-�s0�AD �(D<� 	D9�)D4�4D9�<E$�E�E$c�z�|j|jd�}dj|jdd�S)Nr�r]r^)r0rGr_r`�rHr�s  r�	from_pathzMoveOperation.from_path�s5���#�#�D�N�N�6�$:�;���x�x����s��+�,�,rc��|j|jd�}	t|jd�S#t$r|jdcYSwxYw�Nr�r^)r0rGrbr`rFr�s  r�from_keyzMoveOperation.from_key�sR���#�#�D�N�N�6�$:�;��	&��x�~�~�b�)�*�*���	&��>�>�"�%�%�	&�s�8�A�Ac��|j|jd�}t|�|jd<|j|jd<yr�)r0rGrer`rB)rHr+r�s   rr�zMoveOperation.from_key�s?���#�#�D�N�N�6�$:�;�� ��Z����r��!)������v�rc���|j|k(r*|j|k\r|xjdz
c_n|dz}|j|k(r+|j|kDr|xjdz
c_|S|dz
}|Srs�r�r�rBr rus   rrvzMoveOperation._on_undo_remove�sl���>�>�T�!��}�}��#��
�
��"�
��q����9�9����x�x�#�~����A�
���
��q����
rc���|j|k(r*|j|kDr|xjdzc_n|dz}|j|k(r+|j|kDr|xjdzc_|S|dz
}|Srsr�rus   rrxzMoveOperation._on_undo_add�sl���>�>�T�!��}�}�s�"��
�
��"�
��q����9�9����x�x�#�~����A�
���
��q����
rN)rrrrr5rfr�r�rgrvrxrrrr�r�dsU��I�#�J�-��-��&��&��_�_�/��/�
�rr�c��eZdZdZd�Zy)�
TestOperationz!Test value by specified location.c
��	|jj|�\}}|�|}n|jj||�}	|jd}||k7r1d}t	|j|t|�|t|����|S#t$r}t	t|���d}~wwxYw#t$r}td��d}~wwxYw)Nr+r~z0{0} ({1}) is not equal to tested value {2} ({3}))rErk�walkrrrerGrlrrnr�)rHrMrorp�valrIr+rqs        rr5zTestOperation.apply�s���	/��<�<�/�/��4�L�F�D��|����l�l�'�'���5��	C��N�N�7�+�E�
�%�<�D�C�%�c�j�j��d�3�i�16��U��'E�F�
F��
��$�	/�%�c�"�g�.�.��	/��
�	C�"�A�C�
C��	C�s/�?B	�B.�		B+�B&�&B+�.	C�7C�CN�rrrrr5rrrr�r��s
��+�rr�c��eZdZdZd�Zy)�
CopyOperationzA Copies an object property or an array element to a new location c��	|j|jd�}|j	|�\}}	tj||�}td|j|d�|j��j|�}|S#t$r}td��d}~wwxYw#ttf$r}tt|���d}~wwxYw)Nr�r�r�r�r/)
r0rGrlrrk�copy�deepcopyrmrrer|rDr5r�s       rr5zCopyOperation.apply�s���	B��'�'����v�(>�?�H�
 �'�'��,����	-��M�M�&��,�/�E����M�M��
��'�'�	)�*/��s��		��
��!�	B�"�@�B�
B��	B���*�%�	-�#�C��G�,�,��	-�s.�B�B�	B�B�B�C�.C�CNr�rrrr�r��s
��K�rr�c	���eZdZeej
�Zee�Ze	e
eee
eed��Z	efd�Zd�Zd�ZeZd�Zd�Zd�Zd�Zed	efd
��Zedd	efd��Zdd
�Zed��Zdd�Z d�Z!y	)r3)r�r��replace�move�testr�c�d�||_||_|jD]}|j|��yrO)r7r0�_get_operation)rHr7r0r�s    rrJzJsonPatch.__init__(s4����
�&����*�*�	$�B�����#�	$rc�"�|j�S)zstr(self) -> self.to_string())�	to_stringrRs r�__str__zJsonPatch.__str__3s���~�~��rc�,�t|j�SrO)�boolr7rRs r�__bool__zJsonPatch.__bool__7����D�J�J��rc�,�t|j�SrO)�iterr7rRs r�__iter__zJsonPatch.__iter__<r�rc�>�tt|j��SrO)rP�tuple�_opsrRs rrSzJsonPatch.__hash__?s���E�$�)�)�$�%�%rc�V�t|t�sy|j|jk(SrU)r1r3r�rVs  rrXzJsonPatch.__eq__Bs"���%��+���y�y�E�J�J�&�&rc��||k(SrOrrVs  rrZzJsonPatch.__ne__Gr[rNc�F�|xs|j}||�}|||��S)a�Creates JsonPatch instance from string source.

        :param patch_str: JSON patch as raw string.
        :type patch_str: str

        :param loads: A function of one argument that loads a serialized
                      JSON string.
        :type loads: function

        :param pointer_cls: JSON pointer class to use.
        :type pointer_cls: Type[JsonPointer]

        :return: :class:`JsonPatch` instance.
        r/)�json_loader)�cls�	patch_str�loadsr0r�r7s      rr4zJsonPatch.from_stringJs)�� �.�s�����I�&���5�k�2�2rTc��|xs|j}t||||��}|jdd||�t|j	��}|||��S)aCCreates JsonPatch instance based on comparison of two document
        objects. Json patch would be created for `src` argument against `dst`
        one.

        :param src: Data source document object.
        :type src: dict

        :param dst: Data source document object.
        :type dst: dict

        :param dumps: A function of one argument that produces a serialized
                      JSON string.
        :type dumps: function

        :param pointer_cls: JSON pointer class to use.
        :type pointer_cls: Type[JsonPointer]

        :return: :class:`JsonPatch` instance.

        >>> src = {'foo': 'bar', 'numbers': [1, 3, 4, 8]}
        >>> dst = {'baz': 'qux', 'numbers': [1, 4, 7]}
        >>> patch = JsonPatch.from_diff(src, dst)
        >>> new = patch.apply(src)
        >>> new == dst
        True
        r/�N)�json_dumper�DiffBuilder�_compare_valuesr%�execute)	r�r<r=�optimization�dumpsr0r��builder�opss	         rr;zJsonPatch.from_diff^sT��>�.�s�����c�3���M������D�#�s�3��7�?�?�$�%���3�K�0�0rc�F�|xs|j}||j�S)z!Returns patch set as JSON string.)r�r7)rHr�r�s   rr�zJsonPatch.to_string�s!���/�t�/�/���4�:�:�&�&rc�T�tt|j|j��SrO)r��mapr�r7rRs rr�zJsonPatch._ops�s���S��,�,�d�j�j�9�:�:rc�x�|stj|�}|jD]}|j|�}�|S)a5Applies the patch to a given object.

        :param obj: Document object.
        :type obj: dict

        :param in_place: Tweaks the way how patch would be applied - directly to
                         specified `obj` or to its copy.
        :type in_place: bool

        :return: Modified `obj`.
        )r�r�r�r5)rHrMr8rGs    rr5zJsonPatch.apply�s=����-�-��$�C����	'�I��/�/�#�&�C�	'��
rc��d|vrtd��|d}t|t�std��||jvrtdj	|���|j|}|||j
��S)Nr�z&Operation does not contain 'op' memberzOperation must be a stringzUnknown operation {0!r}r/)rr1r2�
operationsrnr0)rHrGr�r�s    rr�zJsonPatch._get_operation�sy���y� �"�#K�L�L�
�t�_���"�j�)�"�#?�@�@�
�T�_�_�$�"�#<�#C�#C�B�#G�H�H��o�o�b�!���9�$�*:�*:�;�;rrO)F)"rrr�staticmethod�jsonr�r��
_jsonloadsr�rrir|r�r�r�r�r�rrJr�r��__nonzero__r�rSrXrZ�classmethodr4r;r�rfr�r5r�rrrr3r3�s����t�z�z�*�K��z�*�K�!�!��#����
#��J�,�Z+6�	$� � ��K� �&�'�
"��*.�K�3��3�&�(,�D�#�"1��"1�H'�
�;��;��*
<rr3c�z�eZdZejefd�Zd�Zd�Zd�Z	d�Z
d�Zd�Zd�Z
d	�Zd
�Zd�Zd�Zd
�Zd�Zy)r�c��||_||_iig|_ggg|_gx|_}||_||_||dg|ddyrO)r�r0�
index_storage�index_storage2�_DiffBuilder__root�src_doc�dst_doc)rHr�r�r�r0�roots      rrJzDiffBuilder.__init__�sS����
�&��� �"�X���!�2�h�������d���������t�$��Q�rc��|t|�f}	|j|}|j|�}|�|g||<y||j|�y#t$r#|j
|j||f�YywxYwrO)r�r��getr&rFr�)rHr+�index�st�	typed_key�storage�storeds       r�store_indexzDiffBuilder.store_index�s����D��K�(�	�		?��(�(��,�G��[�[��+�F��~�&+�W��	�"��	�"�)�)�%�0���	?�����#�*�*�I�u�+=�>�	?�s�(A
�A
�
)A9�8A9c�>�|t|�f}	|j|j|�}|r|j�Sy#t$rS|j
|}t
t|�dz
dd�D]%}||d|k(s�|j|�dccYSYywxYw)Nrr^r)r�r�r��poprFr��ranger)rHr+r�r�r�r��is       r�
take_indexzDiffBuilder.take_index�s����D��K�(�	�		-��'�'��+�/�/�	�:�F���z�z�|�#����	-��)�)�"�-�G��3�w�<��>�2�r�2�
-���1�:�a�=�I�-�"�;�;�q�>�!�,�,�
-�	-�s�/A�?B�B�B�Bc�H�|j}|d}|||gx|d<|d<|dS)Nrr�r�)rHr�r��lasts    rr�zDiffBuilder.insert�s6���{�{���A�w��!�4��,�,��Q��$�q�'��A�w�rc�.�|\}}}||d<||d<g|ddy)Nrrr)rHr��	link_prev�	link_next�_s     rr�zDiffBuilder.remove�s)��"'��	�9�a� �	�!�� �	�!����a�rc#�ZK�|j}|d}||ur|d��|d}||ur�yy�w�Nr�r�)rH�startr��currs    r�	iter_fromzDiffBuilder.iter_from�s<�����{�{���Q�x���$���q�'�M���7�D��$����&+�+c#�ZK�|j}|d}||ur|d��|d}||ur�yy�wr�r�)rHr�r�s   rr�zDiffBuilder.__iter__�s<�����{�{���A�w���$���q�'�M���7�D��$��r�c#�K�|j}|d}||ur�|d|ur�|d|dd}}|j|jk(rkt|�tk(rYt|�tk(rGtd|j|jdd�|j��j��|dd}��|dj��|d}||ur��yy�w)Nrr�r�r+r�r/)r�rDr�rir|r�rGr0)rHr�r��op_first�	op_seconds     rr�zDiffBuilder.execute�s������{�{���A�w���$���A�w�d�"�&*�1�g�t�A�w�q�z�)���$�$�	�(:�(:�:��X��/�9��Y��<�7�*�'� )� 2� 2�!*�!4�!4�W�!=�,�$(�#3�#3�	5�6?�Y�	?�
 ��7�1�:�D���q�'�#�#�#���7�D��$��s�CC
�C
c��|j|t�}|��|d}t|j�tk(rSt|�tk(rA|j|�D]-}|j
|j|j�|_�/|j|�|jt||�k7rAtd|jt||�d�|j��}|j|�yytdt||�|d�|j��}|j|�}|j||t �y)Nr�r��r�r�rBr/r�r�)r��
_ST_REMOVEr�r rbr�rvrBr�rD�
_path_joinr�r0r�r|r��_ST_ADD)	rHrBr �itemr�r��v�new_op�	new_indexs	         r�_item_addedzDiffBuilder._item_addeds"������j�1�����q��B��B�F�F�|�s�"�t�C�y�C�'7�����.�@�A��.�.�r�w�w����?�B�F�@�
�K�K����{�{�j��s�3�3�&� ��K�K�&�t�S�1�(� $�/�/�	1��
���F�#�
4�"��"�4��-��#� �+�+�	-�F�
���F�+�I����T�9�g�6rc��tdt||�d�|j��}|j|t�}|j|�}|��|d}|jj|j�d}t|�tk(rA|j|�D]-}	|	j|j|j�|_�/|j|�|j |j k7r5t#d|j |j d�|j��}||d<y|j|�y|j%||t&�y)Nr�r�r/r�rr�r)rirr0r�rr�rErkr�r�r%r�rxrBr r�rDr�r�r)
rHrBr r	rr�rr��
added_itemr
s
          r�
_item_removedzDiffBuilder._item_removeds,�� ���t�S�)�"
��'�'�)������g�.���K�K��'�	����q��B�
���+�+�D�L�L�9�!�<�J��J��4�'�����.�=�A��^�^�B�G�G�R�V�V�<�B�F�=�
�K�K������"�+�+�-�&� �"�O�O��K�K�(� $�/�/�	1��
 &�	�!�����I�&�
���T�9�j�9rc	�l�|jtdt||�|d�|j���y)Nr�r�r/)r�r�rr0)rHrBr r	s    r�_item_replacedzDiffBuilder._item_replaced?s6�����$���t�S�)��&
��'�'�	)�	*rc�\�t|j��}t|j��}||z
}||z
}|D]!}|j|t|�||��#|D]!}|j	|t|�||��#||zD]}|j||||||��yrO)�set�keysrrer
r�)	rHrBr<r=�src_keys�dst_keys�
added_keys�removed_keysr s	         r�_compare_dictszDiffBuilder._compare_dictsFs����s�x�x�z�?���s�x�x�z�?����(�
��(�*���	9�C����t�S��X�s�3�x�8�	9��	7�C����T�3�s�8�S��X�6�	7��h�&�	@�C�� � ��s�C��H�c�#�h�?�	@rc�T�t|�t|�}}t||�}t||�}t|�D]�}||kr�||||}
}	|	|
k(r�t	|	t
�r.t	|
t
�r|j
t||�|	|
��Vt	|	t�r.t	|
t�r|jt||�|	|
���|j|||	�|j|||
���||kDr|j||||���|j||||���yrO)r�max�minr�r1rrrr	�_compare_listsrr
)rHrBr<r=�len_src�len_dst�max_len�min_lenr �old�news           rrzDiffBuilder._compare_listsUs���s�8�S��X����g�w�'���g�w�'����>�	6�C��W�}��s�8�S��X�S���#�:����^�4��s�N�3��'�'�
�4��(=�s�C�H���_�5�"�3��8��'�'�
�4��(=�s�C�H��&�&�t�S�#�6��$�$�T�3��4��7�"��"�"�4��#�c�(�;�� � ��s�C��H�5�-	6rc�j�t|t�r.t|t�r|jt||�||�yt|t�r.t|t�r|jt||�||�y|j
|�|j
|�k(ry|j|||�yrO)r1rrrr	rr�r)rHrBr r<r=s     rr�zDiffBuilder._compare_valuesqs����c�>�*��3��/����
�4�� 5�s�C�@�
��_�
-��3��0����
�4�� 5�s�C�@��Z�Z��_��
�
�3��
/��
����c�3�/rN)rrrr�r�rrJr�r�r�r�r�r�r�r
rrrrr�rrrr�r��sS��/3�z�z�{�%�?�-������(7�2:�B*�
@�6�80rr�c�l�|�|S|dzt|�jdd�jdd�zS)Nr]�~z~0z~1)rer�rts  rrr�s9��
�{����#�:��C��(�(��d�3�;�;�C��F�F�Fr)4r�
__future__rr#r��	functoolsr��sys�typesr�ImportErrorr'�jsonpointerrrrr�collections.abcrr	�unicodere�
__author__�__version__�__website__�__license__�version_info�bytesr2�	Exceptionrrr�AssertionErrorrr,�partialr�r�r9r>�objectr@rir|r�r�r�r�r3r�rrrr�<module>r:s���B&�'�����
��&�
:���
�
��?�0�
���@��$�����v�����J�$��$�7�)�7��*��$�,�n�$�� �Y�
�
�t�z�z�Y�
G�
�&+��%&�P&1�B�03/�V�3/�l�n��<1�>�1�h'�~�'�TS�N�S�l�N��6�N��2@<��@<�FT0�&�T0�nG��y��������;�
�C��s"�D�D!�D�D�!D3�2D3