summaryrefslogtreecommitdiff
path: root/libwnck/test-urgent.c
diff options
context:
space:
mode:
Diffstat (limited to 'libwnck/test-urgent.c')
-rw-r--r--libwnck/test-urgent.c96
1 files changed, 96 insertions, 0 deletions
diff --git a/libwnck/test-urgent.c b/libwnck/test-urgent.c
new file mode 100644
index 0000000..37000b6
--- /dev/null
+++ b/libwnck/test-urgent.c
@@ -0,0 +1,96 @@
+/* vim: set sw=2 et: */
+
+#include <gtk/gtk.h>
+
+static void
+set_urgent (GtkWidget *window,
+ gboolean urgent)
+{
+ GtkWidget *label;
+
+ label = gtk_bin_get_child (GTK_BIN (window));
+
+ if (urgent)
+ {
+ gtk_window_set_urgency_hint (GTK_WINDOW (window), TRUE);
+ gtk_window_set_title (GTK_WINDOW (window), "Test Window - Urgent");
+ gtk_label_set_text (GTK_LABEL (label), "I am urgent!");
+ }
+ else
+ {
+ gtk_window_set_urgency_hint (GTK_WINDOW (window), FALSE);
+ gtk_window_set_title (GTK_WINDOW (window), "Test Window");
+ gtk_label_set_text (GTK_LABEL (label), "I'm not urgent.");
+ }
+}
+
+static gboolean
+make_urgent (GtkWidget *widget)
+{
+ set_urgent (widget, TRUE);
+ g_object_set_data (G_OBJECT (widget), "wnck-timeout", NULL);
+
+ return FALSE;
+}
+
+static gboolean
+focused_in (GtkWidget *widget,
+ GdkEventFocus *event,
+ gpointer user_data)
+{
+ guint id;
+
+ set_urgent (widget, FALSE);
+
+ id = GPOINTER_TO_UINT (g_object_get_data (G_OBJECT (widget), "wnck-timeout"));
+ g_object_set_data (G_OBJECT (widget), "wnck-timeout", NULL);
+
+ if (id)
+ g_source_remove (id);
+
+ return FALSE;
+}
+
+static gboolean
+focused_out (GtkWidget *widget,
+ GdkEventFocus *event,
+ gpointer user_data)
+{
+ guint id;
+
+ id = g_timeout_add_seconds (3, (GSourceFunc) make_urgent, widget);
+ g_object_set_data (G_OBJECT (widget), "wnck-timeout", GUINT_TO_POINTER (id));
+
+ return FALSE;
+}
+
+int
+main (int argc, char **argv)
+{
+ GtkWidget *win;
+ GtkWidget *label;
+
+ gtk_init (&argc, &argv);
+
+ win = gtk_window_new (GTK_WINDOW_TOPLEVEL);
+ label = gtk_label_new ("");
+ gtk_container_add (GTK_CONTAINER (win), label);
+ gtk_window_set_keep_above (GTK_WINDOW (win), TRUE);
+ gtk_widget_show_all (win);
+
+ g_signal_connect (G_OBJECT (win), "focus-in-event",
+ G_CALLBACK (focused_in),
+ NULL);
+ g_signal_connect (G_OBJECT (win), "focus-out-event",
+ G_CALLBACK (focused_out),
+ NULL);
+ g_signal_connect (G_OBJECT (win), "destroy",
+ G_CALLBACK (gtk_main_quit),
+ NULL);
+
+ set_urgent (win, FALSE);
+
+ gtk_main ();
+
+ return 0;
+}