2 * This file is part of hildon-libs
4 * Copyright (C) 2005 Nokia Corporation.
6 * Contact: Luc Pionchon <luc.pionchon@nokia.com>
8 * This library is free software; you can redistribute it and/or
9 * modify it under the terms of the GNU Lesser General Public License
10 * as published by the Free Software Foundation; either version 2.1 of
11 * the License, or (at your option) any later version.
13 * This library is distributed in the hope that it will be useful, but
14 * WITHOUT ANY WARRANTY; without even the implied warranty of
15 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 * Lesser General Public License for more details.
18 * You should have received a copy of the GNU Lesser General Public
19 * License along with this library; if not, write to the Free Software
20 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA
26 * @file hildon-dialoghelp.c
28 * This file provides API for the help dialog with
35 #include "hildon-dialoghelp.h"
37 static guint help_signal = 0;
39 static GdkFilterReturn
40 handle_xevent(GdkXEvent * xevent, GdkEvent * event, gpointer dialog)
42 XAnyEvent *eventti = xevent;
44 if (eventti->type == ClientMessage) {
45 Atom help_atom, wm_atom;
47 XClientMessageEvent *cm;
52 help_atom = XInternAtom(disp, "_NET_WM_CONTEXT_HELP", True);
53 wm_atom = XInternAtom(disp, "WM_PROTOCOLS", True);
55 if (cm->message_type == wm_atom && cm->data.l[0] == help_atom) {
56 /* XClientMessageEvent *cm = xevent; */
57 g_signal_emit(G_OBJECT(dialog), help_signal, 0);
60 return GDK_FILTER_REMOVE; /* Event handled, don't process
64 return GDK_FILTER_CONTINUE; /* Event not handled */
68 * gtk_dialog_help_enable:
69 * @dialog: The dialog for which help is to be enabled.
71 * Enables context help button for given dialog. The signal "help" can be
72 * connected to handler by normal gtk methods. Note that this function
73 * has to be called before the dialog is shown.
75 * The "help" signal itself has no other parameters than the dialog where
76 * it is connected to, ie.:
77 * void user_function(GtkDialog *dialog, gpointer user_data);
79 void gtk_dialog_help_enable(GtkDialog * dialog)
91 /* Create help signal if it didn't exist */
92 if (help_signal == 0) {
93 help_signal = g_signal_new("help", GTK_TYPE_DIALOG,
94 G_SIGNAL_ACTION, (guint) - 1, NULL,
95 NULL, g_cclosure_marshal_VOID__VOID,
99 g_return_if_fail(GTK_IS_DIALOG(dialog));
101 gtk_widget_realize(GTK_WIDGET(dialog));
102 window = GTK_WIDGET(dialog)->window;
103 display = gdk_drawable_get_display (window);
105 /* Create a list of atoms stored in GdkWindow */
106 XGetWMProtocols(GDK_DISPLAY_XDISPLAY (display), GDK_WINDOW_XID (window),
109 protocols = (Atom *) malloc ((amount+1) * sizeof (Atom));
110 helpatom = gdk_x11_get_xatom_by_name_for_display (display, "_NET_WM_CONTEXT_HELP");
112 /* Enable the dialoghelp if help_atom is in the atoms' list */
113 for (i=0; i<amount; i++)
115 protocols[n++] = list[i];
116 if (list[i] == helpatom)
123 /* Add the help_atom to the atoms' list if it was not in it */
126 protocols[n++] = gdk_x11_get_xatom_by_name_for_display (display, "_NET_WM_CONTEXT_HELP");
129 /* Replace the protocol property of the GdkWindow with the new atoms' list */
130 XSetWMProtocols (GDK_DISPLAY_XDISPLAY (display), GDK_WINDOW_XID (window), protocols, n);
133 /* Add a callback function as event filter */
134 gdk_window_add_filter(window, handle_xevent, dialog);
138 * gtk_dialog_help_disable:
139 * @dialog: The dialog for which help is to be disabled.
141 * Disables context help button for the given dialog.
143 void gtk_dialog_help_disable(GtkDialog * dialog)
145 GdkWindow *window=NULL;
154 g_return_if_fail(GTK_IS_DIALOG(dialog));
156 gtk_widget_realize(GTK_WIDGET(dialog));
157 window = GTK_WIDGET(dialog)->window;
158 display = gdk_drawable_get_display (window);
160 /* Create a list of atoms stored in GdkWindow */
161 XGetWMProtocols(GDK_DISPLAY_XDISPLAY (display), GDK_WINDOW_XID (window),
164 helpatom = gdk_x11_get_xatom_by_name_for_display (display, "_NET_WM_CONTEXT_HELP");
165 protocols = (Atom *) malloc (amount * sizeof (Atom));
167 /* Remove the help_atom if it is in the atoms' list */
168 for (i=0; i<amount; i++)
170 if (list[i] != helpatom)
172 protocols[n++] = list[i];
177 /* Replace the protocol property of the GdkWindow with the new atoms' list */
178 XSetWMProtocols (GDK_DISPLAY_XDISPLAY (display), GDK_WINDOW_XID (window), protocols, n);
181 /* Remove the event filter */
182 gdk_window_remove_filter(window, handle_xevent, dialog);