]> icculus.org git repositories - dana/openbox.git/blob - openbox/extensions.c
add support for _NET_WM_SYNC_REQUEST
[dana/openbox.git] / openbox / extensions.c
1 /* -*- indent-tabs-mode: nil; tab-width: 4; c-basic-offset: 4; -*-
2
3    extensions.c for the Openbox window manager
4    Copyright (c) 2006        Mikael Magnusson
5    Copyright (c) 2003-2007   Dana Jansens
6    
7    This program is free software; you can redistribute it and/or modify
8    it under the terms of the GNU General Public License as published by
9    the Free Software Foundation; either version 2 of the License, or
10    (at your option) any later version.
11    
12    This program is distributed in the hope that it will be useful,
13    but WITHOUT ANY WARRANTY; without even the implied warranty of
14    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15    GNU General Public License for more details.
16    
17    See the COPYING file for a copy of the GNU General Public License.
18 */
19
20 #include "openbox.h"
21 #include "geom.h"
22 #include "extensions.h"
23 #include "screen.h"
24 #include "debug.h"
25
26 gboolean extensions_xkb       = FALSE;
27 gint     extensions_xkb_event_basep;
28 gboolean extensions_shape     = FALSE;
29 gint     extensions_shape_event_basep;
30 gboolean extensions_xinerama  = FALSE;
31 gint     extensions_xinerama_event_basep;
32 gboolean extensions_randr     = FALSE;
33 gint     extensions_randr_event_basep;
34 gboolean extensions_sync      = FALSE;
35 gint     extensions_sync_event_basep;
36
37 void extensions_query_all()
38 {
39     gint junk;
40     (void)junk;
41      
42 #ifdef XKB
43     extensions_xkb =
44         XkbQueryExtension(ob_display, &junk, &extensions_xkb_event_basep,
45                           &junk, NULL, NULL);
46 #endif
47
48 #ifdef SHAPE
49     extensions_shape =
50         XShapeQueryExtension(ob_display, &extensions_shape_event_basep,
51                              &junk);
52 #endif
53
54 #ifdef XINERAMA
55     extensions_xinerama =
56         XineramaQueryExtension(ob_display, &extensions_xinerama_event_basep,
57                                &junk) && XineramaIsActive(ob_display);
58 #endif
59
60 #ifdef XRANDR
61     extensions_randr =
62         XRRQueryExtension(ob_display, &extensions_randr_event_basep,
63                           &junk);
64 #endif
65
66 #ifdef SYNC
67     extensions_sync =
68         XSyncQueryExtension(ob_display, &extensions_sync_event_basep,
69                             &junk) &&
70         XSyncInitialize(ob_display, &junk, &junk);
71     if (!extensions_sync)
72         ob_debug("X Sync extension is not present on the server or is an "
73                  "incompatible version");
74 #endif
75 }
76
77 void extensions_xinerama_screens(Rect **xin_areas, guint *nxin)
78 {
79     guint i;
80     gint l, r, t, b;
81 #ifdef XINERAMA
82     if (extensions_xinerama) {
83         guint i;
84         gint n;
85         XineramaScreenInfo *info = XineramaQueryScreens(ob_display, &n);
86         *nxin = n;
87         *xin_areas = g_new(Rect, *nxin + 1);
88         for (i = 0; i < *nxin; ++i)
89             RECT_SET((*xin_areas)[i], info[i].x_org, info[i].y_org,
90                      info[i].width, info[i].height);
91         XFree(info);
92     } else
93 #endif
94     {
95         *nxin = 1;
96         *xin_areas = g_new(Rect, *nxin + 1);
97         RECT_SET((*xin_areas)[0], 0, 0,
98                  WidthOfScreen(ScreenOfDisplay(ob_display, ob_screen)),
99                  HeightOfScreen(ScreenOfDisplay(ob_display, ob_screen)));
100     }
101
102     /* returns one extra with the total area in it */
103     l = (*xin_areas)[0].x;
104     t = (*xin_areas)[0].y;
105     r = (*xin_areas)[0].x + (*xin_areas)[0].width - 1;
106     b = (*xin_areas)[0].y + (*xin_areas)[0].height - 1;
107     for (i = 1; i < *nxin; ++i) {
108         l = MIN(l, (*xin_areas)[i].x);
109         t = MIN(l, (*xin_areas)[i].y);
110         r = MAX(r, (*xin_areas)[i].x + (*xin_areas)[i].width - 1);
111         b = MAX(b, (*xin_areas)[i].y + (*xin_areas)[i].height - 1);
112     }
113     RECT_SET((*xin_areas)[*nxin], l, t, r - l + 1, b - t + 1);
114 }