aboutsummaryrefslogtreecommitdiffstats
path: root/lib/history
diff options
context:
space:
mode:
Diffstat (limited to 'lib/history')
-rw-r--r--lib/history/ephy-history-service-hosts-table.c35
-rw-r--r--lib/history/ephy-history-service-urls-table.c28
-rw-r--r--lib/history/ephy-history-service.c76
-rw-r--r--lib/history/ephy-history-service.h1
-rw-r--r--lib/history/ephy-history-types.c14
-rw-r--r--lib/history/ephy-history-types.h7
6 files changed, 96 insertions, 65 deletions
diff --git a/lib/history/ephy-history-service-hosts-table.c b/lib/history/ephy-history-service-hosts-table.c
index 8dcd3d7f4..df4ccf2ec 100644
--- a/lib/history/ephy-history-service-hosts-table.c
+++ b/lib/history/ephy-history-service-hosts-table.c
@@ -40,7 +40,8 @@ ephy_history_service_initialize_hosts_table (EphyHistoryService *self)
"url LONGVARCAR,"
"title LONGVARCAR,"
"visit_count INTEGER DEFAULT 0 NOT NULL,"
- "favicon_id INTEGER DEFAULT 0 NOT NULL)", &error);
+ "favicon_id INTEGER DEFAULT 0 NOT NULL,"
+ "zoom_level REAL DEFAULT 1.0)", &error);
if (error) {
g_error("Could not create hosts table: %s", error->message);
@@ -62,8 +63,8 @@ ephy_history_service_add_host_row (EphyHistoryService *self, EphyHistoryHost *ho
g_assert (priv->history_database != NULL);
statement = ephy_sqlite_connection_create_statement (priv->history_database,
- "INSERT INTO hosts (url, title, visit_count) "
- "VALUES (?, ?, ?)", &error);
+ "INSERT INTO hosts (url, title, visit_count, zoom_level) "
+ "VALUES (?, ?, ?, ?)", &error);
if (error) {
g_error ("Could not build hosts table addition statement: %s", error->message);
@@ -73,7 +74,8 @@ ephy_history_service_add_host_row (EphyHistoryService *self, EphyHistoryHost *ho
if (ephy_sqlite_statement_bind_string (statement, 0, host->url, &error) == FALSE ||
ephy_sqlite_statement_bind_string (statement, 1, host->title, &error) == FALSE ||
- ephy_sqlite_statement_bind_int (statement, 2, host->visit_count, &error) == FALSE) {
+ ephy_sqlite_statement_bind_int (statement, 2, host->visit_count, &error) == FALSE ||
+ ephy_sqlite_statement_bind_double (statement, 3, host->zoom_level, &error) == FALSE) {
g_error ("Could not insert host into hosts table: %s", error->message);
g_error_free (error);
return;
@@ -102,7 +104,7 @@ ephy_history_service_update_host_row (EphyHistoryService *self, EphyHistoryHost
g_assert (priv->history_database != NULL);
statement = ephy_sqlite_connection_create_statement (priv->history_database,
- "UPDATE hosts SET url=?, title=?, visit_count=?"
+ "UPDATE hosts SET url=?, title=?, visit_count=?, zoom_level=?"
"WHERE id=?", &error);
if (error) {
g_error ("Could not build hosts table modification statement: %s", error->message);
@@ -113,7 +115,8 @@ ephy_history_service_update_host_row (EphyHistoryService *self, EphyHistoryHost
if (ephy_sqlite_statement_bind_string (statement, 0, host->url, &error) == FALSE ||
ephy_sqlite_statement_bind_string (statement, 1, host->title, &error) == FALSE ||
ephy_sqlite_statement_bind_int (statement, 2, host->visit_count, &error) == FALSE ||
- ephy_sqlite_statement_bind_int (statement, 3, host->id, &error) == FALSE) {
+ ephy_sqlite_statement_bind_double (statement, 3, host->zoom_level, &error) == FALSE ||
+ ephy_sqlite_statement_bind_int (statement, 4, host->id, &error) == FALSE) {
g_error ("Could not modify host in hosts table: %s", error->message);
g_error_free (error);
return;
@@ -144,11 +147,11 @@ ephy_history_service_get_host_row (EphyHistoryService *self, const gchar *host_s
if (host != NULL && host->id != -1) {
statement = ephy_sqlite_connection_create_statement (priv->history_database,
- "SELECT id, url, title, visit_count FROM hosts "
+ "SELECT id, url, title, visit_count, zoom_level FROM hosts "
"WHERE id=?", &error);
} else {
statement = ephy_sqlite_connection_create_statement (priv->history_database,
- "SELECT id, url, title, visit_count FROM hosts "
+ "SELECT id, url, title, visit_count, zoom_level FROM hosts "
"WHERE url=?", &error);
}
@@ -176,7 +179,7 @@ ephy_history_service_get_host_row (EphyHistoryService *self, const gchar *host_s
}
if (host == NULL) {
- host = ephy_history_host_new (NULL, NULL, 0);
+ host = ephy_history_host_new (NULL, NULL, 0, 1.0);
} else {
if (host->url)
g_free (host->url);
@@ -185,9 +188,10 @@ ephy_history_service_get_host_row (EphyHistoryService *self, const gchar *host_s
}
host->id = ephy_sqlite_statement_get_column_as_int (statement, 0);
- host->url = g_strdup (ephy_sqlite_statement_get_column_as_string (statement, 1)),
- host->title = g_strdup (ephy_sqlite_statement_get_column_as_string (statement, 2)),
- host->visit_count = ephy_sqlite_statement_get_column_as_int (statement, 3),
+ host->url = g_strdup (ephy_sqlite_statement_get_column_as_string (statement, 1));
+ host->title = g_strdup (ephy_sqlite_statement_get_column_as_string (statement, 2));
+ host->visit_count = ephy_sqlite_statement_get_column_as_int (statement, 3);
+ host->zoom_level = ephy_sqlite_statement_get_column_as_double (statement, 4);
g_object_unref (statement);
return host;
@@ -199,7 +203,8 @@ create_host_from_statement (EphySQLiteStatement *statement)
EphyHistoryHost *host =
ephy_history_host_new (ephy_sqlite_statement_get_column_as_string (statement, 1),
ephy_sqlite_statement_get_column_as_string (statement, 2),
- ephy_sqlite_statement_get_column_as_int (statement, 3));
+ ephy_sqlite_statement_get_column_as_int (statement, 3),
+ ephy_sqlite_statement_get_column_as_double (statement, 4));
host->id = ephy_sqlite_statement_get_column_as_int (statement, 0);
return host;
@@ -217,7 +222,7 @@ ephy_history_service_get_all_hosts (EphyHistoryService *self)
g_assert (priv->history_database != NULL);
statement = ephy_sqlite_connection_create_statement (priv->history_database,
- "SELECT id, url, title, visit_count FROM hosts", &error);
+ "SELECT id, url, title, visit_count, zoom_level FROM hosts", &error);
if (error) {
g_error ("Could not build hosts query statement: %s", error->message);
@@ -305,7 +310,7 @@ ephy_history_service_get_host_row_from_url (EphyHistoryService *self,
}
if (host == NULL) {
- host = ephy_history_host_new (host_locations->data, hostname, 0);
+ host = ephy_history_host_new (host_locations->data, hostname, 0, 1.0);
ephy_history_service_add_host_row (self, host);
}
diff --git a/lib/history/ephy-history-service-urls-table.c b/lib/history/ephy-history-service-urls-table.c
index 0b72875a6..fe8d0d5e3 100644
--- a/lib/history/ephy-history-service-urls-table.c
+++ b/lib/history/ephy-history-service-urls-table.c
@@ -40,8 +40,7 @@ ephy_history_service_initialize_urls_table (EphyHistoryService *self)
"title LONGVARCAR,"
"visit_count INTEGER DEFAULT 0 NOT NULL,"
"typed_count INTEGER DEFAULT 0 NOT NULL,"
- "last_visit_time INTEGER,"
- "zoom_level REAL DEFAULT 1.0)", &error);
+ "last_visit_time INTEGER)", &error);
if (error) {
g_error("Could not create urls table: %s", error->message);
@@ -69,11 +68,11 @@ ephy_history_service_get_url_row (EphyHistoryService *self, const char *url_stri
if (url != NULL && url->id != -1) {
statement = ephy_sqlite_connection_create_statement (priv->history_database,
- "SELECT id, url, title, visit_count, typed_count, last_visit_time, zoom_level FROM urls "
+ "SELECT id, url, title, visit_count, typed_count, last_visit_time FROM urls "
"WHERE id=?", &error);
} else {
statement = ephy_sqlite_connection_create_statement (priv->history_database,
- "SELECT id, url, title, visit_count, typed_count, last_visit_time, zoom_level FROM urls "
+ "SELECT id, url, title, visit_count, typed_count, last_visit_time FROM urls "
"WHERE url=?", &error);
}
@@ -101,7 +100,7 @@ ephy_history_service_get_url_row (EphyHistoryService *self, const char *url_stri
}
if (url == NULL) {
- url = ephy_history_url_new (NULL, NULL, 0, 0, 0, 1.0);
+ url = ephy_history_url_new (NULL, NULL, 0, 0, 0);
}
url->id = ephy_sqlite_statement_get_column_as_int (statement, 0);
@@ -116,7 +115,6 @@ ephy_history_service_get_url_row (EphyHistoryService *self, const char *url_stri
url->visit_count = ephy_sqlite_statement_get_column_as_int (statement, 3),
url->typed_count = ephy_sqlite_statement_get_column_as_int (statement, 4),
url->last_visit_time = ephy_sqlite_statement_get_column_as_int (statement, 5);
- url->zoom_level = ephy_sqlite_statement_get_column_as_double (statement, 6);
g_object_unref (statement);
return url;
@@ -133,8 +131,8 @@ ephy_history_service_add_url_row (EphyHistoryService *self, EphyHistoryURL *url)
g_assert (priv->history_database != NULL);
statement = ephy_sqlite_connection_create_statement (priv->history_database,
- "INSERT INTO urls (url, title, visit_count, typed_count, last_visit_time, zoom_level, host) "
- " VALUES (?, ?, ?, ?, ?, ?, ?)", &error);
+ "INSERT INTO urls (url, title, visit_count, typed_count, last_visit_time, host) "
+ " VALUES (?, ?, ?, ?, ?, ?)", &error);
if (error) {
g_error ("Could not build urls table addition statement: %s", error->message);
g_error_free (error);
@@ -146,8 +144,7 @@ ephy_history_service_add_url_row (EphyHistoryService *self, EphyHistoryURL *url)
ephy_sqlite_statement_bind_int (statement, 2, url->visit_count, &error) == FALSE ||
ephy_sqlite_statement_bind_int (statement, 3, url->typed_count, &error) == FALSE ||
ephy_sqlite_statement_bind_int (statement, 4, url->last_visit_time, &error) == FALSE ||
- ephy_sqlite_statement_bind_double (statement, 5, url->zoom_level, &error) == FALSE ||
- ephy_sqlite_statement_bind_int (statement, 6, url->host->id, &error) == FALSE) {
+ ephy_sqlite_statement_bind_int (statement, 5, url->host->id, &error) == FALSE) {
g_error ("Could not insert URL into urls table: %s", error->message);
g_error_free (error);
return;
@@ -175,7 +172,7 @@ ephy_history_service_update_url_row (EphyHistoryService *self, EphyHistoryURL *u
g_assert (priv->history_database != NULL);
statement = ephy_sqlite_connection_create_statement (priv->history_database,
- "UPDATE urls SET title=?, visit_count=?, typed_count=?, last_visit_time=?, zoom_level=? "
+ "UPDATE urls SET title=?, visit_count=?, typed_count=?, last_visit_time=? "
"WHERE id=?", &error);
if (error) {
g_error ("Could not build urls table modification statement: %s", error->message);
@@ -187,8 +184,7 @@ ephy_history_service_update_url_row (EphyHistoryService *self, EphyHistoryURL *u
ephy_sqlite_statement_bind_int (statement, 1, url->visit_count, &error) == FALSE ||
ephy_sqlite_statement_bind_int (statement, 2, url->typed_count, &error) == FALSE ||
ephy_sqlite_statement_bind_int (statement, 3, url->last_visit_time, &error) == FALSE ||
- ephy_sqlite_statement_bind_double (statement, 4, url->zoom_level, &error) == FALSE ||
- ephy_sqlite_statement_bind_int (statement, 5, url->id, &error) == FALSE) {
+ ephy_sqlite_statement_bind_int (statement, 4, url->id, &error) == FALSE) {
g_error ("Could not modify URL in urls table: %s", error->message);
g_error_free (error);
return;
@@ -209,11 +205,10 @@ create_url_from_statement (EphySQLiteStatement *statement)
ephy_sqlite_statement_get_column_as_string (statement, 2),
ephy_sqlite_statement_get_column_as_int (statement, 3),
ephy_sqlite_statement_get_column_as_int (statement, 4),
- ephy_sqlite_statement_get_column_as_int (statement, 5),
- ephy_sqlite_statement_get_column_as_int (statement, 6));
+ ephy_sqlite_statement_get_column_as_int (statement, 5));
url->id = ephy_sqlite_statement_get_column_as_int (statement, 0);
- url->host = ephy_history_host_new (NULL, NULL, 0);
+ url->host = ephy_history_host_new (NULL, NULL, 0, 1.0);
url->host->id = ephy_sqlite_statement_get_column_as_int (statement, 7);
return url;
@@ -236,7 +231,6 @@ ephy_history_service_find_url_rows (EphyHistoryService *self, EphyHistoryQuery *
"urls.visit_count, "
"urls.typed_count, "
"urls.last_visit_time, "
- "urls.zoom_level, "
"urls.host "
"FROM "
"urls ";
diff --git a/lib/history/ephy-history-service.c b/lib/history/ephy-history-service.c
index 61d7b2b05..0b3a2e198 100644
--- a/lib/history/ephy-history-service.c
+++ b/lib/history/ephy-history-service.c
@@ -37,6 +37,7 @@ typedef enum {
QUIT,
/* READ */
GET_URL,
+ GET_HOST_FOR_URL,
QUERY_URLS,
QUERY_VISITS,
} EphyHistoryServiceMessageType;
@@ -531,7 +532,7 @@ ephy_history_service_set_url_title (EphyHistoryService *self,
EphyHistoryJobCallback callback,
gpointer user_data)
{
- EphyHistoryURL *url = ephy_history_url_new (orig_url, title, 0, 0, 0, 1.0);
+ EphyHistoryURL *url = ephy_history_url_new (orig_url, title, 0, 0, 0);
EphyHistoryServiceMessage *message =
ephy_history_service_message_new (self, SET_URL_TITLE,
@@ -542,35 +543,40 @@ ephy_history_service_set_url_title (EphyHistoryService *self,
static gboolean
ephy_history_service_execute_set_url_zoom_level (EphyHistoryService *self,
- EphyHistoryURL *url,
+ GVariant *variant,
gpointer *result)
{
- double zoom_level = url->zoom_level;
+ char *url_string;
+ double zoom_level;
+ EphyHistoryHost *host;
- if (NULL == ephy_history_service_get_url_row (self, NULL, url)) {
- /* The URL is not yet in the database, so we can't update it.. */
- return FALSE;
- } else {
- url->zoom_level = zoom_level;
- ephy_history_service_update_url_row (self, url);
- ephy_history_service_schedule_commit (self);
- return TRUE;
- }
+ g_variant_get (variant, "(sd)", &url_string, &zoom_level);
+
+ host = ephy_history_service_get_host_row_from_url (self, url_string);
+ g_free (url_string);
+
+ g_return_val_if_fail (host != NULL, FALSE);
+
+ host->zoom_level = zoom_level;
+ ephy_history_service_update_host_row (self, host);
+ ephy_history_service_schedule_commit (self);
+
+ return TRUE;
}
void
ephy_history_service_set_url_zoom_level (EphyHistoryService *self,
- const char *orig_url,
+ const char *url,
const double zoom_level,
EphyHistoryJobCallback callback,
gpointer user_data)
{
- EphyHistoryURL *url = ephy_history_url_new (orig_url, NULL, 0, 0, 0, zoom_level);
+ EphyHistoryServiceMessage *message;
+ GVariant *variant = g_variant_new ("(sd)", url, zoom_level);
- EphyHistoryServiceMessage *message =
- ephy_history_service_message_new (self, SET_URL_ZOOM_LEVEL,
- url, (GDestroyNotify) ephy_history_url_free,
- callback, user_data);
+ message = ephy_history_service_message_new (self, SET_URL_ZOOM_LEVEL,
+ variant, (GDestroyNotify)g_variant_unref,
+ callback, user_data);
ephy_history_service_send_message (self, message);
}
@@ -602,6 +608,34 @@ ephy_history_service_get_url (EphyHistoryService *self,
}
static gboolean
+ephy_history_service_execute_get_host_for_url (EphyHistoryService *self,
+ const gchar *url,
+ gpointer *result)
+{
+ EphyHistoryHost *host;
+
+ host = ephy_history_service_get_host_row_from_url (self, url);
+ g_return_val_if_fail (host != NULL, FALSE);
+
+ *result = host;
+
+ return host != NULL;
+}
+
+void
+ephy_history_service_get_host_for_url (EphyHistoryService *self,
+ const char *url,
+ EphyHistoryJobCallback callback,
+ gpointer user_data)
+{
+ EphyHistoryServiceMessage *message =
+ ephy_history_service_message_new (self, GET_HOST_FOR_URL,
+ g_strdup (url), g_free,
+ callback, user_data);
+ ephy_history_service_send_message (self, message);
+}
+
+static gboolean
ephy_history_service_execute_set_url_property (EphyHistoryService *self,
GVariant *variant,
gpointer *result)
@@ -613,7 +647,7 @@ ephy_history_service_execute_set_url_property (EphyHistoryService *self,
g_variant_get (variant, "(s(iv))", &url_string, &property, &value);
- url = ephy_history_url_new (url_string, NULL, 0, 0, 0, 1.0);
+ url = ephy_history_url_new (url_string, NULL, 0, 0, 0);
g_free (url_string);
if (NULL == ephy_history_service_get_url_row (self, NULL, url)) {
@@ -635,9 +669,6 @@ ephy_history_service_execute_set_url_property (EphyHistoryService *self,
url->title = NULL;
}
break;
- case EPHY_HISTORY_URL_ZOOM_LEVEL:
- url->zoom_level = g_variant_get_double (value);
- break;
default:
g_assert_not_reached();
}
@@ -719,6 +750,7 @@ static EphyHistoryServiceMethod methods[] = {
(EphyHistoryServiceMethod)ephy_history_service_execute_delete_urls,
(EphyHistoryServiceMethod)ephy_history_service_execute_quit,
(EphyHistoryServiceMethod)ephy_history_service_execute_get_url,
+ (EphyHistoryServiceMethod)ephy_history_service_execute_get_host_for_url,
(EphyHistoryServiceMethod)ephy_history_service_execute_query_urls,
(EphyHistoryServiceMethod)ephy_history_service_execute_find_visits
};
diff --git a/lib/history/ephy-history-service.h b/lib/history/ephy-history-service.h
index 601d13b07..98b48e275 100644
--- a/lib/history/ephy-history-service.h
+++ b/lib/history/ephy-history-service.h
@@ -61,6 +61,7 @@ void ephy_history_service_query_visits (EphyHisto
void ephy_history_service_query_urls (EphyHistoryService *self, EphyHistoryQuery *query, EphyHistoryJobCallback callback, gpointer user_data);
void ephy_history_service_set_url_title (EphyHistoryService *self, const char *url, const char *title, EphyHistoryJobCallback callback, gpointer user_data);
void ephy_history_service_set_url_zoom_level (EphyHistoryService *self, const char *url, const double zoom_level, EphyHistoryJobCallback callback, gpointer user_data);
+void ephy_history_service_get_host_for_url (EphyHistoryService *self, const char *url, EphyHistoryJobCallback callback, gpointer user_data);
void ephy_history_service_set_url_property (EphyHistoryService *self, const char *url, EphyHistoryURLProperty property, GVariant *value, EphyHistoryJobCallback callback, gpointer user_data);
void ephy_history_service_get_url (EphyHistoryService *self, const char *url, EphyHistoryJobCallback callback, gpointer user_data);
void ephy_history_service_delete_urls (EphyHistoryService *self, GList *urls, EphyHistoryJobCallback callback, gpointer user_data);
diff --git a/lib/history/ephy-history-types.c b/lib/history/ephy-history-types.c
index bb8321653..84e83e72e 100644
--- a/lib/history/ephy-history-types.c
+++ b/lib/history/ephy-history-types.c
@@ -36,7 +36,7 @@ ephy_history_page_visit_new_with_url (EphyHistoryURL *url, gint64 visit_time, Ep
EphyHistoryPageVisit *
ephy_history_page_visit_new (const char *url, gint64 visit_time, EphyHistoryPageVisitType visit_type)
{
- return ephy_history_page_visit_new_with_url (ephy_history_url_new (url, "", 0, 0, 0, 1.0),
+ return ephy_history_page_visit_new_with_url (ephy_history_url_new (url, "", 0, 0, 0),
visit_time, visit_type);
}
@@ -78,7 +78,7 @@ ephy_history_page_visit_list_free (GList *list)
}
EphyHistoryHost *
-ephy_history_host_new (const char *url, const char *title, int visit_count)
+ephy_history_host_new (const char *url, const char *title, int visit_count, double zoom_level)
{
EphyHistoryHost *host = g_slice_alloc0 (sizeof (EphyHistoryHost));
@@ -86,6 +86,7 @@ ephy_history_host_new (const char *url, const char *title, int visit_count)
host->url = g_strdup (url);
host->title = g_strdup (title);
host->visit_count = visit_count;
+ host->zoom_level = zoom_level;
return host;
}
@@ -100,7 +101,8 @@ ephy_history_host_copy (EphyHistoryHost *original)
host = ephy_history_host_new (original->url,
original->title,
- original->visit_count);
+ original->visit_count,
+ original->zoom_level);
host->id = original->id;
return host;
@@ -119,7 +121,7 @@ ephy_history_host_free (EphyHistoryHost *host)
}
EphyHistoryURL *
-ephy_history_url_new (const char *url, const char *title, int visit_count, int typed_count, int last_visit_time, double zoom_level)
+ephy_history_url_new (const char *url, const char *title, int visit_count, int typed_count, int last_visit_time)
{
EphyHistoryURL *history_url = g_slice_alloc0 (sizeof (EphyHistoryURL));
history_url->id = -1;
@@ -128,7 +130,6 @@ ephy_history_url_new (const char *url, const char *title, int visit_count, int t
history_url->visit_count = visit_count;
history_url->typed_count = typed_count;
history_url->last_visit_time = last_visit_time;
- history_url->zoom_level = zoom_level;
history_url->host = NULL;
return history_url;
}
@@ -144,8 +145,7 @@ ephy_history_url_copy (EphyHistoryURL *url)
url->title,
url->visit_count,
url->typed_count,
- url->last_visit_time,
- url->zoom_level);
+ url->last_visit_time);
copy->id = url->id;
copy->host = ephy_history_host_copy (url->host);
return copy;
diff --git a/lib/history/ephy-history-types.h b/lib/history/ephy-history-types.h
index 8d32c5e6c..367e802e3 100644
--- a/lib/history/ephy-history-types.h
+++ b/lib/history/ephy-history-types.h
@@ -39,7 +39,6 @@ typedef enum {
typedef enum {
EPHY_HISTORY_URL_TITLE,
- EPHY_HISTORY_URL_ZOOM_LEVEL
} EphyHistoryURLProperty;
typedef enum {
@@ -56,6 +55,7 @@ typedef struct
char* url;
char* title;
int visit_count;
+ double zoom_level;
} EphyHistoryHost;
typedef struct _EphyHistoryURL
@@ -66,7 +66,6 @@ typedef struct _EphyHistoryURL
int visit_count;
int typed_count;
int last_visit_time;
- double zoom_level;
EphyHistoryHost *host;
} EphyHistoryURL;
@@ -95,11 +94,11 @@ void ephy_history_page_visit_free (EphyHistoryPageVis
GList * ephy_history_page_visit_list_copy (GList* original);
void ephy_history_page_visit_list_free (GList* list);
-EphyHistoryHost * ephy_history_host_new (const char *url, const char *title, int visit_count);
+EphyHistoryHost * ephy_history_host_new (const char *url, const char *title, int visit_count, double zoom_level);
EphyHistoryHost * ephy_history_host_copy (EphyHistoryHost *original);
void ephy_history_host_free (EphyHistoryHost *host);
-EphyHistoryURL * ephy_history_url_new (const char *url, const char* title, int visit_count, int typed_count, int last_visit_time, double zoom_level);
+EphyHistoryURL * ephy_history_url_new (const char *url, const char* title, int visit_count, int typed_count, int last_visit_time);
EphyHistoryURL * ephy_history_url_copy (EphyHistoryURL *url);
void ephy_history_url_free (EphyHistoryURL *url);