diff options
author | Marco Pesenti Gritti <marco@gnome.org> | 2003-10-14 19:36:37 +0800 |
---|---|---|
committer | Marco Pesenti Gritti <marco@src.gnome.org> | 2003-10-14 19:36:37 +0800 |
commit | 15dd9817a91d1c0b9a12f5dc5999d08c38c6d396 (patch) | |
tree | fd433dfc31a7336306628e4ceb200b6428b05460 | |
parent | ee91f3c5d1faa4d0582d10778818827c7f62f5ec (diff) | |
download | gsoc2013-epiphany-15dd9817a91d1c0b9a12f5dc5999d08c38c6d396.tar.gz gsoc2013-epiphany-15dd9817a91d1c0b9a12f5dc5999d08c38c6d396.tar.zst gsoc2013-epiphany-15dd9817a91d1c0b9a12f5dc5999d08c38c6d396.zip |
Make location a normal entry.
2003-10-14 Marco Pesenti Gritti <marco@gnome.org>
* lib/widgets/ephy-location-entry.c:
(ephy_location_entry_class_init),
(ephy_location_entry_construct_contents),
(ephy_location_entry_init), (ephy_location_entry_activate):
* lib/widgets/ephy-location-entry.h:
* src/ephy-history-window.c: (confirmation_dialog_response_cb):
* src/ephy-location-action.c: (remove_completion_actions),
(add_completion_actions), (connect_proxy),
(ephy_location_action_set_address):
* src/ephy-location-action.h:
* src/toolbar.c:
* src/toolbar.h:
Make location a normal entry.
-rw-r--r-- | ChangeLog | 17 | ||||
-rw-r--r-- | lib/widgets/ephy-location-entry.c | 185 | ||||
-rw-r--r-- | lib/widgets/ephy-location-entry.h | 4 | ||||
-rw-r--r-- | src/ephy-history-window.c | 14 | ||||
-rw-r--r-- | src/ephy-location-action.c | 25 | ||||
-rw-r--r-- | src/ephy-location-action.h | 2 | ||||
-rwxr-xr-x | src/toolbar.c | 12 | ||||
-rw-r--r-- | src/toolbar.h | 2 |
8 files changed, 23 insertions, 238 deletions
@@ -1,3 +1,20 @@ +2003-10-14 Marco Pesenti Gritti <marco@gnome.org> + + * lib/widgets/ephy-location-entry.c: + (ephy_location_entry_class_init), + (ephy_location_entry_construct_contents), + (ephy_location_entry_init), (ephy_location_entry_activate): + * lib/widgets/ephy-location-entry.h: + * src/ephy-history-window.c: (confirmation_dialog_response_cb): + * src/ephy-location-action.c: (remove_completion_actions), + (add_completion_actions), (connect_proxy), + (ephy_location_action_set_address): + * src/ephy-location-action.h: + * src/toolbar.c: + * src/toolbar.h: + + Make location a normal entry. + 2003-10-13 Marco Pesenti Gritti <marco@gnome.org> * lib/widgets/ephy-location-entry.c: diff --git a/lib/widgets/ephy-location-entry.c b/lib/widgets/ephy-location-entry.c index e581a0c30..c935f9d04 100644 --- a/lib/widgets/ephy-location-entry.c +++ b/lib/widgets/ephy-location-entry.c @@ -24,11 +24,8 @@ #include "ephy-location-entry.h" #include "ephy-marshal.h" #include "ephy-debug.h" -#include "ephy-file-helpers.h" #include <gtk/gtktoolbar.h> -#include <gtk/gtkliststore.h> -#include <gtk/gtkcomboboxentry.h> #include <gtk/gtkentry.h> #include <gtk/gtkwindow.h> #include <gtk/gtkcellrenderertext.h> @@ -40,15 +37,10 @@ struct _EphyLocationEntryPrivate { - EphyTreeModelNode *combo_model; - GtkWidget *combo; GtkWidget *entry; char *before_completion; gboolean user_changed; gboolean activation_mode; - EphyNodeDb *combo_db; - EphyNode *combo_root; - char *xml_file; guint text_col; guint action_col; @@ -68,7 +60,6 @@ static int n_web_prefixes = G_N_ELEMENTS (web_prefixes); static void ephy_location_entry_class_init (EphyLocationEntryClass *klass); static void ephy_location_entry_init (EphyLocationEntry *le); -static void ephy_location_entry_finalize (GObject *o); static GObjectClass *parent_class = NULL; @@ -144,8 +135,6 @@ ephy_location_entry_class_init (EphyLocationEntryClass *klass) parent_class = g_type_class_peek_parent (klass); - object_class->finalize = ephy_location_entry_finalize; - tool_item_class->set_tooltip = ephy_location_entry_set_tooltip; EphyLocationEntrySignals[USER_CHANGED] = g_signal_new ( @@ -207,91 +196,6 @@ entry_button_press_cb (GtkWidget *entry, GdkEventButton *event, EphyLocationEntr return FALSE; } -static void -add_to_history (EphyLocationEntry *le, const char *text) -{ - GPtrArray *children; - int i, l, n_items, index = -1; - int *order; - - /* check if it already exists */ - children = ephy_node_get_children (le->priv->combo_root); - n_items = children->len; - for (i = 0; i < n_items; i++) - { - EphyNode *kid; - const char *node_text; - - kid = g_ptr_array_index (children, i); - node_text = ephy_node_get_property_string - (kid, EPHY_NODE_LOC_HISTORY_PROP_TEXT); - - if (strcmp (text, node_text) == 0) - { - index = i; - break; - } - } - ephy_node_thaw (le->priv->combo_root); - - /* it doesnt exist, add it */ - if (index < 0) - { - GValue value = { 0, }; - EphyNode *node; - - node = ephy_node_new (le->priv->combo_db); - g_value_init (&value, G_TYPE_STRING); - g_value_set_string (&value, text); - ephy_node_set_property (node, EPHY_NODE_LOC_HISTORY_PROP_TEXT, - &value); - - if (n_items >= MAX_LOC_HISTORY_ITEMS) - { - EphyNode *last; - - last = ephy_node_get_nth_child - (le->priv->combo_root, n_items - 1); - ephy_node_remove_child (le->priv->combo_root, last); - } - - ephy_node_add_child (le->priv->combo_root, node); - } - - /* move it at the top */ - n_items = ephy_node_get_n_children (le->priv->combo_root); - order = g_new0 (int, n_items); - l = 1; - if (index == -1) index = n_items -1; - for (i = 0; i < n_items; i++) - { - if (index != i) - { - order[i] = l; - l++; - } - else - { - order[i] = 0; - } - } - ephy_node_reorder_children (le->priv->combo_root, order); - g_free (order); -} - -static void -entry_activate_cb (GtkEntry *entry, EphyLocationEntry *le) -{ - char *content; - - content = gtk_editable_get_chars (GTK_EDITABLE(entry), 0, -1); - if (content) - { - add_to_history (le, content); - g_free (content); - } -} - static gboolean completion_func (GtkEntryCompletion *completion, const char *key, @@ -376,26 +280,17 @@ static void ephy_location_entry_construct_contents (EphyLocationEntry *le) { EphyLocationEntryPrivate *p = le->priv; - int combo_text_col; LOG ("EphyLocationEntry constructing contents %p", le) - p->combo_model = ephy_tree_model_node_new (p->combo_root, NULL); - combo_text_col = ephy_tree_model_node_add_prop_column - (p->combo_model, G_TYPE_STRING, EPHY_NODE_LOC_HISTORY_PROP_TEXT); - - p->combo = gtk_combo_box_entry_new (GTK_TREE_MODEL (p->combo_model), - combo_text_col); - gtk_container_add (GTK_CONTAINER (le), p->combo); - gtk_widget_show (p->combo); - p->entry = GTK_BIN (p->combo)->child; + p->entry = gtk_entry_new (); + gtk_container_add (GTK_CONTAINER (le), p->entry); + gtk_widget_show (p->entry); g_signal_connect (p->entry, "button_press_event", G_CALLBACK (entry_button_press_cb), le); g_signal_connect (p->entry, "changed", G_CALLBACK (editable_changed_cb), le); - g_signal_connect (p->entry, "activate", - G_CALLBACK (entry_activate_cb), le); } static void @@ -410,15 +305,6 @@ ephy_location_entry_init (EphyLocationEntry *le) p->user_changed = TRUE; p->activation_mode = FALSE; - p->combo_db = ephy_node_db_new ("NodeDB"); - p->combo_root = ephy_node_new_with_id - (p->combo_db, LOCATION_HISTORY_NODE_ID); - p->xml_file = g_build_filename (ephy_dot_dir (), - "ephy-location-history.xml", - NULL); - ephy_node_db_load_from_file (p->combo_db, p->xml_file, - EPHY_LOC_HISTORY_XML_ROOT, - EPHY_LOC_HISTORY_XML_VERSION); ephy_location_entry_construct_contents (le); @@ -429,51 +315,6 @@ ephy_location_entry_init (EphyLocationEntry *le) G_CALLBACK (location_focus_out_cb), le); } -static void -save_location_history (EphyLocationEntry *le) -{ - xmlDocPtr doc; - xmlNodePtr root; - GPtrArray *children; - int i; - - xmlIndentTreeOutput = TRUE; - - doc = xmlNewDoc ("1.0"); - root = xmlNewDocNode (doc, NULL, EPHY_LOC_HISTORY_XML_ROOT, NULL); - xmlSetProp (root, "version", EPHY_LOC_HISTORY_XML_VERSION); - xmlDocSetRootElement (doc, root); - - children = ephy_node_get_children (le->priv->combo_root); - for (i = 0; i < children->len; i++) - { - EphyNode *kid; - - kid = g_ptr_array_index (children, i); - - ephy_node_save_to_xml (kid, root); - } - ephy_node_thaw (le->priv->combo_root); - - ephy_file_save_xml (le->priv->xml_file, doc); - xmlFreeDoc(doc); -} - -static void -ephy_location_entry_finalize (GObject *o) -{ - EphyLocationEntry *le; - - le = EPHY_LOCATION_ENTRY (o); - - save_location_history (le); - g_free (le->priv->xml_file); - - LOG ("EphyLocationEntry finalized") - - G_OBJECT_CLASS (parent_class)->finalize (o); -} - GtkWidget * ephy_location_entry_new (void) { @@ -579,23 +420,3 @@ ephy_location_entry_activate (EphyLocationEntry *le) gtk_window_set_focus (GTK_WINDOW(toplevel), le->priv->entry); } - -void -ephy_location_entry_clear_history (EphyLocationEntry *le) -{ - EphyNode *node; - - while ((node = ephy_node_get_nth_child (le->priv->combo_root, 0)) != NULL) - { - ephy_node_unref (node); - } - - save_location_history (le); -} - -GtkWidget * -ephy_location_entry_get_entry (EphyLocationEntry *le) -{ - return le->priv->entry; -} - diff --git a/lib/widgets/ephy-location-entry.h b/lib/widgets/ephy-location-entry.h index f516a1ad7..6445fad15 100644 --- a/lib/widgets/ephy-location-entry.h +++ b/lib/widgets/ephy-location-entry.h @@ -60,8 +60,6 @@ GType ephy_location_entry_get_type (void); GtkWidget *ephy_location_entry_new (void); -GtkWidget *ephy_location_entry_get_entry (EphyLocationEntry *le); - void ephy_location_entry_set_completion (EphyLocationEntry *le, GtkTreeModel *model, guint text_col, @@ -76,6 +74,4 @@ const char *ephy_location_entry_get_location (EphyLocationEntry *le); void ephy_location_entry_activate (EphyLocationEntry *le); -void ephy_location_entry_clear_history (EphyLocationEntry *le); - #endif diff --git a/src/ephy-history-window.c b/src/ephy-history-window.c index 8db577231..22e1d3b68 100644 --- a/src/ephy-history-window.c +++ b/src/ephy-history-window.c @@ -223,25 +223,11 @@ static void confirmation_dialog_response_cb (GtkDialog *dialog, gint response, EphyHistoryWindow *editor) { - const GList *windows; - Session *session; - gtk_widget_destroy (GTK_WIDGET (dialog)); if (response != GTK_RESPONSE_OK) return; - session = EPHY_SESSION (ephy_shell_get_session (ephy_shell)); - windows = session_get_windows (session); - - for (; windows != NULL; windows = windows->next) - { - Toolbar *t; - - t = ephy_window_get_toolbar (EPHY_WINDOW (windows->data)); - toolbar_clear_location_history (t); - } - ephy_history_clear (editor->priv->history); } diff --git a/src/ephy-location-action.c b/src/ephy-location-action.c index 0d90e8e24..73568195a 100644 --- a/src/ephy-location-action.c +++ b/src/ephy-location-action.c @@ -172,7 +172,7 @@ remove_completion_actions (GtkAction *action, GtkWidget *proxy) EphyLocationAction *la = EPHY_LOCATION_ACTION (action); GList *l; - entry = ephy_location_entry_get_entry (EPHY_LOCATION_ENTRY (proxy)); + entry = GTK_BIN (proxy)->child; completion = gtk_entry_get_completion (GTK_ENTRY (entry)); for (l = la->priv->actions; l != NULL; l = l->next) @@ -195,7 +195,7 @@ add_completion_actions (GtkAction *action, GtkWidget *proxy) EphyLocationAction *la = EPHY_LOCATION_ACTION (action); GList *l; - entry = ephy_location_entry_get_entry (EPHY_LOCATION_ENTRY (proxy)); + entry = GTK_BIN (proxy)->child; completion = gtk_entry_get_completion (GTK_ENTRY (entry)); for (l = la->priv->actions; l != NULL; l = l->next) @@ -238,7 +238,7 @@ connect_proxy (GtkAction *action, GtkWidget *proxy) g_signal_connect_object (action, "notify::address", G_CALLBACK (sync_address), proxy, 0); - entry = ephy_location_entry_get_entry (EPHY_LOCATION_ENTRY (proxy)); + entry = GTK_BIN (proxy)->child; g_signal_connect_object (entry, "activate", G_CALLBACK (location_url_activate_cb), action, 0); @@ -478,22 +478,3 @@ ephy_location_action_set_address (EphyLocationAction *action, action->priv->address = g_strdup (address ? address : ""); g_object_notify (G_OBJECT (action), "address"); } - -static void -clear_history (GtkWidget *proxy, gpointer user_data) -{ - if (EPHY_IS_LOCATION_ENTRY (proxy)) - { - ephy_location_entry_clear_history (EPHY_LOCATION_ENTRY (proxy)); - } -} - -void -ephy_location_action_clear_history (EphyLocationAction *action) -{ - GSList *proxies; - - proxies = gtk_action_get_proxies (GTK_ACTION (action)); - - g_slist_foreach (proxies, (GFunc) clear_history, NULL); -} diff --git a/src/ephy-location-action.h b/src/ephy-location-action.h index 8058eb64f..74de3b175 100644 --- a/src/ephy-location-action.h +++ b/src/ephy-location-action.h @@ -57,8 +57,6 @@ const char *ephy_location_action_get_address (EphyLocationAction *action); void ephy_location_action_set_address (EphyLocationAction *action, const char *address); -void ephy_location_action_clear_history (EphyLocationAction *action); - G_END_DECLS #endif diff --git a/src/toolbar.c b/src/toolbar.c index a1b4553f1..025938e34 100755 --- a/src/toolbar.c +++ b/src/toolbar.c @@ -644,18 +644,6 @@ toolbar_get_location (Toolbar *t) } void -toolbar_clear_location_history (Toolbar *t) -{ - GtkActionGroup *action_group; - GtkAction *action; - - action_group = t->priv->action_group; - action = gtk_action_group_get_action (action_group, "Location"); - - ephy_location_action_clear_history (EPHY_LOCATION_ACTION (action)); -} - -void toolbar_update_navigation_actions (Toolbar *t, gboolean back, gboolean forward, gboolean up) { GtkActionGroup *action_group; diff --git a/src/toolbar.h b/src/toolbar.h index f62021a20..6e4fecdf2 100644 --- a/src/toolbar.h +++ b/src/toolbar.h @@ -63,8 +63,6 @@ void toolbar_set_location (Toolbar *t, void toolbar_activate_location (Toolbar *t); -void toolbar_clear_location_history (Toolbar *t); - void toolbar_update_favicon (Toolbar *t); void toolbar_update_navigation_actions (Toolbar *t, |