X-Git-Url: https://git.dogcows.com/gitweb?a=blobdiff_plain;f=obt%2Fdisplay.c;h=37b1215737bf1117e3dc95dcd7839a65d76bcb01;hb=4f280356392118b02f30bd961bd9b11cf5b81651;hp=049b6aefed2eac4fb6338023e97cb83f000a2de5;hpb=452627a51ce38229533dfe5d8eeb877b0918d02c;p=chaz%2Fopenbox diff --git a/obt/display.c b/obt/display.c index 049b6aef..37b12157 100644 --- a/obt/display.c +++ b/obt/display.c @@ -17,7 +17,9 @@ */ #include "obt/display.h" -#include "obt/util.h" +#include "obt/prop.h" +#include "obt/internal.h" +#include "obt/keyboard.h" #ifdef HAVE_STRING_H # include @@ -29,23 +31,124 @@ # include #endif -Display* obt_display_open(const char *display_name) +Display* obt_display = NULL; + +gboolean obt_display_error_occured = FALSE; + +gboolean obt_display_extension_xkb = FALSE; +gint obt_display_extension_xkb_basep; +gboolean obt_display_extension_shape = FALSE; +gint obt_display_extension_shape_basep; +gboolean obt_display_extension_xinerama = FALSE; +gint obt_display_extension_xinerama_basep; +gboolean obt_display_extension_randr = FALSE; +gint obt_display_extension_randr_basep; +gboolean obt_display_extension_sync = FALSE; +gint obt_display_extension_sync_basep; + +static gint xerror_handler(Display *d, XErrorEvent *e); + +static gboolean xerror_ignore = FALSE; + +gboolean obt_display_open(const char *display_name) { gchar *n; Display *d = NULL; n = display_name ? g_strdup(display_name) : NULL; - d = XOpenDisplay(n); + obt_display = d = XOpenDisplay(n); if (d) { + gint junk, major, minor; + (void)junk, (void)major, (void)minor; + if (fcntl(ConnectionNumber(d), F_SETFD, 1) == -1) g_message("Failed to set display as close-on-exec"); + XSetErrorHandler(xerror_handler); + + /* read what extensions are present */ +#ifdef XKB + major = XkbMajorVersion; + minor = XkbMinorVersion; + obt_display_extension_xkb = + XkbQueryExtension(d, &junk, + &obt_display_extension_xkb_basep, &junk, + &major, &minor); + if (!obt_display_extension_xkb) + g_message("XKB extension is not present on the server or too old"); +#endif + +#ifdef SHAPE + obt_display_extension_shape = + XShapeQueryExtension(d, &obt_display_extension_shape_basep, + &junk); + if (!obt_display_extension_shape) + g_message("X Shape extension is not present on the server"); +#endif + +#ifdef XINERAMA + obt_display_extension_xinerama = + XineramaQueryExtension(d, + &obt_display_extension_xinerama_basep, + &junk) && XineramaIsActive(d); + if (!obt_display_extension_xinerama) + g_message("Xinerama extension is not present on the server"); +#endif + +#ifdef XRANDR + obt_display_extension_randr = + XRRQueryExtension(d, &obt_display_extension_randr_basep, + &junk); + if (!obt_display_extension_randr) + g_message("XRandR extension is not present on the server"); +#endif + +#ifdef SYNC + obt_display_extension_sync = + XSyncQueryExtension(d, &obt_display_extension_sync_basep, + &junk) && XSyncInitialize(d, &junk, &junk); + if (!obt_display_extension_sync) + g_message("X Sync extension is not present on the server or is an " + "incompatible version"); +#endif + + obt_prop_startup(); + obt_keyboard_reload(); } g_free(n); - return d; + return obt_display != NULL; +} + +void obt_display_close(void) +{ + obt_keyboard_shutdown(); + if (obt_display) XCloseDisplay(obt_display); +} + +static gint xerror_handler(Display *d, XErrorEvent *e) +{ +#ifdef DEBUG + gchar errtxt[128]; + + XGetErrorText(d, e->error_code, errtxt, 127); + if (!xerror_ignore) { + if (e->error_code == BadWindow) + /*g_debug(_("X Error: %s\n"), errtxt)*/; + else + g_error("X Error: %s", errtxt); + } else + g_debug("Ignoring XError code %d '%s'", e->error_code, errtxt); +#else + (void)d; (void)e; +#endif + + obt_display_error_occured = TRUE; + return 0; } -void obt_display_close(Display *d) +void obt_display_ignore_errors(gboolean ignore) { - if (d) XCloseDisplay(d); + XSync(obt_display, FALSE); + xerror_ignore = ignore; + if (ignore) obt_display_error_occured = FALSE; }