X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=openbox%2Fextensions.c;h=23d3e0c818809eacd04eebfdc7021f5751509f67;hb=828c095c8b5a2df96a38faaeb8a0df504e68e70f;hp=2fdc686316321b278b188ee411a7104e5e8b957d;hpb=fa6f70ce3a1e5aff0cdafb4b641128f360278f2a;p=chaz%2Fopenbox diff --git a/openbox/extensions.c b/openbox/extensions.c index 2fdc6863..23d3e0c8 100644 --- a/openbox/extensions.c +++ b/openbox/extensions.c @@ -3,17 +3,17 @@ extensions.c for the Openbox window manager Copyright (c) 2006 Mikael Magnusson Copyright (c) 2003-2007 Dana Jansens - + This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version. - + This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. - + See the COPYING file for a copy of the GNU General Public License. */ @@ -33,14 +33,12 @@ gboolean extensions_randr = FALSE; gint extensions_randr_event_basep; gboolean extensions_sync = FALSE; gint extensions_sync_event_basep; -gboolean extensions_comp = FALSE; -gint extensions_comp_event_basep; -void extensions_query_all() +void extensions_query_all(void) { gint junk; (void)junk; - + #ifdef XKB extensions_xkb = XkbQueryExtension(ob_display, &junk, &extensions_xkb_event_basep, @@ -82,41 +80,16 @@ void extensions_query_all() ob_debug("X Sync extension is not present on the server or is an " "incompatible version\n"); #endif - -#ifdef USE_XCOMPOSITE - if (XCompositeQueryExtension(ob_display, &extensions_comp_event_basep, - &junk)) - { - gint major = 0, minor = 2; - XCompositeQueryVersion(ob_display, &major, &minor); - /* Version 0.2 is the first version to have the - XCompositeNameWindowPixmap() request. */ - if (major > 0 || minor >= 2) - extensions_comp = TRUE; - } - if (!extensions_comp) - ob_debug("X Composite extension is not present on the server or is an " - "incompatible version\n"); -#endif } void extensions_xinerama_screens(Rect **xin_areas, guint *nxin) { guint i; - gint l, r, t, b; + gint n, l, r, t, b; #ifdef XINERAMA - if (extensions_xinerama) { - guint i; - gint n; - XineramaScreenInfo *info = XineramaQueryScreens(ob_display, &n); - *nxin = n; - *xin_areas = g_new(Rect, *nxin + 1); - for (i = 0; i < *nxin; ++i) - RECT_SET((*xin_areas)[i], info[i].x_org, info[i].y_org, - info[i].width, info[i].height); - XFree(info); - } else + XineramaScreenInfo *info; #endif + if (ob_debug_xinerama) { gint w = WidthOfScreen(ScreenOfDisplay(ob_display, ob_screen)); gint h = HeightOfScreen(ScreenOfDisplay(ob_display, ob_screen)); @@ -125,7 +98,19 @@ void extensions_xinerama_screens(Rect **xin_areas, guint *nxin) RECT_SET((*xin_areas)[0], 0, 0, w/2, h); RECT_SET((*xin_areas)[1], w/2, 0, w-(w/2), h); } - else { +#ifdef XINERAMA + else if (extensions_xinerama && + (info = XineramaQueryScreens(ob_display, &n))) { + *nxin = n; + *xin_areas = g_new(Rect, *nxin + 1); + for (i = 0; i < *nxin; ++i) + RECT_SET((*xin_areas)[i], info[i].x_org, info[i].y_org, + info[i].width, info[i].height); + XFree(info); + } +#endif + else + { *nxin = 1; *xin_areas = g_new(Rect, *nxin + 1); RECT_SET((*xin_areas)[0], 0, 0, @@ -146,10 +131,3 @@ void extensions_xinerama_screens(Rect **xin_areas, guint *nxin) } RECT_SET((*xin_areas)[*nxin], l, t, r - l + 1, b - t + 1); } - -#ifdef USE_XCOMPOSITE -Picture extensions_create_composite_picture(Window win, Visual *vis, - gboolean *has_alpha) -{ -} -#endif