[tracker/wip/carlosg/no-fts-logic-error] libtracker-sparql: Do not attempt to rebuild non-existing FTS tables
- From: Carlos Garnacho <carlosg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [tracker/wip/carlosg/no-fts-logic-error] libtracker-sparql: Do not attempt to rebuild non-existing FTS tables
- Date: Sun, 5 Jun 2022 11:50:09 +0000 (UTC)
commit 7003f12ac9844e2b7054b8cfe30f999a0b4a335f
Author: Carlos Garnacho <carlosg gnome org>
Date: Sun Jun 5 00:19:51 2022 +0200
libtracker-sparql: Do not attempt to rebuild non-existing FTS tables
If a database/ontology has no fulltext-indexed properties, we do not
create a corresponding FTS table. Likewise, parser/locale updates
should not attempt to update it, or we will get a "SQL logic error"
poking non-existing tables.
Closes: https://gitlab.gnome.org/GNOME/nautilus/-/issues/2278
src/libtracker-sparql/core/tracker-data-manager.c | 28 +++++++++++++++++------
1 file changed, 21 insertions(+), 7 deletions(-)
---
diff --git a/src/libtracker-sparql/core/tracker-data-manager.c
b/src/libtracker-sparql/core/tracker-data-manager.c
index 2a29008b8..33decd3e2 100644
--- a/src/libtracker-sparql/core/tracker-data-manager.c
+++ b/src/libtracker-sparql/core/tracker-data-manager.c
@@ -3866,20 +3866,34 @@ rebuild_fts_tokens (TrackerDataManager *manager,
TrackerDBInterface *iface,
GError **error)
{
+ TrackerProperty **properties;
GHashTableIter iter;
gchar *graph;
+ gboolean has_fts = FALSE;
+ guint len, i;
- g_debug ("Rebuilding FTS tokens, this may take a moment...");
- if (!tracker_db_interface_sqlite_fts_rebuild_tokens (iface, "main", error))
- return FALSE;
+ properties = tracker_ontologies_get_properties (manager->ontologies, &len);
- g_hash_table_iter_init (&iter, manager->graphs);
- while (g_hash_table_iter_next (&iter, (gpointer*) &graph, NULL)) {
- if (!tracker_db_interface_sqlite_fts_rebuild_tokens (iface, graph, error))
+ for (i = 0; i < len; i++) {
+ has_fts |= tracker_property_get_fulltext_indexed (properties[i]);
+ if (has_fts)
+ break;
+ }
+
+ if (has_fts) {
+ g_debug ("Rebuilding FTS tokens, this may take a moment...");
+ if (!tracker_db_interface_sqlite_fts_rebuild_tokens (iface, "main", error))
return FALSE;
+
+ g_hash_table_iter_init (&iter, manager->graphs);
+ while (g_hash_table_iter_next (&iter, (gpointer*) &graph, NULL)) {
+ if (!tracker_db_interface_sqlite_fts_rebuild_tokens (iface, graph, error))
+ return FALSE;
+ }
+
+ g_debug ("FTS tokens rebuilt");
}
- g_debug ("FTS tokens rebuilt");
/* Update the stamp file */
tracker_db_manager_tokenizer_update (manager->db_manager);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]