]> Dogcows Code - chaz/openbox/blobdiff - obt/display.c
Merge branch 'backport' into work
[chaz/openbox] / obt / display.c
index d99667805e9ff7cc1fe715324ff7ffd94f4c35f5..f34fc574056915dc5151d4ea538ac12b7d4ddf48 100644 (file)
@@ -17,6 +17,9 @@
 */
 
 #include "obt/display.h"
+#include "obt/prop.h"
+#include "obt/internal.h"
+#include "obt/keyboard.h"
 
 #ifdef HAVE_STRING_H
 #  include <string.h>
@@ -28,6 +31,8 @@
 #  include <unistd.h>
 #endif
 
+Display* obt_display = NULL;
+
 gboolean obt_display_error_occured = FALSE;
 
 gboolean obt_display_extension_xkb       = FALSE;
@@ -45,13 +50,13 @@ static gint xerror_handler(Display *d, XErrorEvent *e);
 
 static gboolean xerror_ignore = FALSE;
 
-Display* obt_display_open(const char *display_name)
+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;
         (void)junk;
@@ -103,15 +108,19 @@ Display* obt_display_open(const char *display_name)
             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(Display *d)
+void obt_display_close(void)
 {
-    if (d) XCloseDisplay(d);
+    obt_keyboard_shutdown();
+    if (obt_display) XCloseDisplay(obt_display);
 }
 
 static gint xerror_handler(Display *d, XErrorEvent *e)
@@ -122,11 +131,11 @@ static gint xerror_handler(Display *d, XErrorEvent *e)
     XGetErrorText(d, e->error_code, errtxt, 127);
     if (!xerror_ignore) {
         if (e->error_code == BadWindow)
-            /*g_message(_("X Error: %s\n"), errtxt)*/;
+            /*g_debug(_("X Error: %s\n"), errtxt)*/;
         else
             g_error("X Error: %s", errtxt);
     } else
-        g_message("XError code %d '%s'", e->error_code, errtxt);
+        g_debug("Ignoring XError code %d '%s'", e->error_code, errtxt);
 #else
     (void)d; (void)e;
 #endif
@@ -135,9 +144,9 @@ static gint xerror_handler(Display *d, XErrorEvent *e)
     return 0;
 }
 
-void obt_display_ignore_errors(Display *d, gboolean ignore)
+void obt_display_ignore_errors(gboolean ignore)
 {
-    XSync(d, FALSE);
+    XSync(obt_display, FALSE);
     xerror_ignore = ignore;
     if (ignore) obt_display_error_occured = FALSE;
 }
This page took 0.021732 seconds and 4 git commands to generate.