Allow disconnecting connections that are in error state.
In support of this, consolidate the two static error_connection definitions into one so we don't try to free the static out-of-memory error_connection. Commit by Josh Triplett and Jamey Sharp. Signed-off-by: Josh Triplett <josh@joshtriplett.org> Signed-off-by: Jamey Sharp <jamey@minilop.net>
This commit is contained in:
parent
f0565e8f06
commit
1c4717de36
|
@ -58,7 +58,7 @@ typedef struct {
|
|||
uint16_t length;
|
||||
} xcb_setup_generic_t;
|
||||
|
||||
static const int error_connection = 1;
|
||||
const int error_connection = 1;
|
||||
|
||||
static int set_fd_flags(const int fd)
|
||||
{
|
||||
|
@ -293,7 +293,7 @@ xcb_connection_t *xcb_connect_to_fd(int fd, xcb_auth_info_t *auth_info)
|
|||
|
||||
void xcb_disconnect(xcb_connection_t *c)
|
||||
{
|
||||
if(c->has_error)
|
||||
if(c == (xcb_connection_t *) &error_connection)
|
||||
return;
|
||||
|
||||
free(c->setup);
|
||||
|
|
|
@ -54,8 +54,6 @@
|
|||
#include "xcbext.h"
|
||||
#include "xcbint.h"
|
||||
|
||||
static const int error_connection = 1;
|
||||
|
||||
int xcb_popcount(uint32_t mask)
|
||||
{
|
||||
uint32_t y;
|
||||
|
|
|
@ -174,6 +174,8 @@ void _xcb_ext_destroy(xcb_connection_t *c);
|
|||
|
||||
/* xcb_conn.c */
|
||||
|
||||
extern const int error_connection;
|
||||
|
||||
struct xcb_connection_t {
|
||||
int has_error;
|
||||
|
||||
|
|
Loading…
Reference in New Issue