+
+gboolean
+isearch_counted_matches(GtkWidget *widget, guint matches, gpointer data)
+{
+ struct Client *c = (struct Client *)data;
+ char *text = malloc(12);
+ sprintf(text, "%d matches", matches);
+ gtk_label_set_text(GTK_LABEL(c->isearch_matches), text);
+ free(text);
+ return TRUE;
+}
+
+gboolean
+key_isearch(GtkWidget *widget, GdkEvent *event, gpointer data)
+{
+ struct Client *c = (struct Client *)data;
+ if (key_common(widget, event, data)) return TRUE;
+
+ if (event->type == GDK_KEY_PRESS) {
+ int key = ((GdkEventKey *)event)->keyval;
+ if ((GDK_KEY_KP_Enter == key) || (GDK_KEY_Return == key)) {
+ int direction = (((GdkEventKey *)event)->state &
+ GDK_SHIFT_MASK) ?
+ -1 :
+ 1;
+ isearch(c, 0);
+ isearch(c, -1);
+ isearch(c, direction);
+ return TRUE;
+ } else if (GDK_KEY_Escape == key) {
+ isearch(c, 2);
+ gtk_widget_hide(c->isearch_box);
+ gtk_widget_grab_focus(c->web_view);
+ }
+ }
+ return FALSE;
+}
+
+gboolean
+key_wsearch(GtkWidget *widget, GdkEvent *event, gpointer data)
+{
+ struct Client *c = (struct Client *)data;
+ if (key_common(widget, event, data)) return TRUE;
+
+ if (event->type == GDK_KEY_PRESS) {
+ int key = ((GdkEventKey *)event)->keyval;
+ if ((GDK_KEY_KP_Enter == key) || (GDK_KEY_Return == key)) {
+ const gchar *t =
+ gtk_entry_get_text(GTK_ENTRY(c->wsearch));
+ int len = strlen(cfg_search_engine) + strlen(t);
+ gchar *f = malloc(len + 1);
+ if (!f) allocfail();
+
+ snprintf(f, len + 1, "%s%s", cfg_search_engine, t);
+ webkit_web_view_load_uri(WEBKIT_WEB_VIEW(c->web_view),
+ f);
+ g_free(f);
+ gtk_widget_grab_focus(c->web_view);
+ return TRUE;
+ }
+ }
+ return FALSE;
+}
+