diff options
author | Xan Lopez <xan@igalia.com> | 2012-03-20 19:15:09 +0800 |
---|---|---|
committer | Xan Lopez <xan@igalia.com> | 2012-03-20 19:15:09 +0800 |
commit | f788322f9acdf3b490e3bba7aaf3c4c8d66f9ffb (patch) | |
tree | 0382bb1e4cab624b9e80403de0e0379a92f97f15 /embed | |
parent | faf0c7c89a02f38e2272048ae6aa3ba3e11e5f63 (diff) | |
download | gsoc2013-epiphany-f788322f9acdf3b490e3bba7aaf3c4c8d66f9ffb.tar gsoc2013-epiphany-f788322f9acdf3b490e3bba7aaf3c4c8d66f9ffb.tar.gz gsoc2013-epiphany-f788322f9acdf3b490e3bba7aaf3c4c8d66f9ffb.tar.bz2 gsoc2013-epiphany-f788322f9acdf3b490e3bba7aaf3c4c8d66f9ffb.tar.lz gsoc2013-epiphany-f788322f9acdf3b490e3bba7aaf3c4c8d66f9ffb.tar.xz gsoc2013-epiphany-f788322f9acdf3b490e3bba7aaf3c4c8d66f9ffb.tar.zst gsoc2013-epiphany-f788322f9acdf3b490e3bba7aaf3c4c8d66f9ffb.zip |
Remove EphyHistory from the repository. It's unused now.
Diffstat (limited to 'embed')
-rw-r--r-- | embed/Makefile.am | 2 | ||||
-rw-r--r-- | embed/ephy-embed-shell.c | 27 | ||||
-rw-r--r-- | embed/ephy-embed-shell.h | 2 | ||||
-rw-r--r-- | embed/ephy-history.c | 1058 | ||||
-rw-r--r-- | embed/ephy-history.h | 134 | ||||
-rw-r--r-- | embed/ephy-web-view.c | 8 |
6 files changed, 1 insertions, 1230 deletions
diff --git a/embed/Makefile.am b/embed/Makefile.am index ddcdb14c6..4b0ee88fc 100644 --- a/embed/Makefile.am +++ b/embed/Makefile.am @@ -25,7 +25,6 @@ INST_H_FILES = \ ephy-embed-single.h \ ephy-embed-shell.h \ ephy-embed-utils.h \ - ephy-history.h \ ephy-permission-manager.h \ ephy-web-view.h @@ -46,7 +45,6 @@ libephyembed_la_SOURCES = \ ephy-embed-shell.c \ ephy-embed-utils.c \ ephy-encodings.c \ - ephy-history.c \ ephy-permission-manager.c \ ephy-request-about.c \ ephy-embed-prefs.c \ diff --git a/embed/ephy-embed-shell.c b/embed/ephy-embed-shell.c index 3b521f18a..c359afac6 100644 --- a/embed/ephy-embed-shell.c +++ b/embed/ephy-embed-shell.c @@ -35,7 +35,6 @@ #include "ephy-embed-type-builtins.h" #include "ephy-encodings.h" #include "ephy-file-helpers.h" -#include "ephy-history.h" #include "ephy-history-service.h" #include "ephy-print-utils.h" @@ -50,7 +49,6 @@ struct _EphyEmbedShellPrivate { - EphyHistory *global_history; EphyHistoryService *global_history_service; GList *downloads; EphyEmbedSingle *embed_single; @@ -129,12 +127,6 @@ ephy_embed_shell_finalize (GObject *object) shell->priv->downloads = NULL; } - if (shell->priv->global_history) - { - LOG ("Unref history"); - g_object_unref (shell->priv->global_history); - } - if (shell->priv->global_history_service) { LOG ("Unref history service"); @@ -158,25 +150,6 @@ ephy_embed_shell_finalize (GObject *object) } /** - * ephy_embed_shell_get_global_history: - * @shell: the #EphyEmbedShell - * - * Return value: (transfer none): - **/ -GObject * -ephy_embed_shell_get_global_history (EphyEmbedShell *shell) -{ - g_return_val_if_fail (EPHY_IS_EMBED_SHELL (shell), NULL); - - if (shell->priv->global_history == NULL) - { - shell->priv->global_history = ephy_history_new (); - } - - return G_OBJECT (shell->priv->global_history); -} - -/** * ephy_embed_shell_get_global_history_service: * @shell: the #EphyEmbedShell * diff --git a/embed/ephy-embed-shell.h b/embed/ephy-embed-shell.h index 84b507fbc..97ec38a06 100644 --- a/embed/ephy-embed-shell.h +++ b/embed/ephy-embed-shell.h @@ -79,8 +79,6 @@ GType ephy_embed_shell_get_type (void); EphyEmbedShell *ephy_embed_shell_get_default (void); -GObject *ephy_embed_shell_get_global_history (EphyEmbedShell *shell); - GObject *ephy_embed_shell_get_global_history_service (EphyEmbedShell *shell); GObject *ephy_embed_shell_get_encodings (EphyEmbedShell *shell); diff --git a/embed/ephy-history.c b/embed/ephy-history.c deleted file mode 100644 index 0964dca95..000000000 --- a/embed/ephy-history.c +++ /dev/null @@ -1,1058 +0,0 @@ -/* -*- Mode: C; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */ -/* - * Copyright © 2002, 2003 Marco Pesenti Gritti - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2, or (at your option) - * any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. - * - */ - -#include "config.h" - -#include "ephy-history.h" -#include "ephy-file-helpers.h" -#include "ephy-debug.h" -#include "ephy-node-db.h" -#include "ephy-node-common.h" -#include "ephy-prefs.h" -#include "ephy-request-about.h" -#include "ephy-settings.h" -#include "ephy-string.h" - -#include <time.h> -#include <string.h> -#include <glib/gi18n.h> - -#define EPHY_HISTORY_XML_ROOT (const xmlChar *)"ephy_history" -#define EPHY_HISTORY_XML_VERSION (const xmlChar *)"1.0" - -/* how often to save the history, in seconds */ -#define HISTORY_SAVE_INTERVAL (5 * 60) - -/* if you change this remember to change also the user interface description */ -#define HISTORY_PAGE_OBSOLETE_DAYS 10 - -/* the number of seconds in a day */ -#define SECS_PER_DAY (60*60*24) - -#define EPHY_HISTORY_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), EPHY_TYPE_HISTORY, EphyHistoryPrivate)) - -struct _EphyHistoryPrivate -{ - char *xml_file; - EphyNodeDb *db; - EphyNode *hosts; - EphyNode *pages; - EphyNode *last_page; - GHashTable *hosts_hash; - GHashTable *pages_hash; - guint autosave_timeout; - guint update_hosts_idle; - gboolean dirty; - gboolean enabled; -}; - -enum -{ - REDIRECT_FLAG = 1 << 0, - TOPLEVEL_FLAG = 1 << 1 -}; - -enum -{ - PROP_0, - PROP_ENABLED -}; - -enum -{ - ADD_PAGE, - VISITED, - CLEARED, - REDIRECT, - ICON_UPDATED, - LAST_SIGNAL -}; - -static guint signals[LAST_SIGNAL]; - -static void ephy_history_class_init (EphyHistoryClass *klass); -static void ephy_history_init (EphyHistory *history); -static void ephy_history_finalize (GObject *object); -static gboolean impl_add_page (EphyHistory *, const char *, gboolean, gboolean); - -G_DEFINE_TYPE (EphyHistory, ephy_history, G_TYPE_OBJECT) - -static void -ephy_history_set_property (GObject *object, - guint prop_id, - const GValue *value, - GParamSpec *pspec) -{ - EphyHistory *history = EPHY_HISTORY (object); - - switch (prop_id) - { - case PROP_ENABLED: - ephy_history_set_enabled (history, g_value_get_boolean (value)); - break; - } -} - -static void -ephy_history_get_property (GObject *object, - guint prop_id, - GValue *value, - GParamSpec *pspec) -{ - EphyHistory *history = EPHY_HISTORY (object); - - switch (prop_id) - { - case PROP_ENABLED: - g_value_set_boolean (value, history->priv->enabled); - break; - } -} - -static void -ephy_history_class_init (EphyHistoryClass *klass) -{ - GObjectClass *object_class = G_OBJECT_CLASS (klass); - - object_class->finalize = ephy_history_finalize; - object_class->get_property = ephy_history_get_property; - object_class->set_property = ephy_history_set_property; - - klass->add_page = impl_add_page; - - g_object_class_install_property (object_class, - PROP_ENABLED, - g_param_spec_boolean ("enabled", - "Enabled", - "Enabled", - TRUE, - G_PARAM_READWRITE | G_PARAM_STATIC_NAME | G_PARAM_STATIC_NICK | G_PARAM_STATIC_BLURB)); - - signals[ADD_PAGE] = - g_signal_new ("add_page", - G_OBJECT_CLASS_TYPE (object_class), - G_SIGNAL_RUN_LAST, - G_STRUCT_OFFSET (EphyHistoryClass, add_page), - g_signal_accumulator_true_handled, NULL, - g_cclosure_marshal_generic, - G_TYPE_BOOLEAN, - 3, - G_TYPE_STRING | G_SIGNAL_TYPE_STATIC_SCOPE, - G_TYPE_BOOLEAN, - G_TYPE_BOOLEAN); - - signals[VISITED] = - g_signal_new ("visited", - G_OBJECT_CLASS_TYPE (object_class), - G_SIGNAL_RUN_FIRST, - G_STRUCT_OFFSET (EphyHistoryClass, visited), - NULL, NULL, - g_cclosure_marshal_VOID__STRING, - G_TYPE_NONE, - 1, - G_TYPE_STRING); - - signals[CLEARED] = - g_signal_new ("cleared", - G_OBJECT_CLASS_TYPE (object_class), - G_SIGNAL_RUN_FIRST, - G_STRUCT_OFFSET (EphyHistoryClass, cleared), - NULL, NULL, - g_cclosure_marshal_VOID__VOID, - G_TYPE_NONE, - 0); - - signals[REDIRECT] = - g_signal_new ("redirect", - G_OBJECT_CLASS_TYPE (object_class), - G_SIGNAL_RUN_FIRST, - G_STRUCT_OFFSET (EphyHistoryClass, redirect), - NULL, NULL, - g_cclosure_marshal_generic, - G_TYPE_NONE, - 2, - G_TYPE_STRING | G_SIGNAL_TYPE_STATIC_SCOPE, - G_TYPE_STRING | G_SIGNAL_TYPE_STATIC_SCOPE); - - signals[ICON_UPDATED] = - g_signal_new ("icon_updated", - G_OBJECT_CLASS_TYPE (object_class), - G_SIGNAL_RUN_FIRST, - G_STRUCT_OFFSET (EphyHistoryClass, icon_updated), - NULL, NULL, - g_cclosure_marshal_generic, - G_TYPE_NONE, - 2, - G_TYPE_STRING, G_TYPE_STRING); - - g_type_class_add_private (object_class, sizeof (EphyHistoryPrivate)); -} - -static gboolean -page_is_obsolete (EphyNode *node, time_t now) -{ - int last_visit; - - last_visit = ephy_node_get_property_int - (node, EPHY_NODE_PAGE_PROP_LAST_VISIT); - return now - last_visit >= HISTORY_PAGE_OBSOLETE_DAYS*SECS_PER_DAY; -} - -static void -remove_obsolete_pages (EphyHistory *eb) -{ - GPtrArray *children; - int i; - time_t now; - - now = time (NULL); - - children = ephy_node_get_children (eb->priv->pages); - for (i = (int) children->len - 1; i >= 0; i--) - { - EphyNode *kid; - - kid = g_ptr_array_index (children, i); - - if (page_is_obsolete (kid, now)) - { - ephy_node_unref (kid); - } - } -} - -static gboolean -save_filter (EphyNode *node, - EphyNode *page_node) -{ - return node != page_node; -} - -static void -ephy_history_save (EphyHistory *eb) -{ - int ret; - - /* only save if there are changes */ - if (eb->priv->dirty == FALSE && eb->priv->enabled) - { - return; - } - - LOG ("Saving history db"); - - ret = ephy_node_db_write_to_xml_safe - (eb->priv->db, (const xmlChar *)eb->priv->xml_file, - EPHY_HISTORY_XML_ROOT, - EPHY_HISTORY_XML_VERSION, - NULL, /* comment */ - eb->priv->hosts, - (EphyNodeFilterFunc) save_filter, eb->priv->pages, - eb->priv->pages, NULL, NULL, - NULL); - - if (ret >=0) - { - /* save was successful */ - eb->priv->dirty = FALSE; - } -} - -static void -hosts_added_cb (EphyNode *node, - EphyNode *child, - EphyHistory *eb) -{ - eb->priv->dirty = TRUE; - - g_hash_table_insert (eb->priv->hosts_hash, - (char *) ephy_node_get_property_string (child, EPHY_NODE_PAGE_PROP_LOCATION), - child); -} - -static void -hosts_removed_cb (EphyNode *node, - EphyNode *child, - guint old_index, - EphyHistory *eb) -{ - eb->priv->dirty = TRUE; - - g_hash_table_remove (eb->priv->hosts_hash, - ephy_node_get_property_string (child, EPHY_NODE_PAGE_PROP_LOCATION)); -} - -static void -hosts_changed_cb (EphyNode *node, - EphyNode *child, - guint property_id, - EphyHistory *eb) -{ - eb->priv->dirty = TRUE; -} - -static void -pages_added_cb (EphyNode *node, - EphyNode *child, - EphyHistory *eb) -{ - eb->priv->dirty = TRUE; - - g_hash_table_insert (eb->priv->pages_hash, - (char *) ephy_node_get_property_string (child, EPHY_NODE_PAGE_PROP_LOCATION), - child); -} - -static void -pages_removed_cb (EphyNode *node, - EphyNode *child, - guint old_index, - EphyHistory *eb) -{ - eb->priv->dirty = TRUE; - - g_hash_table_remove (eb->priv->pages_hash, - ephy_node_get_property_string (child, EPHY_NODE_PAGE_PROP_LOCATION)); -} - -static void -pages_changed_cb (EphyNode *node, - EphyNode *child, - guint property_id, - EphyHistory *eb) -{ - eb->priv->dirty = TRUE; -} - -static gboolean -periodic_save_cb (EphyHistory *eh) -{ - remove_obsolete_pages (eh); - ephy_history_save (eh); - - return TRUE; -} - -static void -update_host_on_child_remove (EphyNode *node) -{ - GPtrArray *children; - int i, host_last_visit, new_host_last_visit = 0; - - host_last_visit = ephy_node_get_property_int - (node, EPHY_NODE_PAGE_PROP_LAST_VISIT); - - children = ephy_node_get_children (node); - for (i = 0; i < children->len; i++) - { - EphyNode *kid; - int last_visit; - - kid = g_ptr_array_index (children, i); - - last_visit = ephy_node_get_property_int - (kid, EPHY_NODE_PAGE_PROP_LAST_VISIT); - - if (last_visit > new_host_last_visit) - { - new_host_last_visit = last_visit; - } - } - - if (host_last_visit != new_host_last_visit) - { - ephy_node_set_property_int (node, - EPHY_NODE_PAGE_PROP_LAST_VISIT, - new_host_last_visit); - } -} - -static gboolean -update_hosts (EphyHistory *eh) -{ - GPtrArray *children; - int i; - GList *empty = NULL; - - children = ephy_node_get_children (eh->priv->hosts); - for (i = 0; i < children->len; i++) - { - EphyNode *kid; - - kid = g_ptr_array_index (children, i); - - if (kid != eh->priv->pages) - { - if (ephy_node_get_n_children (kid) > 0) - { - update_host_on_child_remove (kid); - } - else - { - empty = g_list_prepend (empty, kid); - } - } - } - - g_list_foreach (empty, (GFunc)ephy_node_unref, NULL); - g_list_free (empty); - - eh->priv->update_hosts_idle = 0; - - return FALSE; -} - -static void -page_removed_from_host_cb (EphyNode *node, - EphyNode *child, - guint old_index, - EphyHistory *eb) -{ - if (eb->priv->update_hosts_idle == 0) - { - eb->priv->update_hosts_idle = g_idle_add - ((GSourceFunc)update_hosts, eb); - } -} - -static void -remove_pages_from_host_cb (EphyNode *host, - EphyHistory *eh) -{ - GPtrArray *children; - EphyNode *site; - int i; - - children = ephy_node_get_children (host); - - for (i = (int) children->len - 1; i >= 0; i--) - { - site = g_ptr_array_index (children, i); - - ephy_node_unref (site); - } -} - -static void -connect_page_removed_from_host (char *url, - EphyNode *node, - EphyHistory *eb) -{ - if (node == eb->priv->pages) return; - - ephy_node_signal_connect_object (node, - EPHY_NODE_CHILD_REMOVED, - (EphyNodeCallback) page_removed_from_host_cb, - G_OBJECT (eb)); - ephy_node_signal_connect_object (node, - EPHY_NODE_DESTROY, - (EphyNodeCallback) remove_pages_from_host_cb, - G_OBJECT (eb)); -} - -static void -ephy_history_init (EphyHistory *eb) -{ - EphyNodeDb *db; - const char *all = _("All"); - - eb->priv = EPHY_HISTORY_GET_PRIVATE (eb); - eb->priv->update_hosts_idle = 0; - eb->priv->enabled = TRUE; - - db = ephy_node_db_new (EPHY_NODE_DB_HISTORY); - eb->priv->db = db; - - eb->priv->xml_file = g_build_filename (ephy_dot_dir (), - "ephy-history.xml", - NULL); - - eb->priv->pages_hash = g_hash_table_new (g_str_hash, - g_str_equal); - eb->priv->hosts_hash = g_hash_table_new (g_str_hash, - g_str_equal); - - /* Pages */ - eb->priv->pages = ephy_node_new_with_id (db, PAGES_NODE_ID); - - ephy_node_set_property_string (eb->priv->pages, - EPHY_NODE_PAGE_PROP_LOCATION, - all); - ephy_node_set_property_string (eb->priv->pages, - EPHY_NODE_PAGE_PROP_TITLE, - all); - - ephy_node_set_property_int (eb->priv->pages, - EPHY_NODE_PAGE_PROP_PRIORITY, - EPHY_NODE_ALL_PRIORITY); - - ephy_node_signal_connect_object (eb->priv->pages, - EPHY_NODE_CHILD_ADDED, - (EphyNodeCallback) pages_added_cb, - G_OBJECT (eb)); - ephy_node_signal_connect_object (eb->priv->pages, - EPHY_NODE_CHILD_REMOVED, - (EphyNodeCallback) pages_removed_cb, - G_OBJECT (eb)); - ephy_node_signal_connect_object (eb->priv->pages, - EPHY_NODE_CHILD_CHANGED, - (EphyNodeCallback) pages_changed_cb, - G_OBJECT (eb)); - - /* Hosts */ - eb->priv->hosts = ephy_node_new_with_id (db, HOSTS_NODE_ID); - ephy_node_signal_connect_object (eb->priv->hosts, - EPHY_NODE_CHILD_ADDED, - (EphyNodeCallback) hosts_added_cb, - G_OBJECT (eb)); - ephy_node_signal_connect_object (eb->priv->hosts, - EPHY_NODE_CHILD_REMOVED, - (EphyNodeCallback) hosts_removed_cb, - G_OBJECT (eb)); - ephy_node_signal_connect_object (eb->priv->hosts, - EPHY_NODE_CHILD_CHANGED, - (EphyNodeCallback) hosts_changed_cb, - G_OBJECT (eb)); - - ephy_node_add_child (eb->priv->hosts, eb->priv->pages); - - ephy_node_db_load_from_file (eb->priv->db, eb->priv->xml_file, - EPHY_HISTORY_XML_ROOT, - EPHY_HISTORY_XML_VERSION); - - g_hash_table_foreach (eb->priv->hosts_hash, - (GHFunc) connect_page_removed_from_host, - eb); - - /* mark as clean */ - eb->priv->dirty = FALSE; - - /* setup the periodic history saving callback */ - eb->priv->autosave_timeout = - g_timeout_add_seconds (HISTORY_SAVE_INTERVAL, - (GSourceFunc)periodic_save_cb, - eb); - - g_settings_bind (EPHY_SETTINGS_LOCKDOWN, - EPHY_PREFS_LOCKDOWN_HISTORY, - eb, "enabled", - G_SETTINGS_BIND_INVERT_BOOLEAN | G_SETTINGS_BIND_GET); -} - -static void -ephy_history_finalize (GObject *object) -{ - EphyHistory *eb = EPHY_HISTORY (object); - - if (eb->priv->update_hosts_idle) - { - g_source_remove (eb->priv->update_hosts_idle); - } - - ephy_history_save (eb); - - ephy_node_unref (eb->priv->pages); - ephy_node_unref (eb->priv->hosts); - - g_object_unref (eb->priv->db); - - g_hash_table_destroy (eb->priv->pages_hash); - g_hash_table_destroy (eb->priv->hosts_hash); - - g_source_remove (eb->priv->autosave_timeout); - - g_free (eb->priv->xml_file); - - LOG ("Global history finalized"); - - G_OBJECT_CLASS (ephy_history_parent_class)->finalize (object); -} - -EphyHistory * -ephy_history_new (void) -{ - return EPHY_HISTORY (g_object_new (EPHY_TYPE_HISTORY, NULL)); -} - -static void -ephy_history_host_visited (EphyHistory *eh, - EphyNode *host, - GTime now) -{ - int visits; - - LOG ("Host visited"); - - visits = ephy_node_get_property_int - (host, EPHY_NODE_PAGE_PROP_VISITS); - if (visits < 0) visits = 0; - visits++; - - ephy_node_set_property_int (host, EPHY_NODE_PAGE_PROP_VISITS, visits); - ephy_node_set_property_int (host, EPHY_NODE_PAGE_PROP_LAST_VISIT, - now); -} - -static EphyNode * -internal_get_host (EphyHistory *eh, const char *url, gboolean create) -{ - EphyNode *host = NULL; - char *host_name = NULL; - GList *host_locations = NULL, *l; - char *scheme = NULL; - GTime now; - - g_return_val_if_fail (url != NULL, NULL); - - if (eh->priv->enabled == FALSE) - { - return NULL; - } - - now = time (NULL); - - if (url) - { - scheme = g_uri_parse_scheme (url); - host_name = ephy_string_get_host_name (url); - } - - /* Build an host name */ - if (scheme == NULL || host_name == NULL) - { - host_name = g_strdup (_("Others")); - host_locations = g_list_append (host_locations, - g_strdup ("about:blank")); - } - else if (strcmp (scheme, "file") == 0) - { - host_name = g_strdup (_("Local files")); - host_locations = g_list_append (host_locations, - g_strdup ("file:///")); - } - else - { - char *location; - char *tmp; - - if (g_str_equal (scheme, "https")) - { - /* If scheme is https, we still fake http. */ - location = g_strconcat ("http://", host_name, "/", NULL); - host_locations = g_list_append (host_locations, location); - } - - /* We append the real address */ - location = g_strconcat (scheme, - "://", host_name, "/", NULL); - host_locations = g_list_append (host_locations, location); - - /* and also a fake www-modified address if it's http or https. */ - if (g_str_has_prefix (scheme, "http")) - { - if (g_str_has_prefix (host_name, "www.")) - { - tmp = g_strdup (host_name + 4); - } - else - { - tmp = g_strconcat ("www.", host_name, NULL); - } - location = g_strconcat ("http://", tmp, "/", NULL); - g_free (tmp); - host_locations = g_list_append (host_locations, location); - } - } - - g_return_val_if_fail (host_locations != NULL, NULL); - - for (l = host_locations; l != NULL; l = l->next) - { - host = g_hash_table_lookup (eh->priv->hosts_hash, - (char *)l->data); - if (host) break; - } - - if (!host && create) - { - host = ephy_node_new (eh->priv->db); - ephy_node_signal_connect_object (host, - EPHY_NODE_CHILD_REMOVED, - (EphyNodeCallback) page_removed_from_host_cb, - G_OBJECT (eh)); - ephy_node_signal_connect_object (host, - EPHY_NODE_DESTROY, - (EphyNodeCallback) remove_pages_from_host_cb, - G_OBJECT (eh)); - ephy_node_set_property_string (host, - EPHY_NODE_PAGE_PROP_TITLE, - host_name); - ephy_node_set_property_string (host, - EPHY_NODE_PAGE_PROP_LOCATION, - (char *)host_locations->data); - ephy_node_set_property_int (host, - EPHY_NODE_PAGE_PROP_FIRST_VISIT, - now); - ephy_node_add_child (eh->priv->hosts, host); - } - - if (host) - { - ephy_history_host_visited (eh, host, now); - } - - g_free (scheme); - g_free (host_name); - - g_list_foreach (host_locations, (GFunc)g_free, NULL); - g_list_free (host_locations); - - return host; -} - -/** - * ephy_history_get_host: - * - * Return value: (transfer none): - **/ -EphyNode * -ephy_history_get_host (EphyHistory *eh, const char *url) -{ - return internal_get_host (eh, url, FALSE); -} - -static EphyNode * -ephy_history_add_host (EphyHistory *eh, EphyNode *page) -{ - const char *url; - - url = ephy_node_get_property_string - (page, EPHY_NODE_PAGE_PROP_LOCATION); - - return internal_get_host (eh, url, TRUE); -} - -static void -ephy_history_visited (EphyHistory *eh, EphyNode *node) -{ - GTime now; - int visits; - const char *url; - int host_id; - - now = time (NULL); - - g_assert (node != NULL); - - url = ephy_node_get_property_string - (node, EPHY_NODE_PAGE_PROP_LOCATION); - - visits = ephy_node_get_property_int - (node, EPHY_NODE_PAGE_PROP_VISITS); - if (visits < 0) visits = 0; - visits++; - - ephy_node_set_property_int (node, EPHY_NODE_PAGE_PROP_VISITS, visits); - ephy_node_set_property_int (node, EPHY_NODE_PAGE_PROP_LAST_VISIT, - now); - if (visits == 1) - { - ephy_node_set_property_int - (node, EPHY_NODE_PAGE_PROP_FIRST_VISIT, now); - } - - host_id = ephy_node_get_property_int (node, EPHY_NODE_PAGE_PROP_HOST_ID); - if (host_id >= 0) - { - EphyNode *host; - - host = ephy_node_db_get_node_from_id (eh->priv->db, host_id); - ephy_history_host_visited (eh, host, now); - } - - eh->priv->last_page = node; - - g_signal_emit (G_OBJECT (eh), signals[VISITED], 0, url); -} - -int -ephy_history_get_page_visits (EphyHistory *gh, - const char *url) -{ - EphyNode *node; - int visits = 0; - - node = ephy_history_get_page (gh, url); - if (node) - { - visits = ephy_node_get_property_int - (node, EPHY_NODE_PAGE_PROP_VISITS); - if (visits < 0) visits = 0; - } - - return visits; -} - -void -ephy_history_add_page (EphyHistory *eh, - const char *url, - gboolean redirect, - gboolean toplevel) -{ - gboolean result = FALSE; - - g_signal_emit (eh, signals[ADD_PAGE], 0, url, redirect, toplevel, &result); -} - -static gboolean -impl_add_page (EphyHistory *eb, - const char *orig_url, - gboolean redirect, - gboolean toplevel) -{ - EphyNode *bm, *node, *host; - gulong flags = 0; - char *url; - - if (eb->priv->enabled == FALSE) - { - return FALSE; - } - - /* Do not show internal ephy-about: protocol to users */ - if (g_str_has_prefix (orig_url, EPHY_ABOUT_SCHEME)) - url = g_strdup_printf ("about:%s", orig_url + EPHY_ABOUT_SCHEME_LEN + 1); - else - url = g_strdup (orig_url); - - node = ephy_history_get_page (eb, url); - if (node) - { - ephy_history_visited (eb, node); - g_free (url); - return TRUE; - } - - bm = ephy_node_new (eb->priv->db); - - ephy_node_set_property_string (bm, EPHY_NODE_PAGE_PROP_LOCATION, url); - ephy_node_set_property_string (bm, EPHY_NODE_PAGE_PROP_TITLE, url); - g_free (url); - - if (redirect) flags |= REDIRECT_FLAG; - if (toplevel) flags |= TOPLEVEL_FLAG; - - /* EphyNode SUCKS! */ - ephy_node_set_property_long (bm, EPHY_NODE_PAGE_PROP_EXTRA_FLAGS, - flags); - - host = ephy_history_add_host (eb, bm); - - ephy_node_set_property_int (bm, EPHY_NODE_PAGE_PROP_HOST_ID, - ephy_node_get_id (host)); - - ephy_history_visited (eb, bm); - - ephy_node_add_child (host, bm); - ephy_node_add_child (eb->priv->pages, bm); - - return TRUE; -} - -/** - * ephy_history_get_page: - * - * Return value: (transfer none): - **/ -EphyNode * -ephy_history_get_page (EphyHistory *eb, - const char *url) -{ - EphyNode *node; - - node = g_hash_table_lookup (eb->priv->pages_hash, url); - - return node; -} - -gboolean -ephy_history_is_page_visited (EphyHistory *gh, - const char *url) -{ - return (ephy_history_get_page (gh, url) != NULL); -} - -void -ephy_history_set_page_title (EphyHistory *gh, - const char *url, - const char *title) -{ - EphyNode *node; - - LOG ("Set page title"); - - if (title == NULL || title[0] == '\0') return; - if (url == NULL) return; - - node = ephy_history_get_page (gh, url); - if (node == NULL) return; - - ephy_node_set_property_string (node, EPHY_NODE_PAGE_PROP_TITLE, - title); -} - -const char* -ephy_history_get_icon (EphyHistory *gh, - const char *url) -{ - EphyNode *node, *host; - int host_id; - - node = ephy_history_get_page (gh, url); - if (node == NULL) return NULL; - - host_id = ephy_node_get_property_int (node, EPHY_NODE_PAGE_PROP_HOST_ID); - g_return_val_if_fail (host_id >= 0, NULL); - - host = ephy_node_db_get_node_from_id (gh->priv->db, host_id); - g_return_val_if_fail (host != NULL, NULL); - - return ephy_node_get_property_string (host, EPHY_NODE_PAGE_PROP_ICON); -} - - -void -ephy_history_set_icon (EphyHistory *gh, - const char *url, - const char *icon) -{ - EphyNode *node, *host; - int host_id; - - node = ephy_history_get_page (gh, url); - if (node == NULL) return; - - host_id = ephy_node_get_property_int (node, EPHY_NODE_PAGE_PROP_HOST_ID); - g_return_if_fail (host_id >= 0); - - host = ephy_node_db_get_node_from_id (gh->priv->db, host_id); - if (host) - { - ephy_node_set_property_string (host, EPHY_NODE_PAGE_PROP_ICON, - icon); - } - - g_signal_emit (gh, signals[ICON_UPDATED], 0, url, icon); -} - -void -ephy_history_clear (EphyHistory *gh) -{ - EphyNode *node; - - LOG ("clearing history"); - - ephy_node_db_set_immutable (gh->priv->db, FALSE); - - while ((node = ephy_node_get_nth_child (gh->priv->pages, 0)) != NULL) - { - ephy_node_unref (node); - } - ephy_history_save (gh); - - ephy_node_db_set_immutable (gh->priv->db, !gh->priv->enabled); - - g_signal_emit (gh, signals[CLEARED], 0); -} - -/** - * ephy_history_get_hosts: - * - * Return value: (transfer none): - **/ -EphyNode * -ephy_history_get_hosts (EphyHistory *eb) -{ - return eb->priv->hosts; -} - -/** - * ephy_history_get_pages: - * - * Return value: (transfer none): - **/ -EphyNode * -ephy_history_get_pages (EphyHistory *eb) -{ - return eb->priv->pages; -} - -const char * -ephy_history_get_last_page (EphyHistory *gh) -{ - if (gh->priv->last_page == NULL) return NULL; - - return ephy_node_get_property_string - (gh->priv->last_page, EPHY_NODE_PAGE_PROP_LOCATION); -} - -gboolean -ephy_history_is_enabled (EphyHistory *history) -{ - g_return_val_if_fail (EPHY_IS_HISTORY (history), FALSE); - - return history->priv->enabled; -} - -void -ephy_history_set_enabled (EphyHistory *history, - gboolean enabled) -{ - int ret; - - ret = 1; - - LOG ("ephy_history_set_enabled %d", enabled); - - /* Write history only when disabling it, not when reenabling it */ - if (!enabled && history->priv->dirty) - { - ret = ephy_node_db_write_to_xml_safe - (history->priv->db, (const xmlChar *)history->priv->xml_file, - EPHY_HISTORY_XML_ROOT, - EPHY_HISTORY_XML_VERSION, - NULL, /* comment */ - history->priv->hosts, - (EphyNodeFilterFunc) save_filter, history->priv->pages, - history->priv->pages, NULL, NULL, - NULL); - } - - if (ret >=0) - { - /* save was successful */ - history->priv->dirty = FALSE; - } - - history->priv->enabled = enabled; - - ephy_node_db_set_immutable (history->priv->db, !enabled); -} - diff --git a/embed/ephy-history.h b/embed/ephy-history.h deleted file mode 100644 index 8b423b4ad..000000000 --- a/embed/ephy-history.h +++ /dev/null @@ -1,134 +0,0 @@ -/* - * Copyright © 2000-2003 Marco Pesenti Gritti - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2, or (at your option) - * any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. - * - */ - -#if !defined (__EPHY_EPIPHANY_H_INSIDE__) && !defined (EPIPHANY_COMPILATION) -#error "Only <epiphany/epiphany.h> can be included directly." -#endif - -#ifndef EPHY_HISTORY_H -#define EPHY_HISTORY_H - -#include <glib-object.h> - -#include "ephy-node.h" - -G_BEGIN_DECLS - -#define EPHY_TYPE_HISTORY (ephy_history_get_type ()) -#define EPHY_HISTORY(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), EPHY_TYPE_HISTORY, EphyHistory)) -#define EPHY_HISTORY_CLASS(k) (G_TYPE_CHECK_CLASS_CAST((k), EPHY_TYPE_HISTORY, EphyHistoryClass)) -#define EPHY_IS_HISTORY(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), EPHY_TYPE_HISTORY)) -#define EPHY_IS_HISTORY_CLASS(k) (G_TYPE_CHECK_CLASS_TYPE ((k), EPHY_TYPE_HISTORY)) -#define EPHY_HISTORY_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), EPHY_TYPE_HISTORY, EphyHistoryClass)) - -typedef struct _EphyHistoryClass EphyHistoryClass; -typedef struct _EphyHistory EphyHistory; -typedef struct _EphyHistoryPrivate EphyHistoryPrivate; - -enum -{ - EPHY_NODE_PAGE_PROP_TITLE = 2, - EPHY_NODE_PAGE_PROP_LOCATION = 3, - EPHY_NODE_PAGE_PROP_VISITS = 4, - EPHY_NODE_PAGE_PROP_LAST_VISIT = 5, - EPHY_NODE_PAGE_PROP_FIRST_VISIT = 6, - EPHY_NODE_PAGE_PROP_HOST_ID = 7, - EPHY_NODE_PAGE_PROP_PRIORITY = 8, - EPHY_NODE_PAGE_PROP_ICON = 9, - EPHY_NODE_HOST_PROP_ZOOM = 10, - EPHY_NODE_PAGE_PROP_GECKO_FLAGS = 11, - EPHY_NODE_PAGE_PROP_EXTRA_FLAGS = 12 -}; - -struct _EphyHistory -{ - GObject parent; - - /*< private >*/ - EphyHistoryPrivate *priv; -}; - -struct _EphyHistoryClass -{ - GObjectClass parent_class; - - /* Signals */ - gboolean (* add_page) (EphyHistory *history, - const char *url, - gboolean redirect, - gboolean toplevel); - void (* visited) (EphyHistory *history, - const char *url); - void (* cleared) (EphyHistory *history); - - void (* redirect) (EphyHistory *history, - const char *from_uri, - const char *to_uri); - void (* icon_updated) (EphyHistory *history, - const char *address, - const char *icon); -}; - -GType ephy_history_get_type (void); - -EphyHistory *ephy_history_new (void); - -EphyNode *ephy_history_get_hosts (EphyHistory *gh); - -EphyNode *ephy_history_get_host (EphyHistory *gh, - const char *url); - -EphyNode *ephy_history_get_pages (EphyHistory *gh); - -EphyNode *ephy_history_get_page (EphyHistory *gh, - const char *url); - -void ephy_history_add_page (EphyHistory *gh, - const char *url, - gboolean redirect, - gboolean toplevel); - -gboolean ephy_history_is_page_visited (EphyHistory *gh, - const char *url); - -int ephy_history_get_page_visits (EphyHistory *gh, - const char *url); - -void ephy_history_set_page_title (EphyHistory *gh, - const char *url, - const char *title); - -const char *ephy_history_get_last_page (EphyHistory *gh); - -void ephy_history_set_icon (EphyHistory *gh, - const char *url, - const char *icon); -const char *ephy_history_get_icon (EphyHistory *gh, - const char *url); - -void ephy_history_clear (EphyHistory *gh); - -gboolean ephy_history_is_enabled (EphyHistory *history); - -void ephy_history_set_enabled (EphyHistory *history, - gboolean enabled); - -G_END_DECLS - -#endif diff --git a/embed/ephy-web-view.c b/embed/ephy-web-view.c index 66c057d0e..5a5293ad4 100644 --- a/embed/ephy-web-view.c +++ b/embed/ephy-web-view.c @@ -33,7 +33,6 @@ #include "ephy-embed-utils.h" #include "ephy-embed.h" #include "ephy-file-helpers.h" -#include "ephy-history.h" #include "ephy-history-service.h" #include "ephy-permission-manager.h" #include "ephy-prefs.h" @@ -1610,7 +1609,6 @@ _ephy_web_view_set_icon_address (EphyWebView *view, { GObject *object = G_OBJECT (view); EphyWebViewPrivate *priv = view->priv; - EphyHistory *history; if (priv->icon != NULL) { g_object_unref (priv->icon); @@ -1619,12 +1617,8 @@ _ephy_web_view_set_icon_address (EphyWebView *view, g_object_notify (object, "icon"); } - if (icon_address && priv->address) { - history = EPHY_HISTORY (ephy_embed_shell_get_global_history (embed_shell)); - ephy_history_set_icon (history, priv->address, icon_address); - + if (icon_address && priv->address) _ephy_web_view_load_icon (view); - } } static void |