summaryrefslogtreecommitdiff
path: root/win32
diff options
context:
space:
mode:
authorusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2006-02-04 12:21:55 +0000
committerusa <usa@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2006-02-04 12:21:55 +0000
commit49a2b019f645a161d4f5c2a0b0075eedd95df9fd (patch)
tree977ac12d326d26cc037ee08fe196d50f7c22c893 /win32
parentbc0e58a181ead48cb615c54cae146813fd056f6d (diff)
* win32/win32.c (LK_ERR): ERROR_NOT_LOCKED is not an error.
In such situation, flock() should return 0. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@9884 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'win32')
-rw-r--r--win32/win32.c15
1 files changed, 14 insertions, 1 deletions
diff --git a/win32/win32.c b/win32/win32.c
index ef6886af2b..ce69f3b826 100644
--- a/win32/win32.c
+++ b/win32/win32.c
@@ -250,7 +250,20 @@ GetCurrentThreadHandle(void)
/* simulate flock by locking a range on the file */
-#define LK_ERR(f,i) ((f) ? (i = 0) : (errno = GetLastError() == ERROR_LOCK_VIOLATION ? EWOULDBLOCK : EACCES))
+#define LK_ERR(f,i) \
+ do { \
+ if (f) \
+ i = 0; \
+ else { \
+ DWORD err = GetLastError(); \
+ if (err == ERROR_LOCK_VIOLATION) \
+ errno = EWOULDBLOCK; \
+ else if (err == ERROR_NOT_LOCKED) \
+ i = 0; \
+ else \
+ errno = map_errno(err); \
+ } \
+ } while (0)
#define LK_LEN ULONG_MAX
static VALUE