mirror of
https://github.com/ValveSoftware/Proton.git
synced 2025-01-13 07:08:10 +03:00
update filelock.py
To b30bdc4fb998f5f4350257235eb51147f9e81862 from https://github.com/benediktschmitt/py-filelock/
This commit is contained in:
parent
31fe51430a
commit
bcda92d532
57
filelock.py
57
filelock.py
@ -1,5 +1,3 @@
|
|||||||
#!/usr/bin/env python
|
|
||||||
|
|
||||||
# This is free and unencumbered software released into the public domain.
|
# This is free and unencumbered software released into the public domain.
|
||||||
#
|
#
|
||||||
# Anyone is free to copy, modify, publish, use, compile, sell, or
|
# Anyone is free to copy, modify, publish, use, compile, sell, or
|
||||||
@ -71,7 +69,7 @@ __all__ = [
|
|||||||
"FileLock"
|
"FileLock"
|
||||||
]
|
]
|
||||||
|
|
||||||
__version__ = "3.0.4"
|
__version__ = "3.0.12"
|
||||||
|
|
||||||
|
|
||||||
_logger = None
|
_logger = None
|
||||||
@ -105,6 +103,29 @@ class Timeout(TimeoutError):
|
|||||||
|
|
||||||
# Classes
|
# Classes
|
||||||
# ------------------------------------------------
|
# ------------------------------------------------
|
||||||
|
|
||||||
|
# This is a helper class which is returned by :meth:`BaseFileLock.acquire`
|
||||||
|
# and wraps the lock to make sure __enter__ is not called twice when entering
|
||||||
|
# the with statement.
|
||||||
|
# If we would simply return *self*, the lock would be acquired again
|
||||||
|
# in the *__enter__* method of the BaseFileLock, but not released again
|
||||||
|
# automatically.
|
||||||
|
#
|
||||||
|
# :seealso: issue #37 (memory leak)
|
||||||
|
class _Acquire_ReturnProxy(object):
|
||||||
|
|
||||||
|
def __init__(self, lock):
|
||||||
|
self.lock = lock
|
||||||
|
return None
|
||||||
|
|
||||||
|
def __enter__(self):
|
||||||
|
return self.lock
|
||||||
|
|
||||||
|
def __exit__(self, exc_type, exc_value, traceback):
|
||||||
|
self.lock.release()
|
||||||
|
return None
|
||||||
|
|
||||||
|
|
||||||
class BaseFileLock(object):
|
class BaseFileLock(object):
|
||||||
"""
|
"""
|
||||||
Implements the base class of a file lock.
|
Implements the base class of a file lock.
|
||||||
@ -214,7 +235,7 @@ class BaseFileLock(object):
|
|||||||
|
|
||||||
:arg float timeout:
|
:arg float timeout:
|
||||||
The maximum time waited for the file lock.
|
The maximum time waited for the file lock.
|
||||||
If ``timeout <= 0``, there is no timeout and this method will
|
If ``timeout < 0``, there is no timeout and this method will
|
||||||
block until the lock could be acquired.
|
block until the lock could be acquired.
|
||||||
If ``timeout`` is None, the default :attr:`~timeout` is used.
|
If ``timeout`` is None, the default :attr:`~timeout` is used.
|
||||||
|
|
||||||
@ -239,12 +260,11 @@ class BaseFileLock(object):
|
|||||||
with self._thread_lock:
|
with self._thread_lock:
|
||||||
self._lock_counter += 1
|
self._lock_counter += 1
|
||||||
|
|
||||||
try:
|
|
||||||
start_time = time.time()
|
|
||||||
while True:
|
|
||||||
lock_id = id(self)
|
lock_id = id(self)
|
||||||
lock_filename = self._lock_file
|
lock_filename = self._lock_file
|
||||||
|
start_time = time.time()
|
||||||
|
try:
|
||||||
|
while True:
|
||||||
with self._thread_lock:
|
with self._thread_lock:
|
||||||
if not self.is_locked:
|
if not self.is_locked:
|
||||||
logger().debug('Attempting to acquire lock %s on %s', lock_id, lock_filename)
|
logger().debug('Attempting to acquire lock %s on %s', lock_id, lock_filename)
|
||||||
@ -268,26 +288,7 @@ class BaseFileLock(object):
|
|||||||
self._lock_counter = max(0, self._lock_counter - 1)
|
self._lock_counter = max(0, self._lock_counter - 1)
|
||||||
|
|
||||||
raise
|
raise
|
||||||
|
return _Acquire_ReturnProxy(lock = self)
|
||||||
# This class wraps the lock to make sure __enter__ is not called
|
|
||||||
# twiced when entering the with statement.
|
|
||||||
# If we would simply return *self*, the lock would be acquired again
|
|
||||||
# in the *__enter__* method of the BaseFileLock, but not released again
|
|
||||||
# automatically.
|
|
||||||
class ReturnProxy(object):
|
|
||||||
|
|
||||||
def __init__(self, lock):
|
|
||||||
self.lock = lock
|
|
||||||
return None
|
|
||||||
|
|
||||||
def __enter__(self):
|
|
||||||
return self.lock
|
|
||||||
|
|
||||||
def __exit__(self, exc_type, exc_value, traceback):
|
|
||||||
self.lock.release()
|
|
||||||
return None
|
|
||||||
|
|
||||||
return ReturnProxy(lock = self)
|
|
||||||
|
|
||||||
def release(self, force = False):
|
def release(self, force = False):
|
||||||
"""
|
"""
|
||||||
|
Loading…
x
Reference in New Issue
Block a user