o UV@stdZddlmZddlZddlZddlZddlmZmZm Z m Z m Z m Z GdddeZ dd Zd d Zd d ZdS)z8 Lockfile behaviour implemented via Unix PID files. )absolute_importN)LockBase AlreadyLocked LockFailed NotLocked NotMyLock LockTimeoutc@sLeZdZdZdddZddZdd Zd d Zdd d ZddZ ddZ dS) PIDLockFileaA Lockfile implemented as a Unix PID file. The lock file is a normal file named by the attribute `path`. A lock's PID file contains a single line of text, containing the process ID (PID) of the process that acquired the lock. >>> lock = PIDLockFile('somefile') >>> lock = PIDLockFile('somefile') FNcCst||d||j|_dS)NF)r__init__path unique_name)selfr threadedtimeoutr6/usr/lib/python3/dist-packages/lockfile/pidlockfile.pyr $s zPIDLockFile.__init__cCs t|jS)z- Get the PID from the lock file. )read_pid_from_pidfiler rrrrread_pid*s zPIDLockFile.read_pidcCstj|jS)zv Test if the lock is currently held. The lock is held if the PID file for this lock exists. )osr existsrrrr is_locked/szPIDLockFile.is_lockedcCs|o t|kS)z Test if the lock is held by the current process. Returns ``True`` if the current process ID matches the number stored in the PID file. )rrgetpidrrrrr i_am_locking7szPIDLockFile.i_am_lockingc Cs|dur|n|j}t}|dur|dkr||7} zt|jWdStyk}z=|jtjkrZt|krL|durE|dkrEtd|jtd|jt |durV|dpWdnt d|jWYd}~nd}~wwq) z Acquire the lock. Creates the PID file for this lock, or raises an error if the lock could not be acquired. NrTz&Timeout waiting to acquire lock for %sz%s is already locked g?zfailed to create %s) rtimewrite_pid_to_pidfiler OSErrorerrnoEEXISTr rsleepr)rrend_timeexcrrracquire?s0    zPIDLockFile.acquirecCs:|s td|j|std|jt|jdS)z Release the lock. Removes the PID file to release the lock, or raises an error if the current process does not hold the lock. z%s is not lockedz%s is locked, but not by meN)rrr rrremove_existing_pidfilerrrrrelease_s zPIDLockFile.releasecCst|jdS)z Break an existing lock. Removes the PID file if it already exists, otherwise does nothing. N)r%r rrrr break_locklszPIDLockFile.break_lock)FN)N) __name__ __module__ __qualname____doc__r rrrr$r&r'rrrrr s   r cCs`d}zt|d}Wn tyY|Sw|}zt|}Wn ty)Ynw||S)z Read the PID recorded in the named PID file. Read and return the numeric PID recorded as text in the named PID file. If the PID file cannot be read, or if the content is not a valid PID, return ``None``. Nr)openIOErrorreadlinestripint ValueErrorclose) pidfile_pathpidpidfilelinerrrrvs    rcCsRtjtjBtjB}d}t|||}t|d}t}|d||dS)u Write the PID in the named PID file. Get the numeric process ID (“PID”) of the current process and write it to the named file as a line of text. iwz%s N) rO_CREATO_EXCLO_WRONLYr-fdopenrwriter3)r4 open_flags open_mode pidfile_fdr6r5rrrrs   rc CsHzt|WdSty#}z|jtjkrnWYd}~dSd}~ww)z Remove the named PID file if it exists. Removing a PID file that doesn't already exist puts us in the desired state, so we ignore the condition if the file does not exist. N)rremoverrENOENT)r4r#rrrr%s r%)r+ __future__rrrrrrrrrr r rrr%rrrrs  ]"