summaryrefslogtreecommitdiff
path: root/src/nautilus-rename-file-popover-controller.c
diff options
context:
space:
mode:
authorErnestas Kulik <ernestask@gnome.org>2018-08-06 12:14:07 +0300
committerErnestas Kulik <ekulik@redhat.com>2019-06-29 14:33:41 +0200
commit43c5cb6fee299059d765281357494b411b59bac4 (patch)
treecf69ea5f5ac5836422a28c5074fee82228b0c65c /src/nautilus-rename-file-popover-controller.c
parent97e5bce83e49da5157565c10420d7bc90a4069e9 (diff)
downloadnautilus-43c5cb6fee299059d765281357494b411b59bac4.tar.gz
rename-file-popover-controller: Use controller for key events
Diffstat (limited to 'src/nautilus-rename-file-popover-controller.c')
-rw-r--r--src/nautilus-rename-file-popover-controller.c37
1 files changed, 14 insertions, 23 deletions
diff --git a/src/nautilus-rename-file-popover-controller.c b/src/nautilus-rename-file-popover-controller.c
index c1c049dab..3163e84fb 100644
--- a/src/nautilus-rename-file-popover-controller.c
+++ b/src/nautilus-rename-file-popover-controller.c
@@ -245,30 +245,18 @@ name_entry_on_undo (GtkWidget *widget,
}
static gboolean
-name_entry_on_event (GtkWidget *widget,
- GdkEvent *event,
- gpointer user_data)
+on_event_controller_key_key_pressed (GtkEventControllerKey *controller,
+ guint keyval,
+ guint keycode,
+ GdkModifierType state,
+ gpointer user_data)
{
+ GtkWidget *widget;
NautilusRenameFilePopoverController *self;
- guint keyval;
- GdkModifierType state;
-
- if (gdk_event_get_event_type (event) != GDK_KEY_PRESS)
- {
- return GDK_EVENT_PROPAGATE;
- }
+ widget = gtk_event_controller_get_widget (GTK_EVENT_CONTROLLER (controller));
self = NAUTILUS_RENAME_FILE_POPOVER_CONTROLLER (user_data);
- if (G_UNLIKELY (!gdk_event_get_keyval (event, &keyval)))
- {
- g_return_val_if_reached (GDK_EVENT_PROPAGATE);
- }
- if (G_UNLIKELY (!gdk_event_get_state (event, &state)))
- {
- g_return_val_if_reached (GDK_EVENT_PROPAGATE);
- }
-
if (keyval == GDK_KEY_F2)
{
return name_entry_on_f2_pressed (widget, self);
@@ -350,6 +338,7 @@ nautilus_rename_file_popover_controller_show_for_file (NautilusRenameFilePopov
g_autoptr (NautilusDirectory) containing_directory = NULL;
g_autofree gchar *display_name = NULL;
gint n_chars;
+ GtkEventController *controller;
g_assert (NAUTILUS_IS_RENAME_FILE_POPOVER_CONTROLLER (self));
g_assert (NAUTILUS_IS_FILE (target_file));
@@ -385,10 +374,12 @@ nautilus_rename_file_popover_controller_show_for_file (NautilusRenameFilePopov
G_CALLBACK (target_file_on_changed),
self);
- self->key_press_event_handler_id = g_signal_connect (self->name_entry,
- "event",
- G_CALLBACK (name_entry_on_event),
- self);
+ controller = gtk_event_controller_key_new ();
+
+ gtk_widget_add_controller (self->name_entry, controller);
+
+ g_signal_connect (controller, "key-pressed",
+ G_CALLBACK (on_event_controller_key_key_pressed), self);
gtk_label_set_text (GTK_LABEL (self->name_label),
self->target_is_folder ? _("Folder name") :