diff options
Diffstat (limited to 'lib/widgets/ephy-location-entry.c')
-rw-r--r-- | lib/widgets/ephy-location-entry.c | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/lib/widgets/ephy-location-entry.c b/lib/widgets/ephy-location-entry.c index b78612f72..426c874b9 100644 --- a/lib/widgets/ephy-location-entry.c +++ b/lib/widgets/ephy-location-entry.c @@ -32,6 +32,7 @@ #include "ephy-debug.h" #include <glib/gi18n.h> +#include <gdk/gdkkeysyms.h> #include <gtk/gtktoolbar.h> #include <gtk/gtkentry.h> #include <gtk/gtkwindow.h> @@ -246,6 +247,23 @@ entry_button_press_cb (GtkWidget *entry, GdkEventButton *event, EphyLocationEntr } static gboolean +entry_key_press_cb (GtkWidget *widget, + GdkEventKey *event, + EphyLocationEntry *entry) +{ + if (event->keyval == GDK_Escape) + { + ephy_location_entry_restore_location (entry); + + /* Don't consume the keypress, since we want the default + * action (close autocompletion popup) too. + */ + } + + return FALSE; +} + +static gboolean keyword_match (const char *list, const char *keyword) { @@ -586,6 +604,8 @@ ephy_location_entry_construct_contents (EphyLocationEntry *entry) G_CALLBACK (entry_populate_popup_cb), entry); g_signal_connect (priv->entry, "button_press_event", G_CALLBACK (entry_button_press_cb), entry); + g_signal_connect (priv->entry, "key-press-event", + G_CALLBACK (entry_key_press_cb), entry); g_signal_connect (priv->entry, "changed", G_CALLBACK (editable_changed_cb), entry); g_signal_connect (priv->entry, "drag_motion", @@ -702,6 +722,18 @@ ephy_location_entry_get_location (EphyLocationEntry *le) } void +ephy_location_entry_restore_location (EphyLocationEntry *entry) +{ + char *url = NULL; + + g_return_if_fail (EPHY_IS_LOCATION_ENTRY (entry)); + + g_signal_emit (entry, signals[GET_LOCATION], 0, &url); + gtk_entry_set_text (GTK_ENTRY (entry->priv->entry), url ? url : ""); + g_free (url); +} + +void ephy_location_entry_activate (EphyLocationEntry *le) { GtkWidget *toplevel; |