diff options
author | Po Lu <luangruo@yahoo.com> | 2022-01-09 13:30:26 +0000 |
---|---|---|
committer | Po Lu <luangruo@yahoo.com> | 2022-01-09 13:34:19 +0000 |
commit | 691015fedbb94c69fd7d5b0fffe9df9715bb0158 (patch) | |
tree | 92cfa2f3ac9cb9242c8bbdedae0a9266dbb1b31c /src/filelock.c | |
parent | 54971f5c14fd430208bd456d9f6efcb28b6abe28 (diff) | |
download | emacs-691015fedbb94c69fd7d5b0fffe9df9715bb0158.tar.gz |
Fix filelock.c for Haiku
This was found during the investigation surrounding bug#53136,
but is not directly related.
* src/filelock.c (lock_if_free): Explictly test err against -1
or -2, and reverse sign of system errors on Haiku. (No Haiku
error occupies -1 or -2.)
Diffstat (limited to 'src/filelock.c')
-rw-r--r-- | src/filelock.c | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/src/filelock.c b/src/filelock.c index a213c2b3cae..8453f17cd4b 100644 --- a/src/filelock.c +++ b/src/filelock.c @@ -608,7 +608,7 @@ lock_if_free (lock_info_type *clasher, char *lfname) err = current_lock_owner (clasher, lfname); if (err != 0) { - if (err < 0) + if (err == -1 || err == -2) return -2 - err; /* We locked it, or someone else has it. */ break; /* current_lock_owner returned strange error. */ } @@ -616,7 +616,14 @@ lock_if_free (lock_info_type *clasher, char *lfname) /* We deleted a stale lock; try again to lock the file. */ } +#if !defined HAIKU \ + || defined BE_USE_POSITIVE_POSIX_ERRORS return err; +#else + /* On Haiku, POSIX error values are negative by default, but this + code's callers assume that any errno value is positive. */ + return -err; +#endif } static Lisp_Object |