diff options
Diffstat (limited to 'src/core')
-rw-r--r-- | src/core/collections.c | 38 | ||||
-rw-r--r-- | src/core/collections.h | 7 |
2 files changed, 17 insertions, 28 deletions
diff --git a/src/core/collections.c b/src/core/collections.c index c867d57..08c97e1 100644 --- a/src/core/collections.c +++ b/src/core/collections.c @@ -32,20 +32,13 @@ #include "../analysis/db/collection.h" #include "../analysis/db/protocol.h" #include "../analysis/db/items/bookmark.h" +#include "../analysis/db/items/comment.h" +#include "../analysis/db/items/switcher.h" -/* Caractéristiques d'une collection */ -typedef struct _collec_t -{ - GType items; /* Type d'éléments rassemblés */ - create_db_table_fc create; /* Création de la BD associée */ - -} collec_t; - - /* Mémorisation des types de collection enregistrés */ -static collec_t *_collection_definitions = NULL; +static GType *_collection_definitions = NULL; static uint32_t _collection_definitions_count = 0; /* Verrou pour des accès atomiques */ @@ -55,8 +48,7 @@ static uint32_t _collection_definitions_count = 0; /****************************************************************************** * * -* Paramètres : items = type GLib des éléments constituant une collection. * -* create = création de la base de données correspondante. * +* Paramètres : items = type GLib des éléments constituant une collection. * * * * Description : Enregistre un type d'élément à gérer par collection. * * * @@ -66,7 +58,7 @@ static uint32_t _collection_definitions_count = 0; * * ******************************************************************************/ -uint32_t register_collection_type(GType items, create_db_table_fc create) +uint32_t register_collection_type(GType items) { uint32_t result; /* Identifiant à retourner */ @@ -74,11 +66,10 @@ uint32_t register_collection_type(GType items, create_db_table_fc create) result = _collection_definitions_count++; - _collection_definitions = (collec_t *)realloc(_collection_definitions, - _collection_definitions_count * sizeof(collec_t)); + _collection_definitions = (GType *)realloc(_collection_definitions, + _collection_definitions_count * sizeof(GType)); - _collection_definitions[result].items = items; - _collection_definitions[result].create = create; + _collection_definitions[result] = items; /* TODO : unlock */ @@ -109,9 +100,15 @@ bool load_hard_coded_collection_definitions(void) * afin de garder la correspondance entre les identifiants. */ - id = register_collection_type(G_TYPE_BM_COLLECTION, create_bookmark_db_table); + id = register_collection_type(G_TYPE_BM_COLLECTION); assert(id == DBF_BOOKMARKS); + id = register_collection_type(G_TYPE_COMMENT_COLLECTION); + assert(id == DBF_COMMENTS); + + id = register_collection_type(G_TYPE_SWITCHER_COLLECTION); + assert(id == DBF_DISPLAY_SWITCHERS); + return true; } @@ -156,16 +153,13 @@ GList *create_collections_list(void) { GList *result; /* Groupe à retourner */ uint32_t i; /* Boucle de parcours */ - const collec_t *def; /* Définition brute à lire */ GDbCollection *collec; /* Nouveau groupe à intégrer */ result = NULL; for (i = 0; i < _collection_definitions_count; i++) { - def = &_collection_definitions[i]; - //collec = g_db_collection_new(i, def->items, "Bookmarks"); - collec = g_object_new(def->items, NULL); + collec = g_object_new(_collection_definitions[i], NULL); result = g_list_append(result, collec); diff --git a/src/core/collections.h b/src/core/collections.h index b84bdd9..dbe869a 100644 --- a/src/core/collections.h +++ b/src/core/collections.h @@ -32,13 +32,8 @@ -/* Crée la table dans une base de données. */ -typedef bool (* create_db_table_fc) (sqlite3 *); - - - /* Enregistre un type d'élément à gérer par collection. */ -uint32_t register_collection_type(GType, create_db_table_fc); +uint32_t register_collection_type(GType); /* Charge les définitions de collections "natives". */ bool load_hard_coded_collection_definitions(void); |