diff options
Diffstat (limited to 'src/glibext/generator.c')
-rw-r--r-- | src/glibext/generator.c | 135 |
1 files changed, 82 insertions, 53 deletions
diff --git a/src/glibext/generator.c b/src/glibext/generator.c index c5291ab..2d3d349 100644 --- a/src/glibext/generator.c +++ b/src/glibext/generator.c @@ -1,8 +1,8 @@ /* Chrysalide - Outil d'analyse de fichiers binaires - * linegen.c - intermédiaires de génération de lignes + * generator.c - intermédiaires de génération de lignes à partir de bribres de texte * - * Copyright (C) 2016-2018 Cyrille Bagard + * Copyright (C) 2016-2024 Cyrille Bagard * * This file is part of Chrysalide. * @@ -21,23 +21,26 @@ */ -#include "linegen.h" +#include "generator.h" #include <assert.h> -#include "linegen-int.h" +#include "generator-int.h" /* Procède à l'initialisation de l'interface de génération. */ -static void g_line_generator_default_init(GLineGeneratorInterface *); +static void g_token_generator_default_init(GTokenGeneratorInterface *); + +/* Indique le nombre de ligne prêtes à être générées. */ +static size_t _g_token_generator_count_one_line(const GTokenGenerator *); /* Détermine le type d'une interface pour la mise en place de lignes. */ -G_DEFINE_INTERFACE(GLineGenerator, g_line_generator, G_TYPE_OBJECT) +G_DEFINE_INTERFACE(GTokenGenerator, g_token_generator, G_TYPE_OBJECT) /****************************************************************************** @@ -52,8 +55,32 @@ G_DEFINE_INTERFACE(GLineGenerator, g_line_generator, G_TYPE_OBJECT) * * ******************************************************************************/ -static void g_line_generator_default_init(GLineGeneratorInterface *iface) +static void g_token_generator_default_init(GTokenGeneratorInterface *iface) +{ + iface->count = _g_token_generator_count_one_line; + +} + + +/****************************************************************************** +* * +* Paramètres : generator = générateur à consulter. * +* * +* Description : Indique le nombre de ligne prêtes à être générées. * +* * +* Retour : Nombre de lignes devant apparaître au final. * +* * +* Remarques : - * +* * +******************************************************************************/ + +static size_t _g_token_generator_count_one_line(const GTokenGenerator *generator) { + size_t result; /* Décompte à retourner */ + + result = 1; + + return result; } @@ -70,12 +97,12 @@ static void g_line_generator_default_init(GLineGeneratorInterface *iface) * * ******************************************************************************/ -size_t g_line_generator_count_lines(const GLineGenerator *generator) +size_t g_token_generator_count_lines(const GTokenGenerator *generator) { size_t result; /* Décompte à retourner */ - GLineGeneratorIface *iface; /* Interface utilisée */ + GTokenGeneratorInterface *iface; /* Interface utilisée */ - iface = G_LINE_GENERATOR_GET_IFACE(generator); + iface = G_TOKEN_GENERATOR_GET_IFACE(generator); result = iface->count(generator); @@ -87,31 +114,29 @@ size_t g_line_generator_count_lines(const GLineGenerator *generator) /****************************************************************************** * * * Paramètres : generator = générateur à consulter. * -* x = position géographique sur la ligne concernée. * * index = indice de cette même ligne dans le tampon global.* * repeat = indice d'utilisations successives du générateur. * * * -* Description : Retrouve l'emplacement correspondant à une position donnée. * +* Description : Renseigne sur les propriétés liées à un générateur. * * * -* Retour : Emplacement constitué. * +* Retour : Propriétés particulières associées. * * * * Remarques : - * * * ******************************************************************************/ -GLineCursor *g_line_generator_compute_cursor(const GLineGenerator *generator, gint x, size_t index, size_t repeat) +BufferLineFlags g_token_generator_get_flags(const GTokenGenerator *generator, size_t index, size_t repeat) { - GLineCursor *result; /* Emplacement à renvoyer */ - GLineGeneratorIface *iface; /* Interface utilisée */ + BufferLineFlags result; /* Fanions à retourner */ + GTokenGeneratorInterface *iface; /* Interface utilisée */ - iface = G_LINE_GENERATOR_GET_IFACE(generator); + iface = G_TOKEN_GENERATOR_GET_IFACE(generator); #ifndef NDEBUG - if (iface->count != NULL) - assert(repeat < g_line_generator_count_lines(generator)); + assert(repeat < g_token_generator_count_lines(generator)); #endif - iface->compute(generator, x, index, repeat, &result); + result = iface->get_flags(generator, index, repeat); return result; @@ -120,65 +145,65 @@ GLineCursor *g_line_generator_compute_cursor(const GLineGenerator *generator, gi /****************************************************************************** * * -* Paramètres : generator = générateur à consulter. * +* Paramètres : generator = générateur à utiliser pour l'impression. * * index = indice de cette même ligne dans le tampon global.* * repeat = indice d'utilisations successives du générateur. * -* cursor = emplacement à analyser. * +* line = ligne de rendu à compléter. * +* data = éventuelle donnée complémentaire fournie. * * * -* Description : Détermine si le conteneur s'inscrit dans une plage donnée. * +* Description : Etablit dans une ligne de rendu le contenu représenté. * * * -* Retour : Bilan de la détermination, utilisable en comparaisons. * +* Retour : - * * * * Remarques : - * * * ******************************************************************************/ -int g_line_generator_contain_cursor(const GLineGenerator *generator, size_t index, size_t repeat, const GLineCursor *cursor) +void g_token_generator_populate_line(const GTokenGenerator *generator, size_t index, size_t repeat, GBufferLine *line, void *data) { - int result; /* Bilan d'analyse à retourner */ - GLineGeneratorIface *iface; /* Interface utilisée */ + GTokenGeneratorInterface *iface; /* Interface utilisée */ - iface = G_LINE_GENERATOR_GET_IFACE(generator); + iface = G_TOKEN_GENERATOR_GET_IFACE(generator); #ifndef NDEBUG - if (iface->count != NULL) - assert(repeat < g_line_generator_count_lines(generator)); + assert(repeat < g_token_generator_count_lines(generator)); #endif - result = iface->contain(generator, index, repeat, cursor); - - return result; + iface->populate(generator, index, repeat, line, data); } +#if 0 + + /****************************************************************************** * * * Paramètres : generator = générateur à consulter. * +* x = position géographique sur la ligne concernée. * * index = indice de cette même ligne dans le tampon global.* * repeat = indice d'utilisations successives du générateur. * * * -* Description : Renseigne sur les propriétés liées à un générateur. * +* Description : Retrouve l'emplacement correspondant à une position donnée. * * * -* Retour : Propriétés particulières associées. * +* Retour : Emplacement constitué. * * * * Remarques : - * * * ******************************************************************************/ -BufferLineFlags g_line_generator_get_flags(const GLineGenerator *generator, size_t index, size_t repeat) +GLineCursor *g_token_generator_compute_cursor(const GTokenGenerator *generator, gint x, size_t index, size_t repeat) { - BufferLineFlags result; /* Fanions à retourner */ - GLineGeneratorIface *iface; /* Interface utilisée */ + GLineCursor *result; /* Emplacement à renvoyer */ + GTokenGeneratorInterface *iface; /* Interface utilisée */ - iface = G_LINE_GENERATOR_GET_IFACE(generator); + iface = G_TOKEN_GENERATOR_GET_IFACE(generator); #ifndef NDEBUG - if (iface->count != NULL) - assert(repeat < g_line_generator_count_lines(generator)); + assert(repeat < g_token_generator_count_lines(generator)); #endif - result = iface->get_flags(generator, index, repeat); + iface->compute(generator, x, index, repeat, &result); return result; @@ -187,31 +212,35 @@ BufferLineFlags g_line_generator_get_flags(const GLineGenerator *generator, size /****************************************************************************** * * -* Paramètres : generator = générateur à utiliser pour l'impression. * -* line = ligne de rendu à compléter. * +* Paramètres : generator = générateur à consulter. * * index = indice de cette même ligne dans le tampon global.* * repeat = indice d'utilisations successives du générateur. * -* content = éventuel contenu binaire brut à imprimer. * +* cursor = emplacement à analyser. * * * -* Description : Imprime dans une ligne de rendu le contenu représenté. * +* Description : Détermine si le conteneur s'inscrit dans une plage donnée. * * * -* Retour : - * +* Retour : Bilan de la détermination, utilisable en comparaisons. * * * * Remarques : - * * * ******************************************************************************/ -void g_line_generator_print(GLineGenerator *generator, GBufferLine *line, size_t index, size_t repeat, const GBinContent *content) +int g_token_generator_contain_cursor(const GTokenGenerator *generator, size_t index, size_t repeat, const GLineCursor *cursor) { - GLineGeneratorIface *iface; /* Interface utilisée */ + int result; /* Bilan d'analyse à retourner */ + GTokenGeneratorInterface *iface; /* Interface utilisée */ - iface = G_LINE_GENERATOR_GET_IFACE(generator); + iface = G_TOKEN_GENERATOR_GET_IFACE(generator); #ifndef NDEBUG - if (iface->count != NULL) - assert(repeat < g_line_generator_count_lines(generator)); + assert(repeat < g_token_generator_count_lines(generator)); #endif - iface->print(generator, line, index, repeat, content); + result = iface->contain(generator, index, repeat, cursor); + + return result; } + + +#endif |