projects
/
free-sw
/
xcb
/
libxcb
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix IP6 work for FreeBSD/Mac.
[free-sw/xcb/libxcb]
/
src
/
xcb_xlib.c
diff --git
a/src/xcb_xlib.c
b/src/xcb_xlib.c
index
61518f7
..
59f972c
100644
(file)
--- a/
src/xcb_xlib.c
+++ b/
src/xcb_xlib.c
@@
-26,12
+26,30
@@
#include "xcbxlib.h"
#include "xcbint.h"
#include "xcbxlib.h"
#include "xcbint.h"
-unsigned int XCBGetRequestSent(XCBConnection *c)
+#include <assert.h>
+
+unsigned int xcb_get_request_sent(xcb_connection_t *c)
{
{
+ if(c->has_error)
+ return 0;
return c->out.request;
}
return c->out.request;
}
-pthread_mutex_t *XCBGetIOLock(XCBConnection *c)
+void xcb_xlib_lock(xcb_connection_t *c)
+{
+ _xcb_lock_io(c);
+ assert(!c->xlib.lock);
+ c->xlib.lock = 1;
+ c->xlib.thread = pthread_self();
+ _xcb_unlock_io(c);
+}
+
+void xcb_xlib_unlock(xcb_connection_t *c)
{
{
- return &c->iolock;
+ _xcb_lock_io(c);
+ assert(c->xlib.lock);
+ assert(pthread_equal(c->xlib.thread, pthread_self()));
+ c->xlib.lock = 0;
+ pthread_cond_broadcast(&c->xlib.cond);
+ _xcb_unlock_io(c);
}
}