summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorColin Guthrie <cguthrie@mandriva.org>2010-09-18 10:37:11 +0100
committerColin Guthrie <cguthrie@mandriva.org>2010-09-18 12:05:26 +0100
commitc0e045d003b52c5edf8dbee10ff1545435bce297 (patch)
tree3ba7c2f22a0f23ae0e422f0f2e02a2bf164faef6
parent24014e779c889caf43bf9e9c29d645e505127743 (diff)
xcb: xcb_get_setup() can return 0, so make sure we check it before using
-rw-r--r--src/pulsecore/x11prop.c68
1 files changed, 48 insertions, 20 deletions
diff --git a/src/pulsecore/x11prop.c b/src/pulsecore/x11prop.c
index cc5987a84..4f2fec0d0 100644
--- a/src/pulsecore/x11prop.c
+++ b/src/pulsecore/x11prop.c
@@ -27,6 +27,8 @@
#include "x11prop.h"
+#include <pulsecore/macro.h>
+
#include <xcb/xproto.h>
#include <xcb/xcb_atom.h>
@@ -34,16 +36,33 @@
void pa_x11_set_prop(xcb_connection_t *xcb, const char *name, const char *data) {
xcb_screen_t *screen;
- xcb_atom_t a = xcb_atom_get(xcb, name);
- screen = xcb_setup_roots_iterator(xcb_get_setup(xcb)).data;
- xcb_change_property(xcb, XCB_PROP_MODE_REPLACE, screen->root, a, STRING, PA_XCB_FORMAT, (int) strlen(data), (const void*) data);
+ const xcb_setup_t *s;
+ xcb_atom_t a;
+
+ pa_assert(xcb);
+ pa_assert(name);
+ pa_assert(data);
+
+ if ((s = xcb_get_setup(xcb))) {
+ a = xcb_atom_get(xcb, name);
+ screen = xcb_setup_roots_iterator(s).data;
+ xcb_change_property(xcb, XCB_PROP_MODE_REPLACE, screen->root, a, STRING, PA_XCB_FORMAT, (int) strlen(data), (const void*) data);
+ }
}
void pa_x11_del_prop(xcb_connection_t *xcb, const char *name) {
xcb_screen_t *screen;
- xcb_atom_t a = xcb_atom_get(xcb, name);
- screen = xcb_setup_roots_iterator(xcb_get_setup(xcb)).data;
- xcb_delete_property(xcb, screen->root, a);
+ const xcb_setup_t *s;
+ xcb_atom_t a;
+
+ pa_assert(xcb);
+ pa_assert(name);
+
+ if ((s = xcb_get_setup(xcb))) {
+ a = xcb_atom_get(xcb, name);
+ screen = xcb_setup_roots_iterator(s).data;
+ xcb_delete_property(xcb, screen->root, a);
+ }
}
char* pa_x11_get_prop(xcb_connection_t *xcb, const char *name, char *p, size_t l) {
@@ -52,26 +71,35 @@ char* pa_x11_get_prop(xcb_connection_t *xcb, const char *name, char *p, size_t l
xcb_get_property_cookie_t req;
xcb_get_property_reply_t* prop = NULL;
xcb_screen_t *screen;
- xcb_atom_t a = xcb_atom_get(xcb, name);
- screen = xcb_setup_roots_iterator(xcb_get_setup(xcb)).data;
+ const xcb_setup_t *s;
+ xcb_atom_t a;
+
+ pa_assert(xcb);
+ pa_assert(name);
+ pa_assert(p);
+
+ if ((s = xcb_get_setup(xcb))) {
+ a = xcb_atom_get(xcb, name);
+ screen = xcb_setup_roots_iterator(s).data;
- req = xcb_get_property(xcb, 0, screen->root, a, STRING, 0, (uint32_t)(l-1));
- prop = xcb_get_property_reply(xcb, req, NULL);
+ req = xcb_get_property(xcb, 0, screen->root, a, STRING, 0, (uint32_t)(l-1));
+ prop = xcb_get_property_reply(xcb, req, NULL);
- if (!prop)
- goto finish;
+ if (!prop)
+ goto finish;
- if (PA_XCB_FORMAT != prop->format)
- goto finish;
+ if (PA_XCB_FORMAT != prop->format)
+ goto finish;
- len = xcb_get_property_value_length(prop);
- if (len < 1 || len >= (int)l)
- goto finish;
+ len = xcb_get_property_value_length(prop);
+ if (len < 1 || len >= (int)l)
+ goto finish;
- memcpy(p, xcb_get_property_value(prop), len);
- p[len] = 0;
+ memcpy(p, xcb_get_property_value(prop), len);
+ p[len] = 0;
- ret = p;
+ ret = p;
+ }
finish: