X-Git-Url: https://git.distorted.org.uk/~mdw/xtoys/blobdiff_plain/d6130abd9c338ba8b63bfc4600adf1fa09c02fe8..6930fe78c92035ff7edb59104c70cd822316beef:/xshutdown.c diff --git a/xshutdown.c b/xshutdown.c index a21dab9..d2a1750 100644 --- a/xshutdown.c +++ b/xshutdown.c @@ -1,6 +1,6 @@ /* -*-c-*- * - * $Id: xshutdown.c,v 1.3 1998/11/30 22:36:49 mdw Exp $ + * $Id: xshutdown.c,v 1.5 1998/12/03 01:00:19 mdw Exp $ * * Pretty GTK interface to waking up an xwait * @@ -29,6 +29,12 @@ /*----- Revision history --------------------------------------------------* * * $Log: xshutdown.c,v $ + * Revision 1.5 1998/12/03 01:00:19 mdw + * Honour escape presses in the dialogue boxes. + * + * Revision 1.4 1998/12/03 00:39:45 mdw + * Force focus when starting up. + * * Revision 1.3 1998/11/30 22:36:49 mdw * Tidy up tabbing in help texts very slightly. * @@ -52,7 +58,9 @@ #include #include +#include +#include "mdwfocus.h" #include "mdwopt.h" #include "quis.h" #include "xwait.h" @@ -66,6 +74,29 @@ static Atom xwait_die; /*----- Main code ---------------------------------------------------------*/ +/* --- @check_escape@ --- * + * + * Arguments: @GtkWidget *w@ = widget raising the signal + * @GdkEventKey *ev@ = pointer to event data + * @gpointer *p@ = widget to activate in response + * + * Returns: --- + * + * Use: Activates a widget when an escape keypress is detected. + */ + +static gboolean check_escape(GtkWidget *w, GdkEventKey *ev, gpointer *p) +{ + if (ev->keyval == GDK_Escape) { + if (p) + gtk_widget_activate(GTK_WIDGET(p)); + else + gtk_object_destroy(GTK_OBJECT(w)); + return (1); + } + return (0); +} + /* --- @cancel@ --- * * * Just end the main loop. @@ -206,6 +237,8 @@ int main(int argc, char *argv[]) gtk_window_set_title(GTK_WINDOW(win), "xshutdown"); gtk_signal_connect(GTK_OBJECT(win), "destroy", GTK_SIGNAL_FUNC(cancel), 0); + gtk_signal_connect(GTK_OBJECT(win), "key_press_event", + GTK_SIGNAL_FUNC(check_escape), 0); gtk_box_set_homogeneous(GTK_BOX(GTK_DIALOG(win)->action_area), 0); @@ -229,6 +262,8 @@ int main(int argc, char *argv[]) /* --- Make everything work --- */ + gtk_widget_realize(win); + mdwfocus(win); gtk_widget_show(win); gtk_main(); exit(EXIT_FAILURE); @@ -276,6 +311,10 @@ int main(int argc, char *argv[]) /* --- Show the completed window --- */ + gtk_signal_connect(GTK_OBJECT(win), "key_press_event", + GTK_SIGNAL_FUNC(check_escape), 0); + gtk_widget_realize(win); + mdwfocus(win); gtk_widget_show(win); }