diff options
Diffstat (limited to 'src')
-rw-r--r-- | src/ephy-find-toolbar.c | 165 | ||||
-rw-r--r-- | src/ephy-find-toolbar.h | 15 | ||||
-rw-r--r-- | src/ephy-window.c | 94 | ||||
-rw-r--r-- | src/ephy-window.h | 2 | ||||
-rw-r--r-- | src/window-commands.c | 17 |
5 files changed, 153 insertions, 140 deletions
diff --git a/src/ephy-find-toolbar.c b/src/ephy-find-toolbar.c index 93ce237fe..10e244a1a 100644 --- a/src/ephy-find-toolbar.c +++ b/src/ephy-find-toolbar.c @@ -22,6 +22,8 @@ #include "config.h" #include "ephy-find-toolbar.h" +#include "ephy-embed-find.h" +#include "ephy-embed-factory.h" #include "ephy-debug.h" #include <gdk/gdkkeysyms.h> @@ -34,6 +36,7 @@ #include <gtk/gtkseparatortoolitem.h> #include <gtk/gtkstock.h> #include <gtk/gtktoolbutton.h> +#include <gtk/gtkalignment.h> #include <gtk/gtkmain.h> #include <string.h> @@ -41,7 +44,8 @@ struct _EphyFindToolbarPrivate { - EphyWindow *window; + EphyEmbedFind *find; + EphyEmbed *embed; GtkWidget *entry; GtkToolItem *next; GtkToolItem *prev; @@ -66,20 +70,29 @@ static guint signals[LAST_SIGNAL] = { 0 }; static GObjectClass *parent_class = NULL; -/* public functions */ +/* private functions */ -const char * -ephy_find_toolbar_get_text (EphyFindToolbar *toolbar) +static EphyEmbedFind * +get_find (EphyFindToolbar *toolbar) { EphyFindToolbarPrivate *priv = toolbar->priv; - return gtk_entry_get_text (GTK_ENTRY (priv->entry)); + if (priv->find == NULL) + { + priv->find = EPHY_EMBED_FIND (ephy_embed_factory_new_object (EPHY_TYPE_EMBED_FIND)); + + g_return_val_if_fail (priv->embed == NULL || GTK_WIDGET_REALIZED (GTK_WIDGET (priv->embed)), priv->find); + + ephy_embed_find_set_embed (priv->find, priv->embed); + } + + return priv->find; } -void -ephy_find_toolbar_set_controls (EphyFindToolbar *toolbar, - gboolean can_find_next, - gboolean can_find_prev) +static void +set_controls (EphyFindToolbar *toolbar, + gboolean can_find_next, + gboolean can_find_prev) { EphyFindToolbarPrivate *priv = toolbar->priv; @@ -87,7 +100,13 @@ ephy_find_toolbar_set_controls (EphyFindToolbar *toolbar, gtk_widget_set_sensitive (GTK_WIDGET (priv->prev), can_find_prev); } -/* private functions */ +static void +tab_content_changed_cb (EphyEmbed *embed, + const char *uri, + EphyFindToolbar *toolbar) +{ + set_controls (toolbar, TRUE, TRUE); +} static void find_next_cb (EphyFindToolbar *toolbar) @@ -103,9 +122,19 @@ find_prev_cb (EphyFindToolbar *toolbar) static void entry_changed_cb (GtkEntry *entry, - GObject *toolbar) + EphyFindToolbar *toolbar) { - g_object_notify (toolbar, "text"); + EphyFindToolbarPrivate *priv = toolbar->priv; + const char *text; + gboolean found = TRUE; + + text = gtk_entry_get_text (GTK_ENTRY (priv->entry)); +#ifdef HAVE_TYPEAHEADFIND + found = ephy_embed_find_find (get_find (toolbar), text, FALSE); +#else + ephy_embed_find_set_properties (get_find (toolbar), text, FALSE); +#endif + set_controls (toolbar, found, found); } static gboolean @@ -200,7 +229,7 @@ ephy_find_toolbar_init (EphyFindToolbar *toolbar) EphyFindToolbarPrivate *priv; GtkToolbar *gtoolbar; GtkToolItem *item; - GtkWidget *arrow, *box, *label; + GtkWidget *alignment, *arrow, *box, *label; priv = toolbar->priv = EPHY_FIND_TOOLBAR_GET_PRIVATE (toolbar); gtoolbar = GTK_TOOLBAR (toolbar); @@ -208,7 +237,11 @@ ephy_find_toolbar_init (EphyFindToolbar *toolbar) gtk_toolbar_set_style (gtoolbar, GTK_TOOLBAR_BOTH_HORIZ); /* Find: |_____| */ + alignment = gtk_alignment_new (0.0, 0.5, 1.0, 0.0); + gtk_alignment_set_padding (GTK_ALIGNMENT (alignment), 0, 0, 2, 2); + box = gtk_hbox_new (FALSE, 12); + gtk_container_add (GTK_CONTAINER (alignment), box); label = gtk_label_new (NULL); gtk_label_set_markup (GTK_LABEL (label), _("Find:")); @@ -220,7 +253,7 @@ ephy_find_toolbar_init (EphyFindToolbar *toolbar) gtk_box_pack_start (GTK_BOX (box), priv->entry, TRUE, TRUE, 0); item = gtk_tool_item_new (); - gtk_container_add (GTK_CONTAINER (item), box); + gtk_container_add (GTK_CONTAINER (item), alignment); //gtk_tool_item_set_expand (item, TRUE); gtk_toolbar_insert (GTK_TOOLBAR (toolbar), item, -1); gtk_widget_show_all (GTK_WIDGET (item)); @@ -265,53 +298,35 @@ ephy_find_toolbar_init (EphyFindToolbar *toolbar) } static void -ephy_find_toolbar_set_property (GObject *object, - guint prop_id, - const GValue *value, - GParamSpec *pspec) +ephy_find_toolbar_finalize (GObject *object) { EphyFindToolbar *toolbar = EPHY_FIND_TOOLBAR (object); EphyFindToolbarPrivate *priv = toolbar->priv; - switch (prop_id) + if (priv->find != NULL) { - case PROP_TEXT: - gtk_entry_set_text (GTK_ENTRY (priv->entry), - g_value_get_string (value)); - break; + g_object_unref (priv->find); } -} - -static void -ephy_find_toolbar_get_property (GObject *object, - guint prop_id, - GValue *value, - GParamSpec *pspec) -{ - EphyFindToolbar *toolbar = EPHY_FIND_TOOLBAR (object); - switch (prop_id) - { - case PROP_TEXT: - g_value_set_string (value, ephy_find_toolbar_get_text (toolbar)); - break; - } + parent_class->finalize (object); } static void ephy_find_toolbar_class_init (EphyFindToolbarClass *klass) { - GObjectClass *object_class = G_OBJECT_CLASS (klass); + GObjectClass *object_class = G_OBJECT_CLASS (klass); GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass); parent_class = g_type_class_peek_parent (klass); - object_class->set_property = ephy_find_toolbar_set_property; - object_class->get_property = ephy_find_toolbar_get_property; + object_class->finalize = ephy_find_toolbar_finalize; widget_class->parent_set = ephy_find_toolbar_parent_set; widget_class->grab_focus = ephy_find_toolbar_grab_focus; + klass->next = ephy_find_toolbar_find_next; + klass->previous = ephy_find_toolbar_find_previous; + signals[NEXT] = g_signal_new ("next", G_OBJECT_CLASS_TYPE (object_class), @@ -339,18 +354,11 @@ ephy_find_toolbar_class_init (EphyFindToolbarClass *klass) g_cclosure_marshal_VOID__VOID, G_TYPE_NONE, 0); - g_object_class_install_property - (object_class, - PROP_TEXT, - g_param_spec_string ("text", - "Search string", - "Search string", - "", - G_PARAM_READWRITE)); - g_type_class_add_private (klass, sizeof (EphyFindToolbarPrivate)); } +/* public functions */ + GType ephy_find_toolbar_get_type (void) { @@ -384,3 +392,60 @@ ephy_find_toolbar_new (void) { return EPHY_FIND_TOOLBAR (g_object_new (EPHY_TYPE_FIND_TOOLBAR, NULL)); } + +const char * +ephy_find_toolbar_get_text (EphyFindToolbar *toolbar) +{ + EphyFindToolbarPrivate *priv = toolbar->priv; + + return gtk_entry_get_text (GTK_ENTRY (priv->entry)); +} + +void +ephy_find_toolbar_set_embed (EphyFindToolbar *toolbar, + EphyEmbed *embed) +{ + EphyFindToolbarPrivate *priv = toolbar->priv; + + if (priv->embed == embed) return; + + if (priv->embed != NULL) + { + g_signal_handlers_disconnect_by_func + (embed, G_CALLBACK (tab_content_changed_cb), toolbar); + } + + priv->embed = embed; + 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); + + if (priv->find != NULL) + { + g_return_if_fail (GTK_WIDGET_REALIZED (GTK_WIDGET (priv->embed))); + + ephy_embed_find_set_embed (priv->find, embed); + } + } +} + +void +ephy_find_toolbar_find_next (EphyFindToolbar *toolbar) +{ + gboolean found; + + found = ephy_embed_find_find_again (get_find (toolbar), TRUE); + set_controls (toolbar, found, found); +} + +void +ephy_find_toolbar_find_previous (EphyFindToolbar *toolbar) +{ + gboolean found; + + found = ephy_embed_find_find_again (get_find (toolbar), FALSE); + set_controls (toolbar, found, found); +} diff --git a/src/ephy-find-toolbar.h b/src/ephy-find-toolbar.h index 8f3ef4567..b55a2f2cf 100644 --- a/src/ephy-find-toolbar.h +++ b/src/ephy-find-toolbar.h @@ -57,15 +57,18 @@ struct _EphyFindToolbarClass void (* close) (EphyFindToolbar *toolbar); }; -GType ephy_find_toolbar_get_type (void) G_GNUC_CONST; +GType ephy_find_toolbar_get_type (void) G_GNUC_CONST; -EphyFindToolbar *ephy_find_toolbar_new (void); +EphyFindToolbar *ephy_find_toolbar_new (void); -const char *ephy_find_toolbar_get_text (EphyFindToolbar *toolbar); +const char *ephy_find_toolbar_get_text (EphyFindToolbar *toolbar); -void ephy_find_toolbar_set_controls (EphyFindToolbar *toolbar, - gboolean next, - gboolean previous); +void ephy_find_toolbar_set_embed (EphyFindToolbar *toolbar, + EphyEmbed *embed); + +void ephy_find_toolbar_find_next (EphyFindToolbar *toolbar); + +void ephy_find_toolbar_find_previous (EphyFindToolbar *toolbar); G_END_DECLS 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); diff --git a/src/ephy-window.h b/src/ephy-window.h index df0486c8f..6cd3fa9bc 100644 --- a/src/ephy-window.h +++ b/src/ephy-window.h @@ -72,6 +72,8 @@ GtkWidget *ephy_window_get_bookmarksbar (EphyWindow *window); GtkWidget *ephy_window_get_notebook (EphyWindow *window); +GtkWidget *ephy_window_get_find_toolbar (EphyWindow *window); + GtkWidget *ephy_window_get_statusbar (EphyWindow *window); void ephy_window_add_tab (EphyWindow *window, diff --git a/src/window-commands.c b/src/window-commands.c index f6f59b1ee..7f4893aab 100644 --- a/src/window-commands.c +++ b/src/window-commands.c @@ -44,6 +44,7 @@ #include "ephy-zoom.h" #include "ephy-notebook.h" #include "ephy-toolbar-editor.h" +#include "ephy-find-toolbar.h" #include <string.h> #include <glib.h> @@ -559,24 +560,20 @@ void window_cmd_edit_find_next (GtkAction *action, EphyWindow *window) { - EphyEmbed *embed; - - embed = ephy_window_get_active_embed (window); - g_return_if_fail (embed != NULL); + EphyFindToolbar *toolbar; - ephy_embed_find_next (embed, FALSE); + toolbar = EPHY_FIND_TOOLBAR (ephy_window_get_find_toolbar (window)); + ephy_find_toolbar_find_next (toolbar); } void window_cmd_edit_find_prev (GtkAction *action, EphyWindow *window) { - EphyEmbed *embed; - - embed = ephy_window_get_active_embed (window); - g_return_if_fail (embed != NULL); + EphyFindToolbar *toolbar; - ephy_embed_find_next (embed, TRUE); + toolbar = EPHY_FIND_TOOLBAR (ephy_window_get_find_toolbar (window)); + ephy_find_toolbar_find_previous (toolbar); } void |