diff options
Diffstat (limited to 'embed/ephy-history.c')
-rw-r--r-- | embed/ephy-history.c | 68 |
1 files changed, 51 insertions, 17 deletions
diff --git a/embed/ephy-history.c b/embed/ephy-history.c index d3c64d286..ce0f9e017 100644 --- a/embed/ephy-history.c +++ b/embed/ephy-history.c @@ -69,6 +69,7 @@ enum enum { + ADD_PAGE, VISITED, CLEARED, REDIRECT, @@ -80,6 +81,7 @@ static guint signals[LAST_SIGNAL] = { 0 }; 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 *histroy, const char *url); static GObjectClass *parent_class = NULL; @@ -170,6 +172,8 @@ ephy_history_class_init (EphyHistoryClass *klass) 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", @@ -178,6 +182,17 @@ ephy_history_class_init (EphyHistoryClass *klass) TRUE, G_PARAM_READWRITE)); + 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, + ephy_marshal_BOOLEAN__STRING, + G_TYPE_BOOLEAN, + 1, + G_TYPE_STRING | G_SIGNAL_TYPE_STATIC_SCOPE); + signals[VISITED] = g_signal_new ("visited", G_OBJECT_CLASS_TYPE (object_class), @@ -657,18 +672,7 @@ ephy_history_host_visited (EphyHistory *eh, } 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 ephy_history_get_host (eh, url); -} - -EphyNode * -ephy_history_get_host (EphyHistory *eh, const char *url) +internal_get_host (EphyHistory *eh, const char *url, gboolean create) { GnomeVFSURI *vfs_uri = NULL; EphyNode *host = NULL; @@ -740,7 +744,7 @@ ephy_history_get_host (EphyHistory *eh, const char *url) if (host) break; } - if (!host) + if (!host && create) { host = ephy_node_new (eh->priv->db); ephy_node_signal_connect_object (host, @@ -773,7 +777,10 @@ ephy_history_get_host (EphyHistory *eh, const char *url) ephy_node_add_child (eh->priv->hosts, host); } - ephy_history_host_visited (eh, host, now); + if (host) + { + ephy_history_host_visited (eh, host, now); + } if (vfs_uri) { @@ -786,6 +793,23 @@ ephy_history_get_host (EphyHistory *eh, const char *url) return host; } +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) { @@ -857,22 +881,30 @@ ephy_history_get_page_visits (EphyHistory *gh, } void -ephy_history_add_page (EphyHistory *eb, +ephy_history_add_page (EphyHistory *eh, const char *url) { + gboolean result = FALSE; + + g_signal_emit (eh, signals[ADD_PAGE], 0, url, &result); +} + +static gboolean +impl_add_page (EphyHistory *eb, const char *url) +{ EphyNode *bm, *node, *host; GValue value = { 0, }; if (eb->priv->enabled == FALSE) { - return; + return FALSE; } node = ephy_history_get_page (eb, url); if (node) { ephy_history_visited (eb, node); - return; + return TRUE; } bm = ephy_node_new (eb->priv->db); @@ -897,6 +929,8 @@ ephy_history_add_page (EphyHistory *eb, ephy_node_add_child (host, bm); ephy_node_add_child (eb->priv->pages, bm); + + return TRUE; } EphyNode * |