Streamline mutex stuff
This commit is contained in:
parent
438c4eee35
commit
831886a9b4
|
@ -45,49 +45,64 @@ HB_BEGIN_DECLS
|
||||||
|
|
||||||
#include <glib.h>
|
#include <glib.h>
|
||||||
|
|
||||||
typedef GStaticMutex hb_mutex_t;
|
typedef GStaticMutex hb_mutex_impl_t;
|
||||||
#define HB_MUTEX_INIT G_STATIC_MUTEX_INIT
|
#define HB_MUTEX_IMPL_INIT G_STATIC_MUTEX_INIT
|
||||||
#define hb_mutex_init(M) g_static_mutex_init (M)
|
#define hb_mutex_impl_init(M) g_static_mutex_init (M)
|
||||||
#define hb_mutex_lock(M) g_static_mutex_lock (M)
|
#define hb_mutex_impl_lock(M) g_static_mutex_lock (M)
|
||||||
#define hb_mutex_unlock(M) g_static_mutex_unlock (M)
|
#define hb_mutex_impl_unlock(M) g_static_mutex_unlock (M)
|
||||||
#define hb_mutex_free(M) g_static_mutex_free (M)
|
#define hb_mutex_impl_free(M) g_static_mutex_free (M)
|
||||||
|
|
||||||
|
|
||||||
#elif defined(_MSC_VER)
|
#elif defined(_MSC_VER)
|
||||||
|
|
||||||
#include <Windows.h>
|
#include <Windows.h>
|
||||||
|
|
||||||
typedef CRITICAL_SECTION hb_mutex_t;
|
typedef CRITICAL_SECTION hb_mutex_impl_t;
|
||||||
#define HB_MUTEX_INIT { NULL, 0, 0, NULL, NULL, 0 }
|
#define HB_MUTEX_IMPL_INIT { NULL, 0, 0, NULL, NULL, 0 }
|
||||||
#define hb_mutex_init(M) InitializeCriticalSection (M)
|
#define hb_mutex_impl_init(M) InitializeCriticalSection (M)
|
||||||
#define hb_mutex_lock(M) EnterCriticalSection (M)
|
#define hb_mutex_impl_lock(M) EnterCriticalSection (M)
|
||||||
#define hb_mutex_unlock(M) LeaveCriticalSection (M)
|
#define hb_mutex_impl_unlock(M) LeaveCriticalSection (M)
|
||||||
#define hb_mutex_free(M) DeleteCriticalSection (M)
|
#define hb_mutex_impl_free(M) DeleteCriticalSection (M)
|
||||||
|
|
||||||
|
|
||||||
#else
|
#else
|
||||||
|
|
||||||
#warning "Could not find any system to define platform macros, library will NOT be thread-safe"
|
#warning "Could not find any system to define platform macros, library will NOT be thread-safe"
|
||||||
|
|
||||||
typedef struct { volatile int m; } hb_mutex_t;
|
typedef struct { volatile int m; } hb_mutex_impl_t;
|
||||||
#define HB_MUTEX_INIT 0
|
#define HB_MUTEX_IMPL_INIT 0
|
||||||
#define hb_mutex_init(M) ((void) ((M)->m = 0))
|
#define hb_mutex_impl_init(M) ((void) ((M)->m = 0))
|
||||||
#define hb_mutex_lock(M) ((void) ((M)->m = 1))
|
#define hb_mutex_impl_lock(M) ((void) ((M)->m = 1))
|
||||||
#define hb_mutex_unlock(M) ((void) ((M)->m = 0))
|
#define hb_mutex_impl_unlock(M) ((void) ((M)->m = 0))
|
||||||
#define hb_mutex_free(M) ((void) ((M)-M = 2))
|
#define hb_mutex_impl_free(M) ((void) ((M)-M = 2))
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
struct hb_mutex_t
|
||||||
|
{
|
||||||
|
hb_mutex_impl_t m;
|
||||||
|
|
||||||
|
inline void init (void) { hb_mutex_impl_init (&m); }
|
||||||
|
inline void lock (void) { hb_mutex_impl_lock (&m); }
|
||||||
|
inline void unlock (void) { hb_mutex_impl_unlock (&m); }
|
||||||
|
inline void free (void) { hb_mutex_impl_free (&m); }
|
||||||
|
};
|
||||||
|
|
||||||
|
#define HB_MUTEX_INIT {HB_MUTEX_IMPL_INIT}
|
||||||
|
#define hb_mutex_init(M) (M)->init ()
|
||||||
|
#define hb_mutex_lock(M) (M)->lock ()
|
||||||
|
#define hb_mutex_unlock(M) (M)->unlock ()
|
||||||
|
#define hb_mutex_free(M) (M)->free ()
|
||||||
|
|
||||||
|
|
||||||
struct hb_static_mutex_t : hb_mutex_t
|
struct hb_static_mutex_t : hb_mutex_t
|
||||||
{
|
{
|
||||||
hb_static_mutex_t (void) {
|
hb_static_mutex_t (void) { this->init (); }
|
||||||
hb_mutex_init (this);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline void lock (void) { hb_mutex_lock (this); }
|
private:
|
||||||
inline void unlock (void) { hb_mutex_unlock (this); }
|
NO_COPY (hb_static_mutex_t);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -494,6 +494,14 @@ static inline unsigned char TOLOWER (unsigned char c)
|
||||||
((const char *) s)[3]))
|
((const char *) s)[3]))
|
||||||
|
|
||||||
|
|
||||||
|
/* C++ helpers */
|
||||||
|
|
||||||
|
/* Makes class uncopyable. Use in private: section. */
|
||||||
|
#define NO_COPY(T) \
|
||||||
|
T (const T &o); \
|
||||||
|
T &operator = (const T &o);
|
||||||
|
|
||||||
|
|
||||||
/* Debug */
|
/* Debug */
|
||||||
|
|
||||||
#ifndef HB_DEBUG
|
#ifndef HB_DEBUG
|
||||||
|
|
Loading…
Reference in New Issue