Fix building without the X11 GDK backend
This commit is contained in:
parent
592aa42055
commit
14b8ac2fb2
|
@ -28,7 +28,10 @@
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#include <gdk/gdk.h>
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
# include <gdk/gdkx.h>
|
# include <gdk/gdkx.h>
|
||||||
|
#endif
|
||||||
#include "Desktop.h"
|
#include "Desktop.h"
|
||||||
|
|
||||||
|
|
||||||
|
@ -38,6 +41,7 @@
|
||||||
/* gdk_window_clear */
|
/* gdk_window_clear */
|
||||||
void gdk_window_clear(GdkWindow * window)
|
void gdk_window_clear(GdkWindow * window)
|
||||||
{
|
{
|
||||||
|
# if defined(GDK_WINDOWING_X11)
|
||||||
Display * display;
|
Display * display;
|
||||||
Window wid;
|
Window wid;
|
||||||
|
|
||||||
|
@ -46,6 +50,7 @@ void gdk_window_clear(GdkWindow * window)
|
||||||
gdk_error_trap_push();
|
gdk_error_trap_push();
|
||||||
XClearWindow(display, wid);
|
XClearWindow(display, wid);
|
||||||
gdk_error_trap_pop();
|
gdk_error_trap_pop();
|
||||||
|
# endif
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
|
|
@ -37,11 +37,13 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <gtk/gtk.h>
|
#include <gtk/gtk.h>
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
# if GTK_CHECK_VERSION(3, 0, 0)
|
# if GTK_CHECK_VERSION(3, 0, 0)
|
||||||
# include <gtk/gtkx.h>
|
# include <gtk/gtkx.h>
|
||||||
# else
|
# else
|
||||||
# include <gdk/gdkx.h>
|
# include <gdk/gdkx.h>
|
||||||
# endif
|
# endif
|
||||||
|
#endif
|
||||||
#include <System.h>
|
#include <System.h>
|
||||||
#include "Desktop.h"
|
#include "Desktop.h"
|
||||||
|
|
||||||
|
@ -52,11 +54,13 @@
|
||||||
typedef struct _MessageCallback
|
typedef struct _MessageCallback
|
||||||
{
|
{
|
||||||
GtkWidget * window;
|
GtkWidget * window;
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
# if GTK_CHECK_VERSION(3, 0, 0)
|
# if GTK_CHECK_VERSION(3, 0, 0)
|
||||||
Atom atom;
|
Atom atom;
|
||||||
# else
|
# else
|
||||||
GtkWidget * widget;
|
GtkWidget * widget;
|
||||||
Window xwindow;
|
Window xwindow;
|
||||||
|
# endif
|
||||||
#endif
|
#endif
|
||||||
DesktopMessageCallback callback;
|
DesktopMessageCallback callback;
|
||||||
void * data;
|
void * data;
|
||||||
|
@ -70,8 +74,10 @@ static size_t _callbacks_cnt = 0;
|
||||||
|
|
||||||
/* prototypes */
|
/* prototypes */
|
||||||
/* callbacks */
|
/* callbacks */
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
static GdkFilterReturn _desktop_message_on_callback(GdkXEvent * xevent,
|
static GdkFilterReturn _desktop_message_on_callback(GdkXEvent * xevent,
|
||||||
GdkEvent * event, gpointer data);
|
GdkEvent * event, gpointer data);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
/* public */
|
/* public */
|
||||||
|
@ -83,9 +89,11 @@ int desktop_message_register(GtkWidget * window, char const * destination,
|
||||||
MessageCallback ** p;
|
MessageCallback ** p;
|
||||||
MessageCallback * mc;
|
MessageCallback * mc;
|
||||||
GdkWindow * gwindow;
|
GdkWindow * gwindow;
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
# if !GTK_CHECK_VERSION(3, 0, 0)
|
# if !GTK_CHECK_VERSION(3, 0, 0)
|
||||||
GdkAtom atom;
|
GdkAtom atom;
|
||||||
# endif
|
# endif
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifdef DEBUG
|
#ifdef DEBUG
|
||||||
fprintf(stderr, "DEBUG: %s(%p, \"%s\", %p, %p)\n", __func__, window,
|
fprintf(stderr, "DEBUG: %s(%p, \"%s\", %p, %p)\n", __func__, window,
|
||||||
|
@ -99,6 +107,7 @@ int desktop_message_register(GtkWidget * window, char const * destination,
|
||||||
_callbacks[_callbacks_cnt++] = mc;
|
_callbacks[_callbacks_cnt++] = mc;
|
||||||
mc->callback = callback;
|
mc->callback = callback;
|
||||||
mc->data = data;
|
mc->data = data;
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
# if GTK_CHECK_VERSION(3, 0, 0)
|
# if GTK_CHECK_VERSION(3, 0, 0)
|
||||||
mc->atom = XInternAtom(gdk_x11_get_default_xdisplay(), destination,
|
mc->atom = XInternAtom(gdk_x11_get_default_xdisplay(), destination,
|
||||||
FALSE);
|
FALSE);
|
||||||
|
@ -116,6 +125,7 @@ int desktop_message_register(GtkWidget * window, char const * destination,
|
||||||
mc->xwindow = GDK_WINDOW_XWINDOW(gwindow);
|
mc->xwindow = GDK_WINDOW_XWINDOW(gwindow);
|
||||||
atom = gdk_atom_intern(destination, FALSE);
|
atom = gdk_atom_intern(destination, FALSE);
|
||||||
gdk_add_client_message_filter(atom, _desktop_message_on_callback, mc);
|
gdk_add_client_message_filter(atom, _desktop_message_on_callback, mc);
|
||||||
|
# endif
|
||||||
#endif
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -125,6 +135,7 @@ int desktop_message_register(GtkWidget * window, char const * destination,
|
||||||
int desktop_message_send(char const * destination, uint32_t value1,
|
int desktop_message_send(char const * destination, uint32_t value1,
|
||||||
uint32_t value2, uint32_t value3)
|
uint32_t value2, uint32_t value3)
|
||||||
{
|
{
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
# if GTK_CHECK_VERSION(3, 0, 0)
|
# if GTK_CHECK_VERSION(3, 0, 0)
|
||||||
GdkDisplay * display;
|
GdkDisplay * display;
|
||||||
Display * xdisplay;
|
Display * xdisplay;
|
||||||
|
@ -166,6 +177,10 @@ int desktop_message_send(char const * destination, uint32_t value1,
|
||||||
gdk_event_send_clientmessage_toall(&event);
|
gdk_event_send_clientmessage_toall(&event);
|
||||||
return 0;
|
return 0;
|
||||||
# endif
|
# endif
|
||||||
|
#else
|
||||||
|
/* FIXME not implemented */
|
||||||
|
return -1;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -196,6 +211,7 @@ void desktop_message_unregister(GtkWidget * window,
|
||||||
#else
|
#else
|
||||||
w = gtk_widget_get_window(mc->widget);
|
w = gtk_widget_get_window(mc->widget);
|
||||||
#endif
|
#endif
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
gdk_window_remove_filter(w, _desktop_message_on_callback, mc);
|
gdk_window_remove_filter(w, _desktop_message_on_callback, mc);
|
||||||
# if !GTK_CHECK_VERSION(3, 0, 0)
|
# if !GTK_CHECK_VERSION(3, 0, 0)
|
||||||
if(mc->window == NULL)
|
if(mc->window == NULL)
|
||||||
|
@ -207,11 +223,13 @@ void desktop_message_unregister(GtkWidget * window,
|
||||||
if((p = realloc(_callbacks, sizeof(*p) * (--_callbacks_cnt))) != NULL
|
if((p = realloc(_callbacks, sizeof(*p) * (--_callbacks_cnt))) != NULL
|
||||||
|| _callbacks_cnt == 0)
|
|| _callbacks_cnt == 0)
|
||||||
_callbacks = p;
|
_callbacks = p;
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
/* private */
|
/* private */
|
||||||
/* callbacks */
|
/* callbacks */
|
||||||
|
#if defined(GDK_WINDOWING_X11)
|
||||||
/* desktop_message_on_callback */
|
/* desktop_message_on_callback */
|
||||||
static GdkFilterReturn _desktop_message_on_callback(GdkXEvent * xevent,
|
static GdkFilterReturn _desktop_message_on_callback(GdkXEvent * xevent,
|
||||||
GdkEvent * event, gpointer data)
|
GdkEvent * event, gpointer data)
|
||||||
|
@ -254,3 +272,4 @@ static GdkFilterReturn _desktop_message_on_callback(GdkXEvent * xevent,
|
||||||
desktop_message_unregister(mc->window, mc->callback, mc->data);
|
desktop_message_unregister(mc->window, mc->callback, mc->data);
|
||||||
return GDK_FILTER_REMOVE;
|
return GDK_FILTER_REMOVE;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
Loading…
Reference in New Issue
Block a user