aboutsummaryrefslogtreecommitdiffstats
path: root/src/ephy-window.c
diff options
context:
space:
mode:
authorChristian Persch <chpe@cvs.gnome.org>2005-05-29 05:58:47 +0800
committerChristian Persch <chpe@src.gnome.org>2005-05-29 05:58:47 +0800
commitd0cc3530df347aed28b20fb884321a42b1b1958d (patch)
treeec070c45a016178c79322d426114bcde3b596ce6 /src/ephy-window.c
parent995f6539fb26444a0496b6311fecdbe9ad9cc8ff (diff)
downloadgsoc2013-epiphany-d0cc3530df347aed28b20fb884321a42b1b1958d.tar.gz
gsoc2013-epiphany-d0cc3530df347aed28b20fb884321a42b1b1958d.tar.zst
gsoc2013-epiphany-d0cc3530df347aed28b20fb884321a42b1b1958d.zip
Check for toolkit nsITypeAheadFind.
2005-05-28 Christian Persch <chpe@cvs.gnome.org> * configure.ac: Check for toolkit nsITypeAheadFind. * embed/Makefile.am: * embed/ephy-embed-factory.c: (ephy_embed_factory_new_object): * embed/ephy-embed-find.c: (ephy_embed_find_set_embed), (ephy_embed_find_set_properties), (ephy_embed_find_find), (ephy_embed_find_find_again), (ephy_embed_find_get_type): * embed/ephy-embed-find.h: * embed/ephy-embed.c: * embed/ephy-embed.h: * embed/mozilla/EphyBrowser.cpp: * embed/mozilla/EphyBrowser.h: * embed/mozilla/EphyFind.cpp: * embed/mozilla/EphyFind.h: * embed/mozilla/Makefile.am: * embed/mozilla/mozilla-embed-find.cpp: * embed/mozilla/mozilla-embed-find.h: * embed/mozilla/mozilla-embed.cpp: * src/bookmarks/ephy-bookmarks-import.c: (gul_general_read_line_from_file): * src/ephy-find-toolbar.c: (get_find), (set_controls), (tab_content_changed_cb), (entry_changed_cb), (ephy_find_toolbar_init), (ephy_find_toolbar_finalize), (ephy_find_toolbar_class_init), (ephy_find_toolbar_new), (ephy_find_toolbar_get_text), (ephy_find_toolbar_set_embed), (ephy_find_toolbar_find_next), (ephy_find_toolbar_find_previous): * src/ephy-find-toolbar.h: * src/ephy-window.c: (ephy_window_set_active_tab), (ephy_window_init), (ephy_window_get_find_toolbar), (ephy_window_notebook_switch_page_cb): * src/ephy-window.h: * src/window-commands.c: (window_cmd_edit_find_next), (window_cmd_edit_find_prev): Implement typeaheadfind for the find toolbar.
Diffstat (limited to 'src/ephy-window.c')
-rw-r--r--src/ephy-window.c94
1 files changed, 20 insertions, 74 deletions
diff --git a/src/ephy-window.c b/src/ephy-window.c
index 79c5efee4..e48c73704 100644
--- a/src/ephy-window.c
+++ b/src/ephy-window.c
@@ -1790,18 +1790,6 @@ tab_context_menu_cb (EphyEmbed *embed,
return TRUE;
}
-static void
-tab_content_changed_cb (EphyEmbed *embed,
- const char *uri,
- EphyWindow *window)
-{
- EphyWindowPrivate *priv = window->priv;
-
- if (priv->closing) return;
-
- ephy_find_toolbar_set_controls (priv->find_toolbar, TRUE, TRUE);
-}
-
static gboolean
let_me_resize_hack (EphyWindow *window)
{
@@ -1922,9 +1910,8 @@ ephy_window_set_active_tab (EphyWindow *window, EphyTab *new_tab)
g_signal_handlers_disconnect_by_func
(embed, G_CALLBACK (tab_context_menu_cb), window);
g_signal_handlers_disconnect_by_func
- (embed, G_CALLBACK (tab_content_changed_cb), window);
- g_signal_handlers_disconnect_by_func
(embed, G_CALLBACK (tab_size_to_cb), window);
+
}
window->priv->active_tab = new_tab;
@@ -1985,9 +1972,6 @@ ephy_window_set_active_tab (EphyWindow *window, EphyTab *new_tab)
g_signal_connect_object (embed, "ge-context-menu",
G_CALLBACK (tab_context_menu_cb),
window, G_CONNECT_AFTER);
- g_signal_connect_object (embed, "ge-content-change",
- G_CALLBACK (tab_content_changed_cb),
- window, G_CONNECT_AFTER);
g_signal_connect_object (embed, "size-to",
G_CALLBACK (tab_size_to_cb),
window, 0);
@@ -2690,56 +2674,6 @@ ephy_window_open_link (EphyLink *link,
}
static void
-sync_find_toolbar_text_cb (EphyFindToolbar *toolbar,
- GParamSpec *pspec,
- EphyWindow *window)
-{
- EphyEmbed *embed;
- const char *text;
-
- embed = ephy_window_get_active_embed (window);
- g_return_if_fail (embed != NULL);
-
- text = ephy_find_toolbar_get_text (toolbar);
- ephy_embed_find_set_properties (embed, text, FALSE, TRUE);
- ephy_find_toolbar_set_controls (toolbar, TRUE, TRUE);
-}
-
-static void
-find_toolbar_find_next_cb (EphyFindToolbar *toolbar,
- EphyWindow *window)
-{
- EphyEmbed *embed;
- const char *text;
- gboolean found;
-
- embed = ephy_window_get_active_embed (window);
- g_return_if_fail (embed != NULL);
-
- text = ephy_find_toolbar_get_text (toolbar);
- ephy_embed_find_set_properties (embed, text, FALSE, TRUE);
- found = ephy_embed_find_next (embed, FALSE);
- ephy_find_toolbar_set_controls (toolbar, found, found);
-}
-
-static void
-find_toolbar_find_previous_cb (EphyFindToolbar *toolbar,
- EphyWindow *window)
-{
- EphyEmbed *embed;
- const char *text;
- gboolean found;
-
- embed = ephy_window_get_active_embed (window);
- g_return_if_fail (embed != NULL);
-
- text = ephy_find_toolbar_get_text (toolbar);
- ephy_embed_find_set_properties (embed, text, FALSE, TRUE);
- found = ephy_embed_find_next (embed, TRUE);
- ephy_find_toolbar_set_controls (toolbar, found, found);
-}
-
-static void
find_toolbar_close_cb (EphyFindToolbar *toolbar,
EphyWindow *window)
{
@@ -2777,12 +2711,6 @@ ephy_window_init (EphyWindow *window)
gtk_widget_show (GTK_WIDGET (window->priv->notebook));
priv->find_toolbar = ephy_find_toolbar_new ();
- g_signal_connect (priv->find_toolbar, "notify::text",
- G_CALLBACK (sync_find_toolbar_text_cb), window);
- g_signal_connect (priv->find_toolbar, "next",
- G_CALLBACK (find_toolbar_find_next_cb), window);
- g_signal_connect (priv->find_toolbar, "previous",
- G_CALLBACK (find_toolbar_find_previous_cb), window);
g_signal_connect (priv->find_toolbar, "close",
G_CALLBACK (find_toolbar_close_cb), window);
gtk_box_pack_start (GTK_BOX (window->priv->main_vbox),
@@ -3057,6 +2985,22 @@ ephy_window_get_notebook (EphyWindow *window)
}
/**
+ * ephy_window_get_find_toolbar:
+ * @window: an #EphyWindow
+ *
+ * Returns the #EphyFindToolbar used by this window.
+ *
+ * Return value: the @window's #EphyFindToolbar
+ **/
+GtkWidget *
+ephy_window_get_find_toolbar (EphyWindow *window)
+{
+ g_return_val_if_fail (EPHY_IS_WINDOW (window), NULL);
+
+ return GTK_WIDGET (window->priv->find_toolbar);
+}
+
+/**
* ephy_window_get_statusbar:
* @window: an #EphyWindow
*
@@ -3291,16 +3235,18 @@ ephy_window_notebook_switch_page_cb (GtkNotebook *notebook,
{
EphyWindowPrivate *priv = window->priv;
EphyTab *tab;
+ EphyEmbed *embed;
if (priv->closing) return;
/* get the new tab */
tab = real_get_active_tab (window, page_num);
+ embed = ephy_tab_get_embed (tab);
/* update new tab */
ephy_window_set_active_tab (window, tab);
- ephy_find_toolbar_set_controls (priv->find_toolbar, TRUE, TRUE);
+ ephy_find_toolbar_set_embed (priv->find_toolbar, embed);
/* update window controls */
update_tabs_menu_sensitivity (window);