X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=include%2Fzebra-lock.h;h=7aa47f9985c64910612283c7e5eb583273f7a13d;hb=77686142af94172d1887190ebd47aeb53f704057;hp=01f338db309da799726c8ab0e53739baa0e4c690;hpb=c41c84a497ae744aa825a90f144c85b54f1cd4bb;p=idzebra-moved-to-github.git diff --git a/include/zebra-lock.h b/include/zebra-lock.h index 01f338d..7aa47f9 100644 --- a/include/zebra-lock.h +++ b/include/zebra-lock.h @@ -2,7 +2,10 @@ #ifndef ZEBRA_LOCK_H #define ZEBRA_LOCK_H -#if HAVE_PTHREAD_H +#ifdef WIN32 +#include +#endif +#if YAZ_POSIX_THREADS #include #endif @@ -11,7 +14,16 @@ YAZ_BEGIN_CDECL typedef struct { +#ifdef WIN32 + CRITICAL_SECTION mutex; +#else +# if YAZ_POSIX_THREADS pthread_mutex_t mutex; +# else + int dummy; +# endif +#endif + int state; } Zebra_mutex; YAZ_EXPORT int zebra_mutex_init (Zebra_mutex *p); @@ -22,8 +34,10 @@ YAZ_EXPORT int zebra_mutex_unlock (Zebra_mutex *p); typedef struct { int readers_reading; int writers_writing; +#if YAZ_POSIX_THREADS pthread_mutex_t mutex; pthread_cond_t lock_free; +#endif } Zebra_lock_rdwr; YAZ_EXPORT int zebra_lock_rdwr_init (Zebra_lock_rdwr *p); @@ -34,8 +48,12 @@ YAZ_EXPORT int zebra_lock_rdwr_runlock (Zebra_lock_rdwr *p); YAZ_EXPORT int zebra_lock_rdwr_wunlock (Zebra_lock_rdwr *p); typedef struct { +#if YAZ_POSIX_THREADS pthread_mutex_t mutex; pthread_cond_t cond; +#else + int dummy; +#endif } Zebra_mutex_cond; YAZ_EXPORT int zebra_mutex_cond_init (Zebra_mutex_cond *p); @@ -46,4 +64,5 @@ YAZ_EXPORT int zebra_mutex_cond_wait (Zebra_mutex_cond *p); YAZ_EXPORT int zebra_mutex_cond_signal (Zebra_mutex_cond *p); YAZ_END_CDECL + #endif