
    zc3                     8    d Z ddlZ G d dej                  ZdS )u  
Utility collections or "bricks".

:module: watchdog.utils.bricks
:author: yesudeep@google.com (Yesudeep Mangalapilly)
:author: lalinsky@gmail.com (Lukáš Lalinský)
:author: python@rcn.com (Raymond Hettinger)
:author: contact@tiger-222.fr (Mickaël Schoentgen)

Classes
=======
.. autoclass:: OrderedSetQueue
   :members:
   :show-inheritance:
   :inherited-members:

.. autoclass:: OrderedSet

    Nc                   6     e Zd ZdZ fdZ fdZ fdZ xZS )SkipRepeatsQueuea  Thread-safe implementation of an special queue where a
    put of the last-item put'd will be dropped.

    The implementation leverages locking already implemented in the base class
    redefining only the primitives.

    Queued items must be immutable and hashable so that they can be used
    as dictionary keys. You must implement **only read-only properties** and
    the :meth:`Item.__hash__()`, :meth:`Item.__eq__()`, and
    :meth:`Item.__ne__()` methods for items to be hashable.

    An example implementation follows::

        class Item:
            def __init__(self, a, b):
                self._a = a
                self._b = b

            @property
            def a(self):
                return self._a

            @property
            def b(self):
                return self._b

            def _key(self):
                return (self._a, self._b)

            def __eq__(self, item):
                return self._key() == item._key()

            def __ne__(self, item):
                return self._key() != item._key()

            def __hash__(self):
                return hash(self._key())

    based on the OrderedSetQueue below
    c                 X    t                                          |           d | _        d S N)super_init
_last_item)selfmaxsize	__class__s     5lib/python3.11/site-packages/watchdog/utils/bricks.pyr   zSkipRepeatsQueue._initU   s$    g    c                     | j         || j         k    r*t                                          |           || _         d S | xj        dz  c_        d S )N   )r	   r   _putunfinished_tasksr
   itemr   s     r   r   zSkipRepeatsQueue._putY   sX    ? 	'ddo&= 	'GGLL"DOOO !!Q&!!!!r   c                 h    t                                                      }|| j        u rd | _        |S r   )r   _getr	   r   s     r   r   zSkipRepeatsQueue._getb   s/    ww||~~4?" 	#"DOr   )__name__
__module____qualname____doc__r   r   r   __classcell__)r   s   @r   r   r   *   su        ' 'R    ' ' ' ' '        r   r   )r   queueQueuer    r   r   <module>r      sP   & ( < < < < <u{ < < < < <r   