From 17da9c4062e9cc702c3f8a2c21ab688a67891205 Mon Sep 17 00:00:00 2001 From: BobTheBuidler <70677534+BobTheBuidler@users.noreply.github.com> Date: Fri, 22 Nov 2024 02:39:43 -0400 Subject: [PATCH] fix: temporary hacky-fix to prevent issues in downstream libs (#419) --- a_sync/primitives/locks/prio_semaphore.pyx | 29 +++++++++++++++++----- 1 file changed, 23 insertions(+), 6 deletions(-) diff --git a/a_sync/primitives/locks/prio_semaphore.pyx b/a_sync/primitives/locks/prio_semaphore.pyx index 9bf7e44c..bddb92a7 100644 --- a/a_sync/primitives/locks/prio_semaphore.pyx +++ b/a_sync/primitives/locks/prio_semaphore.pyx @@ -50,8 +50,15 @@ cdef class _AbstractPrioritySemaphore(Semaphore): # NOTE: This should (hopefully) be temporary self._potential_lost_waiters: List["asyncio.Future[None]"] = [] """A list of futures representing waiters that might have been lost.""" - - def __init__(self, value: int = 1, *, name: Optional[str] = None) -> None: + + def __init__( + self, + context_manager_class: Type[_AbstractPrioritySemaphoreContextManager], + top_priority: object, + value: int = 1, + *, + name: Optional[str] = None, + ) -> None: """Initializes the priority semaphore. Args: @@ -61,11 +68,15 @@ cdef class _AbstractPrioritySemaphore(Semaphore): Examples: >>> semaphore = _AbstractPrioritySemaphore(5, name="test_semaphore") """ + # context manager class is some temporary hacky shit, just ignore this super().__init__(value, name=name) self._capacity = value """The initial capacity of the semaphore.""" + self._top_priority = top_priority + self._context_manager_class = context_manager_class + def __repr__(self) -> str: """Returns a string representation of the semaphore.""" return f"<{self.__class__.__name__} name={self.name} capacity={self._capacity} value={self._Semaphore__value} waiters={self._count_waiters()}>" @@ -431,10 +442,7 @@ cdef class PrioritySemaphore(_AbstractPrioritySemaphore): # type: ignore [type- :class:`_AbstractPrioritySemaphore` for the base class implementation. """ - def __cinit__(self): - self._top_priority = -1 - self._context_manager_class = _PrioritySemaphoreContextManager - + def __cinit__(self): # _AbstractPrioritySemaphore.__cinit__(self) self._context_managers = {} @@ -446,6 +454,15 @@ cdef class PrioritySemaphore(_AbstractPrioritySemaphore): # type: ignore [type- # NOTE: This should (hopefully) be temporary self._potential_lost_waiters: List["asyncio.Future[None]"] = [] """A list of futures representing waiters that might have been lost.""" + + def __init__( + self, + value: int = 1, + *, + name: Optional[str] = None, + ) -> None: + # context manager class is some temporary hacky shit, just ignore this + super().__init__(_PrioritySemaphoreContextManager, -1, value, name=name) def __getitem__( self, priority: Optional[PT]