diff options
Diffstat (limited to 'lib/history')
-rw-r--r-- | lib/history/ephy-history-service-hosts-table.c | 35 | ||||
-rw-r--r-- | lib/history/ephy-history-service-urls-table.c | 28 | ||||
-rw-r--r-- | lib/history/ephy-history-service.c | 76 | ||||
-rw-r--r-- | lib/history/ephy-history-service.h | 1 | ||||
-rw-r--r-- | lib/history/ephy-history-types.c | 14 | ||||
-rw-r--r-- | lib/history/ephy-history-types.h | 7 |
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); |