summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorArnaud Fontaine <arnau@debian.org>2009-12-16 19:55:01 +0100
committerArnaud Fontaine <arfontaine@ITEM-58736.dhcp.oxfd.uk.sopra>2010-02-11 14:47:30 +0000
commit87a57de994ede5520ed4b3efd15aac47e704d31f (patch)
tree688b84abdfc36a4ca300e820715213e6377124ad
parent95f205f6acb9cbb71c44b5902a8d22416abdc910 (diff)
xcb_ewmh_init_atoms: use xcb_setup_roots_length()
-rw-r--r--ewmh/ewmh.c.m413
1 files changed, 6 insertions, 7 deletions
diff --git a/ewmh/ewmh.c.m4 b/ewmh/ewmh.c.m4
index 50e49a0..520d3a5 100644
--- a/ewmh/ewmh.c.m4
+++ b/ewmh/ewmh.c.m4
@@ -515,12 +515,9 @@ xcb_ewmh_init_atoms(xcb_connection_t *c,
ewmh->connection = c;
- xcb_screen_iterator_t screen_iter = xcb_setup_roots_iterator(xcb_get_setup(c));
- xcb_screen_iterator_t iter;
-
- for(iter = screen_iter; iter.rem; xcb_screen_next(&iter))
- ewmh->nb_screens++;
+ const xcb_setup_t *setup = xcb_get_setup(c);
+ ewmh->nb_screens = xcb_setup_roots_length(setup);
if(!ewmh->nb_screens)
return NULL;
@@ -528,8 +525,10 @@ xcb_ewmh_init_atoms(xcb_connection_t *c,
ewmh->screens = malloc(sizeof(xcb_screen_t *) * ewmh->nb_screens);
ewmh->_NET_WM_CM_Sn = malloc(sizeof(xcb_atom_t) * ewmh->nb_screens);
- for(iter = screen_iter, screen_nbr = 0; iter.rem; xcb_screen_next(&iter))
- ewmh->screens[screen_nbr++] = iter.data;
+ xcb_screen_iterator_t screen_iter = xcb_setup_roots_iterator(setup);
+ for(screen_iter = xcb_setup_roots_iterator(setup), screen_nbr = 0; screen_iter.rem;
+ xcb_screen_next(&screen_iter))
+ ewmh->screens[screen_nbr++] = screen_iter.data;
/* _NET_WM_CM_Sn atoms will be treated differently, by adding them
at the end of this array, than other atoms as it depends on the