aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorChristian Persch <chpe@cvs.gnome.org>2005-12-05 06:17:51 +0800
committerChristian Persch <chpe@src.gnome.org>2005-12-05 06:17:51 +0800
commite8bf34f418f3c4df8c03c64713c4ddce122f20fd (patch)
treef28c63399708ed946fefa92833f95a2d71d8a0b7 /src
parenteb05fa4984eba5504e49349b4536b3619b62b453 (diff)
downloadgsoc2013-epiphany-e8bf34f418f3c4df8c03c64713c4ddce122f20fd.tar
gsoc2013-epiphany-e8bf34f418f3c4df8c03c64713c4ddce122f20fd.tar.gz
gsoc2013-epiphany-e8bf34f418f3c4df8c03c64713c4ddce122f20fd.tar.bz2
gsoc2013-epiphany-e8bf34f418f3c4df8c03c64713c4ddce122f20fd.tar.lz
gsoc2013-epiphany-e8bf34f418f3c4df8c03c64713c4ddce122f20fd.tar.xz
gsoc2013-epiphany-e8bf34f418f3c4df8c03c64713c4ddce122f20fd.tar.zst
gsoc2013-epiphany-e8bf34f418f3c4df8c03c64713c4ddce122f20fd.zip
Refactor find toolbar closing not to crash with auto-closing popups. Unset
2005-12-04 Christian Persch <chpe@cvs.gnome.org> * src/ephy-find-toolbar.c: (set_status), (clear_status), (tab_search_key_press_cb), (entry_key_press_event_cb), (entry_activate_cb), (set_focus_cb), (ephy_find_toolbar_set_window), (ephy_find_toolbar_init), (ephy_find_toolbar_class_init), (ephy_find_toolbar_set_embed), (ephy_find_toolbar_open), (ephy_find_toolbar_close), (ephy_find_toolbar_request_close): * src/ephy-find-toolbar.h: * src/ephy-window.c: (sync_tab_document_type), (find_toolbar_close_cb), (ephy_window_set_print_preview), (ephy_window_get_find_toolbar), (ephy_window_get_context_event): Refactor find toolbar closing not to crash with auto-closing popups. Unset the selection colour on close. Remove dead #ifdef FIND_WHILE_TYPING_IN_EMBED code. (Merged from HEAD.)
Diffstat (limited to 'src')
-rw-r--r--src/ephy-find-toolbar.c165
-rw-r--r--src/ephy-find-toolbar.h2
-rw-r--r--src/ephy-window.c20
3 files changed, 29 insertions, 158 deletions
diff --git a/src/ephy-find-toolbar.c b/src/ephy-find-toolbar.c
index 3e9ac57ac..b827ad574 100644
--- a/src/ephy-find-toolbar.c
+++ b/src/ephy-find-toolbar.c
@@ -40,8 +40,6 @@
#include <gtk/gtkmain.h>
#include <string.h>
-#undef FIND_WHILE_TYPING_IN_EMBED
-
#define EPHY_FIND_TOOLBAR_GET_PRIVATE(object) (G_TYPE_INSTANCE_GET_PRIVATE ((object),EPHY_TYPE_FIND_TOOLBAR, EphyFindToolbarPrivate))
struct _EphyFindToolbarPrivate
@@ -121,42 +119,6 @@ tab_content_changed_cb (EphyEmbed *embed,
#ifdef HAVE_TYPEAHEADFIND
-#ifdef FIND_WHILE_TYPING_IN_EMBED
-
-/* Cut and paste from gtkwindow.c */
-static void
-send_focus_change (GtkWidget *widget,
- gboolean in)
-{
- GdkEvent *event;
-
- event = gdk_event_new (GDK_FOCUS_CHANGE);
-
- g_object_ref (widget);
-
- if (in)
- {
- GTK_WIDGET_SET_FLAGS (widget, GTK_HAS_FOCUS);
- }
- else
- {
- GTK_WIDGET_UNSET_FLAGS (widget, GTK_HAS_FOCUS);
- }
-
- event->focus_change.type = GDK_FOCUS_CHANGE;
- event->focus_change.window = (GdkWindow *) g_object_ref (widget->window);
- event->focus_change.in = in;
-
- gtk_widget_event (widget, event);
-
- g_object_notify (G_OBJECT (widget), "has_focus");
-
- g_object_unref (widget);
- gdk_event_free (event);
-}
-
-#endif /* FIND_WHILE_TYPING_IN_EMBED */
-
/* Code adapted from gtktreeview.c:gtk_tree_view_key_press() and
* gtk_tree_view_real_start_interactive_seach()
*/
@@ -167,12 +129,6 @@ tab_search_key_press_cb (EphyEmbed *embed,
{
EphyFindToolbarPrivate *priv = toolbar->priv;
GtkWidget *widget = (GtkWidget *) toolbar;
-#ifdef FIND_WHILE_TYPING_IN_EMBED
- GtkEntry *entry = (GtkEntry *) priv->entry;
- GdkWindow *event_window;
- gboolean retval = FALSE;
- guint oldhash, newhash;
-#endif
g_return_val_if_fail (event != NULL, FALSE);
@@ -195,58 +151,8 @@ tab_search_key_press_cb (EphyEmbed *embed,
}
return FALSE;
-
-#ifdef FIND_WHILE_TYPING_IN_EMBED
- /* don't do anything if the find toolbar is hidden */
- if (GTK_WIDGET_VISIBLE (widget) == FALSE ||
- event->keyval == GDK_Return ||
- event->keyval == GDK_KP_Enter ||
- event->keyval == GDK_ISO_Enter)
- {
- return FALSE;
- }
-
- oldhash = g_str_hash (gtk_entry_get_text (entry));
-
- event_window = event->window;
- event->window = priv->entry->window;
-
- /* Send the event to the window. If the preedit_changed signal is emitted
- * during this event, we will set priv->imcontext_changed */
- priv->preedit_changed = priv->activated = FALSE;
- priv->prevent_activate = TRUE;
- retval = gtk_widget_event (priv->entry, (GdkEvent*) event);
- priv->prevent_activate = FALSE;
-
- /* restore event window, else gdk_event_free below will crash */
- event->window = event_window;
-
- newhash = g_str_hash (gtk_entry_get_text (entry));
-
- /* FIXME: is this correct? */
- return retval && (oldhash != newhash || priv->preedit_changed) && !priv->activated;
-#endif /* FIND_WHILE_TYPING_IN_EMBED */
-}
-
-#ifdef FIND_WHILE_TYPING_IN_EMBED
-
-static gboolean
-tab_dom_mouse_click_cb (EphyEmbed *embed,
- gpointer event,
- EphyFindToolbar *toolbar)
-{
- EphyFindToolbarPrivate *priv = toolbar->priv;
-
- if (!priv->explicit_focus)
- {
- ephy_find_toolbar_close (toolbar);
- }
-
- return FALSE;
}
-#endif /* FIND_WHILE_TYPING_IN_EMBED */
-
#endif /* HAVE_TYPEAHEADFIND */
static void
@@ -286,15 +192,6 @@ entry_changed_cb (GtkEntry *entry,
set_controls (toolbar, found, found);
}
-#ifdef FIND_WHILE_TYPING_IN_EMBED
-static void
-entry_preedit_changed_cb (GtkIMContext *context,
- EphyFindToolbar *toolbar)
-{
- toolbar->priv->preedit_changed = TRUE;
-}
-#endif
-
static gboolean
entry_key_press_event_cb (GtkEntry *entry,
GdkEventKey *event,
@@ -306,7 +203,7 @@ entry_key_press_event_cb (GtkEntry *entry,
/* Hide the toolbar when ESC is pressed */
if ((event->state & mask) == 0 && event->keyval == GDK_Escape)
{
- g_signal_emit (toolbar, signals[CLOSE], 0);
+ ephy_find_toolbar_request_close (toolbar);
handled = TRUE;
}
else if ((event->state & mask) == GDK_CONTROL_MASK &&
@@ -324,11 +221,6 @@ entry_activate_cb (GtkWidget *entry,
{
EphyFindToolbarPrivate *priv = toolbar->priv;
-#ifdef FIND_WHILE_TYPING_IN_EMBED
- priv->activated = TRUE;
- if (priv->prevent_activate) return;
-#endif
-
if (priv->typing_ahead)
{
ephy_embed_find_activate_link (get_find (toolbar), 0);
@@ -359,18 +251,7 @@ set_focus_cb (EphyWindow *window,
}
else if (priv->explicit_focus)
{
- g_signal_emit (toolbar, signals[CLOSE], 0);
- }
-}
-
-static void
-sync_print_preview_mode (EphyWindow *window,
- GParamSpec *pspec,
- EphyFindToolbar *toolbar)
-{
- if (ephy_window_get_is_print_preview (window) && GTK_WIDGET_VISIBLE (GTK_WIDGET (toolbar)))
- {
- ephy_find_toolbar_close (toolbar);
+ ephy_find_toolbar_request_close (toolbar);
}
}
@@ -381,10 +262,6 @@ ephy_find_toolbar_set_window (EphyFindToolbar *toolbar,
EphyFindToolbarPrivate *priv = toolbar->priv;
priv->window = window;
-
- sync_print_preview_mode (window, NULL, toolbar);
- g_signal_connect (window, "notify::print-preview-mode",
- G_CALLBACK (sync_print_preview_mode), toolbar);
}
static void
@@ -476,10 +353,6 @@ ephy_find_toolbar_init (EphyFindToolbar *toolbar)
G_CALLBACK (entry_key_press_event_cb), toolbar);
g_signal_connect_after (priv->entry, "changed",
G_CALLBACK (entry_changed_cb), toolbar);
-#ifdef FIND_WHILE_TYPING_IN_EMBED
- g_signal_connect (GTK_ENTRY (priv->entry)->im_context, "preedit-changed",
- G_CALLBACK (entry_preedit_changed_cb), toolbar);
-#endif
g_signal_connect (priv->entry, "activate",
G_CALLBACK (entry_activate_cb), toolbar);
g_signal_connect_swapped (priv->next, "clicked",
@@ -545,7 +418,6 @@ ephy_find_toolbar_class_init (EphyFindToolbarClass *klass)
klass->next = ephy_find_toolbar_find_next;
klass->previous = ephy_find_toolbar_find_previous;
- klass->close = ephy_find_toolbar_close;
signals[NEXT] =
g_signal_new ("next",
@@ -650,6 +522,7 @@ ephy_find_toolbar_set_embed (EphyFindToolbar *toolbar,
if (embed != NULL)
{
set_controls (toolbar, TRUE, TRUE);
+
g_signal_connect_object (embed, "ge-content-change",
G_CALLBACK (tab_content_changed_cb),
toolbar, G_CONNECT_AFTER);
@@ -657,11 +530,6 @@ ephy_find_toolbar_set_embed (EphyFindToolbar *toolbar,
g_signal_connect_object (embed, "ge-search-key-press",
G_CALLBACK (tab_search_key_press_cb),
toolbar, 0);
-#ifdef FIND_WHILE_TYPING_IN_EMBED
- g_signal_connect_object (embed, "dom-mouse-click",
- G_CALLBACK (tab_dom_mouse_click_cb),
- toolbar, 0);
-#endif /* FIND_WHILE_TYPING_IN_EMBED */
#endif /* HAVE_TYPEAHEADFIND */
if (priv->find != NULL)
@@ -716,19 +584,7 @@ ephy_find_toolbar_open (EphyFindToolbar *toolbar,
gtk_widget_show (GTK_WIDGET (toolbar));
-#if defined(HAVE_TYPEAHEADFIND) && defined(FIND_WHILE_TYPING_IN_EMBED)
- gtk_widget_grab_focus (GTK_WIDGET (priv->embed));
-
- send_focus_change (priv->entry, TRUE);
-
- if (strlen(gtk_entry_get_text (GTK_ENTRY (priv->entry))) != 0)
- {
- entry_changed_cb (GTK_ENTRY (priv->entry), toolbar);
- }
-#else
gtk_widget_grab_focus (GTK_WIDGET (toolbar));
-#endif
-
}
void
@@ -736,13 +592,14 @@ ephy_find_toolbar_close (EphyFindToolbar *toolbar)
{
EphyFindToolbarPrivate *priv = toolbar->priv;
- g_return_if_fail (priv->embed != NULL);
-
- gtk_widget_hide (GTK_WIDGET (toolbar));
-
/* first unset explicit_focus, else we get infinite recursion */
priv->explicit_focus = FALSE;
-#ifndef FIND_WHILE_TYPING_IN_EMBED
- gtk_widget_grab_focus (GTK_WIDGET (priv->embed));
-#endif
+
+ gtk_widget_hide (GTK_WIDGET (toolbar));
+}
+
+void
+ephy_find_toolbar_request_close (EphyFindToolbar *toolbar)
+{
+ g_signal_emit (toolbar, signals[CLOSE], 0);
}
diff --git a/src/ephy-find-toolbar.h b/src/ephy-find-toolbar.h
index 10d11859e..b6b2aa248 100644
--- a/src/ephy-find-toolbar.h
+++ b/src/ephy-find-toolbar.h
@@ -76,6 +76,8 @@ void ephy_find_toolbar_open (EphyFindToolbar *toolbar,
void ephy_find_toolbar_close (EphyFindToolbar *toolbar);
+void ephy_find_toolbar_request_close (EphyFindToolbar *toolbar);
+
G_END_DECLS
#endif /* EPHY_FIND_TOOLBAR_H */
diff --git a/src/ephy-window.c b/src/ephy-window.c
index 633ed4b77..714711b99 100644
--- a/src/ephy-window.c
+++ b/src/ephy-window.c
@@ -1214,7 +1214,7 @@ sync_tab_document_type (EphyTab *tab,
if (!can_find)
{
- ephy_find_toolbar_close (priv->find_toolbar);
+ ephy_find_toolbar_request_close (priv->find_toolbar);
}
}
@@ -2889,7 +2889,17 @@ static void
find_toolbar_close_cb (EphyFindToolbar *toolbar,
EphyWindow *window)
{
- gtk_widget_hide (GTK_WIDGET (toolbar));
+ EphyWindowPrivate *priv = window->priv;
+ EphyTab *tab;
+
+ if (priv->closing) return;
+
+ ephy_find_toolbar_close (priv->find_toolbar);
+
+ tab = ephy_window_get_active_tab (window);
+ if (tab == NULL) return;
+
+ gtk_widget_grab_focus (GTK_WIDGET (tab));
}
static void
@@ -3135,6 +3145,8 @@ ephy_window_set_print_preview (EphyWindow *window,
{
g_return_if_fail (priv->ppview_toolbar == NULL);
+ ephy_find_toolbar_request_close (priv->find_toolbar);
+
priv->ppview_toolbar = ppview_toolbar_new (window);
gtk_window_remove_accel_group (GTK_WINDOW (window), accel_group);
}
@@ -3225,9 +3237,9 @@ ephy_window_get_notebook (EphyWindow *window)
GtkWidget *
ephy_window_get_find_toolbar (EphyWindow *window)
{
- g_return_val_if_fail (EPHY_IS_WINDOW (window), NULL);
+ g_return_val_if_fail (EPHY_IS_WINDOW (window), NULL);
- return GTK_WIDGET (window->priv->find_toolbar);
+ return GTK_WIDGET (window->priv->find_toolbar);
}
/**