diff options
author | Colin Guthrie <cguthrie@mandriva.org> | 2010-09-18 10:37:11 +0100 |
---|---|---|
committer | Colin Guthrie <cguthrie@mandriva.org> | 2010-09-18 12:05:26 +0100 |
commit | c0e045d003b52c5edf8dbee10ff1545435bce297 (patch) | |
tree | 3ba7c2f22a0f23ae0e422f0f2e02a2bf164faef6 | |
parent | 24014e779c889caf43bf9e9c29d645e505127743 (diff) |
xcb: xcb_get_setup() can return 0, so make sure we check it before using
-rw-r--r-- | src/pulsecore/x11prop.c | 68 |
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: |