make portalocker really optional
Signed-off-by: Nicolas Sebrecht <nicolas.s-dev@laposte.net>
This commit is contained in:
parent
93bc8d11ac
commit
801893cc73
@ -35,6 +35,9 @@ SYNC_MUTEXES_LOCK = Lock()
|
|||||||
|
|
||||||
try:
|
try:
|
||||||
import portalocker
|
import portalocker
|
||||||
|
except:
|
||||||
|
try:
|
||||||
|
import fcntl
|
||||||
except:
|
except:
|
||||||
pass # Ok if this fails, we can do without.
|
pass # Ok if this fails, we can do without.
|
||||||
|
|
||||||
@ -234,8 +237,11 @@ class SyncableAccount(Account):
|
|||||||
try:
|
try:
|
||||||
portalocker.lock(self._lockfd, portalocker.LOCK_EX)
|
portalocker.lock(self._lockfd, portalocker.LOCK_EX)
|
||||||
except NameError:
|
except NameError:
|
||||||
#fcntl not available (Windows), disable file locking... :(
|
# portalocker not available for Windows.
|
||||||
pass
|
try:
|
||||||
|
fcntl.lockf(self._lockfd, fcntl.LOCK_EX|fcntl.LOCK_NB)
|
||||||
|
except NameError:
|
||||||
|
pass # fnctl not available, disable file locking... :(
|
||||||
except IOError:
|
except IOError:
|
||||||
self._lockfd.close()
|
self._lockfd.close()
|
||||||
six.reraise(OfflineImapError,
|
six.reraise(OfflineImapError,
|
||||||
@ -250,7 +256,10 @@ class SyncableAccount(Account):
|
|||||||
|
|
||||||
#If we own the lock file, delete it
|
#If we own the lock file, delete it
|
||||||
if self._lockfd and not self._lockfd.closed:
|
if self._lockfd and not self._lockfd.closed:
|
||||||
|
try:
|
||||||
portalocker.unlock(self._lockfd)
|
portalocker.unlock(self._lockfd)
|
||||||
|
except NameError:
|
||||||
|
pass
|
||||||
self._lockfd.close()
|
self._lockfd.close()
|
||||||
try:
|
try:
|
||||||
os.unlink(self._lockfilepath)
|
os.unlink(self._lockfilepath)
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
# Requirements
|
# Requirements
|
||||||
six
|
six
|
||||||
gssapi[kerberos]
|
gssapi[kerberos]
|
||||||
portalocker
|
portalocker[cygwin]
|
||||||
|
Loading…
Reference in New Issue
Block a user