Package: wmcliphist
Tags: patch
Hi,
Attached is a patch for wmbubble to build against GTK+ 2.0:
- changes the required bits in the Makefile
- splits foo_create_main_icon_window() and creates foo_set_wmhints(),
as WMHints need to be set later on, once the windows are shown
- uses the new function in wmcliphist.c
Please apply, as it'll help clear the list of GTK+1.2 applications.
Thanks,
JB.
--
Julien BLACHE <[EMAIL PROTECTED]> | Debian, because code matters more
Debian & GNU/Linux Developer | <http://www.debian.org>
Public key available on <http://www.jblache.org> - KeyID: F5D6 5169
GPG Fingerprint : 935A 79F1 C8B3 3521 FD62 7CC7 CD61 4FD7 F5D6 5169
diff -ru orig/wmcliphist-0.6/Makefile wmcliphist-0.6/Makefile
--- orig/wmcliphist-0.6/Makefile 2003-06-24 00:35:45.000000000 +0200
+++ wmcliphist-0.6/Makefile 2007-08-12 16:21:16.772090470 +0200
@@ -1,6 +1,6 @@
CC = gcc
-INCLUDES = `gtk-config --cflags` -I. -Ifoodock -g
+INCLUDES = `pkg-config gtk+-2.0 --cflags` -I. -Ifoodock -g
DESTDIR = "/usr/local/bin"
@@ -15,7 +15,7 @@
#DEBUG = debug.o
-LFLAGS = `gtk-config --libs`
+LFLAGS = `pkg-config gtk+-2.0 --libs`
OBJECTS = wmcliphist.o clipboard.o gui.o rcconfig.o history.o hotkeys.o $(DEBUG)
diff -ru orig/wmcliphist-0.6/foodock/foodock.c wmcliphist-0.6/foodock/foodock.c
--- orig/wmcliphist-0.6/foodock/foodock.c 2001-03-16 01:59:46.000000000 +0100
+++ wmcliphist-0.6/foodock/foodock.c 2007-08-12 16:34:44.818138390 +0200
@@ -21,6 +21,8 @@
* before calling foo_create_main_icon_window. Returned event box
* will be realized by foo_create_main_icon_window. You should to show
* icon window as well as main window before gtk_main().
+ *
+ * Call foo_set_wmhints() after both windows are shown (gtk_widget_show()).
*
* Input:
* mw Pointer to main window
@@ -34,20 +36,37 @@
char *margv[]) {
GtkWidget *foobox; /* This will become icon box */
- Window xmw;
- XWMHints *wm_hints;
-
- xmw = GDK_WINDOW_XWINDOW(mw->window);
foobox = gtk_event_box_new();
gtk_widget_set_usize(foobox, s, s);
gtk_container_add (GTK_CONTAINER (mw), foobox);
gtk_widget_realize(foobox);
-
+
+ return foobox;
+}
+
+/*
+ * Set WMHints on the dockapp (icon) window. Needs to be called after
+ * the main window is shown, due to changes in GTK+ 2.4.
+ *
+ * Input:
+ * mw Pointer to main window
+ * dw Pointer to icon (dockapp) window
+ * margc, margv argc and argv of main program for XSetCommand
+ */
+void foo_set_wmhints(GtkWidget *mw,
+ GtkWidget *dw,
+ int margc,
+ char *margv[]) {
+ Window xmw;
+ XWMHints *wm_hints;
+
+ xmw = GDK_WINDOW_XWINDOW(mw->window);
+
/* Time for game with Xlib */
wm_hints = XAllocWMHints();
wm_hints->window_group = xmw;
- wm_hints->icon_window = GDK_WINDOW_XWINDOW(foobox->window);
+ wm_hints->icon_window = GDK_WINDOW_XWINDOW(dw->window);
wm_hints->icon_x = 0;
wm_hints->icon_y = 0;
wm_hints->initial_state = WithdrawnState;
@@ -60,6 +79,4 @@
XSetCommand(GDK_DISPLAY(), xmw, margv, margc);
XFree(wm_hints);
-
- return foobox;
}
diff -ru orig/wmcliphist-0.6/foodock/foodock.h wmcliphist-0.6/foodock/foodock.h
--- orig/wmcliphist-0.6/foodock/foodock.h 2001-03-16 01:59:52.000000000 +0100
+++ wmcliphist-0.6/foodock/foodock.h 2007-08-12 16:34:40.317881934 +0200
@@ -15,6 +15,8 @@
* before calling foo_create_main_icon_window. Returned event box
* will be realized by foo_create_main_icon_window. You should to show
* icon window as well as main window before gtk_main().
+ *
+ * Call foo_set_wmhints() after both windows are shown (gtk_widget_show()).
*
* Input:
* mw Pointer to main window
@@ -25,3 +27,17 @@
unsigned int size,
int main_argc,
char *main_argv[]);
+
+/*
+ * Set WMHints on the dockapp (icon) window. Needs to be called after
+ * the main window is shown, due to changes in GTK+ 2.4.
+ *
+ * Input:
+ * mw Pointer to main window
+ * dw Pointer to icon (dockapp) window
+ * margc, margv argc and argv of main program for XSetCommand
+ */
+void foo_set_wmhints(GtkWidget *mw,
+ GtkWidget *dw,
+ int margc,
+ char *margv[]);
diff -ru orig/wmcliphist-0.6/wmcliphist.c wmcliphist-0.6/wmcliphist.c
--- orig/wmcliphist-0.6/wmcliphist.c 2003-06-23 23:24:24.000000000 +0200
+++ wmcliphist-0.6/wmcliphist.c 2007-08-12 16:31:20.806512430 +0200
@@ -333,6 +333,10 @@
/* show icon */
gtk_widget_show(dock_app);
gtk_widget_show(main_window);
+
+ /* Set WMHints - after gtk_widget_show() due to changes in GTK+ 2.4 */
+ foo_set_wmhints(main_window, dock_app, argc, argv);
+
gdk_window_shape_combine_mask(main_window->window, icon_mask, 0, 0);
gdk_window_shape_combine_mask(dock_app->window, icon_mask, 0, 0);