diff options
Diffstat (limited to 'src/gtkext')
-rw-r--r-- | src/gtkext/Makefile.am | 2 | ||||
-rw-r--r-- | src/gtkext/gtkstatusstack.c | 8 | ||||
-rw-r--r-- | src/gtkext/gtkstatusstack.h | 2 | ||||
-rw-r--r-- | src/gtkext/named-int.h | 65 | ||||
-rw-r--r-- | src/gtkext/named.c | 333 | ||||
-rw-r--r-- | src/gtkext/named.h | 62 |
6 files changed, 469 insertions, 3 deletions
diff --git a/src/gtkext/Makefile.am b/src/gtkext/Makefile.am index a56cf33..4523d69 100644 --- a/src/gtkext/Makefile.am +++ b/src/gtkext/Makefile.am @@ -21,6 +21,8 @@ libgtkext_la_SOURCES = \ gtkgraphdisplay.h gtkgraphdisplay.c \ gtkstatusstack.h gtkstatusstack.c \ hexdisplay.h hexdisplay.c \ + named-int.h \ + named.h named.c \ rendering.h rendering.c \ resources.h resources.c \ support.h support.c \ diff --git a/src/gtkext/gtkstatusstack.c b/src/gtkext/gtkstatusstack.c index 31cc55a..1df5d35 100644 --- a/src/gtkext/gtkstatusstack.c +++ b/src/gtkext/gtkstatusstack.c @@ -308,9 +308,13 @@ static void gtk_status_stack_finalize(GtkStatusStack *stack) * * ******************************************************************************/ -GtkWidget *gtk_status_stack_new(void) +GtkStatusStack *gtk_status_stack_new(void) { - return g_object_new(GTK_TYPE_STATUS_STACK, NULL); + GtkStatusStack *result; /* Instance à retourner */ + + result = g_object_new(GTK_TYPE_STATUS_STACK, NULL); + + return result; } diff --git a/src/gtkext/gtkstatusstack.h b/src/gtkext/gtkstatusstack.h index 7eecc68..b68e387 100644 --- a/src/gtkext/gtkstatusstack.h +++ b/src/gtkext/gtkstatusstack.h @@ -54,7 +54,7 @@ typedef struct _GtkStatusStackClass GtkStatusStackClass; GType gtk_status_stack_get_type(void); /* Crée une nouvelle instance de barre de statut. */ -GtkWidget *gtk_status_stack_new(void); +GtkStatusStack *gtk_status_stack_new(void); diff --git a/src/gtkext/named-int.h b/src/gtkext/named-int.h new file mode 100644 index 0000000..1ae2efe --- /dev/null +++ b/src/gtkext/named-int.h @@ -0,0 +1,65 @@ + +/* Chrysalide - Outil d'analyse de fichiers binaires + * named-int.h - définitions internes propres à la préparation de composants à l'affichage avec leurs noms + * + * Copyright (C) 2020 Cyrille Bagard + * + * This file is part of Chrysalide. + * + * Chrysalide is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 3 of the License, or + * (at your option) any later version. + * + * Chrysalide is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with Chrysalide. If not, see <http://www.gnu.org/licenses/>. + */ + + +#ifndef _GTK_NAMED_INT_H +#define _GTK_NAMED_INT_H + + +#include "named.h" + + + +/* Préparation d'un composant pour affichage avec ses noms (instance) */ +struct _GtkBuiltNamedWidget +{ + GObject parent; /* A laisser en premier */ + + char *name; /* Description courte */ + char *lname; /* Description longue */ + + /** + * La gestion générique du constructeur repose sur quelques + * prérequis quant à l'enregistrement de composants : + * + * - "box" doit être le support de panneau à intégrer. + * + * - pour les contenus actualisables, une pile de composants + * "stack" doit contenir un support "content" pour le + * contenu principal et un support "mask" qui prend le + * relais pendant les opérations de mise à jour. + */ + + GtkBuilder *builder; /* Constructeur utilisé */ + +}; + +/* Préparation d'un composant pour affichage avec ses noms (classe) */ +struct _GtkBuiltNamedWidgetClass +{ + GObjectClass parent; /* A laisser en premier */ + +}; + + + +#endif /* _GTK_NAMED_INT_H */ diff --git a/src/gtkext/named.c b/src/gtkext/named.c new file mode 100644 index 0000000..de0dd3f --- /dev/null +++ b/src/gtkext/named.c @@ -0,0 +1,333 @@ + +/* Chrysalide - Outil d'analyse de fichiers binaires + * named.c - préparation de composants à l'affichage avec leurs noms + * + * Copyright (C) 2020 Cyrille Bagard + * + * This file is part of Chrysalide. + * + * Chrysalide is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 3 of the License, or + * (at your option) any later version. + * + * Chrysalide is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with Chrysalide. If not, see <http://www.gnu.org/licenses/>. + */ + + +#include "named.h" + + +#include <malloc.h> +#include <string.h> + + +#include "named-int.h" +#include "../glibext/named-int.h" + + + +/* ---------------------- PREPARATION VIS A VIS DE L'EXTERIEUR ---------------------- */ + + +/* Procède à l'initialisation de l'afficheur générique. */ +static void gtk_built_named_widget_class_init(GtkBuiltNamedWidgetClass *); + +/* Procède à l'initialisation d'une préparation pour affichage. */ +static void gtk_built_named_widget_init(GtkBuiltNamedWidget *); + +/* Procède à l'initialisation de l'interface de composant nommé. */ +static void gtk_built_named_widget_named_interface_init(GNamedWidgetInterface *); + +/* Supprime toutes les références externes. */ +static void gtk_built_named_widget_dispose(GtkBuiltNamedWidget *); + +/* Procède à la libération totale de la mémoire. */ +static void gtk_built_named_widget_finalize(GtkBuiltNamedWidget *); + + + +/* -------------------------- INTERFACE DE COMPOSANT NOMME -------------------------- */ + + +/* Fournit le désignation associée à un composant nommé. */ +static char *gtk_built_named_widget_get_name(const GtkBuiltNamedWidget *, bool); + +/* Fournit le composant associé à un composant nommé. */ +static GtkWidget *gtk_built_named_widget_get_widget(const GtkBuiltNamedWidget *); + + + +/* ---------------------------------------------------------------------------------- */ +/* PREPARATION VIS A VIS DE L'EXTERIEUR */ +/* ---------------------------------------------------------------------------------- */ + + +/* Détermine le type des préparations de composant pour affichage avec noms. */ +G_DEFINE_TYPE_WITH_CODE(GtkBuiltNamedWidget, gtk_built_named_widget, G_TYPE_OBJECT, + G_IMPLEMENT_INTERFACE(G_TYPE_NAMED_WIDGET, gtk_built_named_widget_named_interface_init)); + + +/****************************************************************************** +* * +* Paramètres : class = classe GTK à initialiser. * +* * +* Description : Procède à l'initialisation de l'afficheur générique. * +* * +* Retour : - * +* * +* Remarques : - * +* * +******************************************************************************/ + +static void gtk_built_named_widget_class_init(GtkBuiltNamedWidgetClass *class) +{ + GObjectClass *object; /* Plus haut niveau équivalent */ + + object = G_OBJECT_CLASS(class); + + object->dispose = (GObjectFinalizeFunc/* ! */)gtk_built_named_widget_dispose; + object->finalize = (GObjectFinalizeFunc)gtk_built_named_widget_finalize; + +} + + +/****************************************************************************** +* * +* Paramètres : widget = composant GTK à initialiser. * +* * +* Description : Procède à l'initialisation d'une préparation pour affichage. * +* * +* Retour : - * +* * +* Remarques : - * +* * +******************************************************************************/ + +static void gtk_built_named_widget_init(GtkBuiltNamedWidget *widget) +{ + widget->builder = NULL; + + widget->name = NULL; + widget->lname = NULL; + +} + + +/****************************************************************************** +* * +* Paramètres : iface = interface GLib à initialiser. * +* * +* Description : Procède à l'initialisation de l'interface de composant nommé.* +* * +* Retour : - * +* * +* Remarques : - * +* * +******************************************************************************/ + +static void gtk_built_named_widget_named_interface_init(GNamedWidgetInterface *iface) +{ + iface->get_name = (get_named_widget_name_fc)gtk_built_named_widget_get_name; + iface->get_widget = (get_named_widget_widget_fc)gtk_built_named_widget_get_widget; + +} + + +/****************************************************************************** +* * +* Paramètres : widget = instance d'objet GLib à traiter. * +* * +* Description : Supprime toutes les références externes. * +* * +* Retour : - * +* * +* Remarques : - * +* * +******************************************************************************/ + +static void gtk_built_named_widget_dispose(GtkBuiltNamedWidget *widget) +{ + g_clear_object(&widget->builder); + + G_OBJECT_CLASS(gtk_built_named_widget_parent_class)->dispose(G_OBJECT(widget)); + +} + + +/****************************************************************************** +* * +* Paramètres : widget = instance d'objet GLib à traiter. * +* * +* Description : Procède à la libération totale de la mémoire. * +* * +* Retour : - * +* * +* Remarques : - * +* * +******************************************************************************/ + +static void gtk_built_named_widget_finalize(GtkBuiltNamedWidget *widget) +{ + if (widget->name != NULL) + free(widget->name); + + if (widget->lname != NULL) + free(widget->lname); + + G_OBJECT_CLASS(gtk_built_named_widget_parent_class)->finalize(G_OBJECT(widget)); + +} + + +/****************************************************************************** +* * +* Paramètres : name = nom associé à l'élément. * +* lname = description longue du panneau. * +* path = chemin vers la description d'un composant graphique. * +* * +* Description : Crée une préparation pour l'affichage d'un composant nommé. * +* * +* Retour : Adresse de la structure mise en place. * +* * +* Remarques : - * +* * +******************************************************************************/ + +GtkBuiltNamedWidget *gtk_built_named_widget_new(const char *name, const char *lname, const char *path) +{ + GtkBuiltNamedWidget *result; /* Instance à retourner */ + + result = g_object_new(GTK_TYPE_BUILT_NAMED_WIDGET, NULL); + + result->name = strdup(name); + result->lname = strdup(lname); + + result->builder = gtk_builder_new_from_resource(path); + + return result; + +} + + +/****************************************************************************** +* * +* Paramètres : name = nom associé à l'élément. * +* lname = description longue du panneau. * +* resid = indentificant d'une ressource pour un composant. * +* * +* Description : Crée une préparation pour l'affichage d'un composant nommé. * +* * +* Retour : Adresse de la structure mise en place. * +* * +* Remarques : - * +* * +******************************************************************************/ + +GtkBuiltNamedWidget *gtk_built_named_widget_new_for_panel(const char *name, const char *lname, const char *resid) +{ + GtkBuiltNamedWidget *result; /* Instance à retourner */ + char *path; /* Chemin d'accès à constituer */ + + asprintf(&path, "/org/chrysalide/gui/panels/%s.ui", resid); + + result = gtk_built_named_widget_new(name, lname, path); + + free(path); + + return result; + +} + + +/****************************************************************************** +* * +* Paramètres : widget = préparation de composant à consulter. * +* * +* Description : Fournit le constructeur facilitant l'affichage. * +* * +* Retour : Constructeur mis en place. * +* * +* Remarques : - * +* * +******************************************************************************/ + +GtkBuilder *gtk_built_named_widget_get_builder(const GtkBuiltNamedWidget *widget) +{ + GtkBuilder *result; /* Constructeur à retourner */ + + result = widget->builder; + + if (result) + g_object_ref(G_OBJECT(result)); + + return result; + +} + + + +/* ---------------------------------------------------------------------------------- */ +/* INTERFACE DE COMPOSANT NOMME */ +/* ---------------------------------------------------------------------------------- */ + + +/****************************************************************************** +* * +* Paramètres : widget = composant nommé à consulter. * +* lname = précise s'il s'agit d'une version longue ou non. * +* * +* Description : Fournit le désignation associée à un composant nommé. * +* * +* Retour : Description courante. * +* * +* Remarques : - * +* * +******************************************************************************/ + +static char *gtk_built_named_widget_get_name(const GtkBuiltNamedWidget *widget, bool lname) +{ + char *result; /* Désignation à retourner */ + + if (lname) + result = strdup(widget->lname); + else + result = strdup(widget->name); + + return result; + +} + + +/****************************************************************************** +* * +* Paramètres : widget = composant nommé à consulter. * +* * +* Description : Fournit le composant associé à un composant nommé. * +* * +* Retour : Composant graphique GTK. * +* * +* Remarques : - * +* * +******************************************************************************/ + +static GtkWidget *gtk_built_named_widget_get_widget(const GtkBuiltNamedWidget *widget) +{ + GtkWidget *result; /* Composant GTK à renvoyer */ + + result = GTK_WIDGET(gtk_builder_get_object(widget->builder, "box")); + + g_object_ref(G_OBJECT(result)); + + if (gtk_widget_get_parent(result)) + gtk_widget_unparent(result); + + return result; + +} diff --git a/src/gtkext/named.h b/src/gtkext/named.h new file mode 100644 index 0000000..bb8d968 --- /dev/null +++ b/src/gtkext/named.h @@ -0,0 +1,62 @@ + +/* Chrysalide - Outil d'analyse de fichiers binaires + * named.h - prototypes pour la préparation de composants à l'affichage avec leurs noms + * + * Copyright (C) 2020 Cyrille Bagard + * + * This file is part of Chrysalide. + * + * Chrysalide is free software; you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation; either version 3 of the License, or + * (at your option) any later version. + * + * Chrysalide is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with Chrysalide. If not, see <http://www.gnu.org/licenses/>. + */ + + +#ifndef _GTKEXT_NAMED_H +#define _GTKEXT_NAMED_H + + +#include <glib-object.h> +#include <gtk/gtk.h> + + + +#define GTK_TYPE_BUILT_NAMED_WIDGET (gtk_built_named_widget_get_type()) +#define GTK_BUILT_NAMED_WIDGET(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj), GTK_TYPE_BUILT_NAMED_WIDGET, GtkBuiltNamedWidget)) +#define GTK_BUILT_NAMED_WIDGET_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass), GTK_TYPE_BUILT_NAMED_WIDGET, GtkBuiltNamedWidgetClass)) +#define GTK_IS_BUILT_NAMED_WIDGET(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), GTK_TYPE_BUILT_NAMED_WIDGET)) +#define GTK_IS_BUILT_NAMED_WIDGET_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), GTK_TYPE_BUILT_NAMED_WIDGET)) +#define GTK_BUILT_NAMED_WIDGET_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj), GTK_TYPE_BUILT_NAMED_WIDGET, GtkBuiltNamedWidgetClass)) + + +/* Préparation d'un composant pour affichage avec ses noms (instance) */ +typedef struct _GtkBuiltNamedWidget GtkBuiltNamedWidget; + +/* Préparation d'un composant pour affichage avec ses noms (classe) */ +typedef struct _GtkBuiltNamedWidgetClass GtkBuiltNamedWidgetClass; + + +/* Détermine le type des préparations de composant pour affichage avec noms. */ +GType gtk_built_named_widget_get_type(void); + +/* Crée une préparation pour l'affichage d'un composant nommé. */ +GtkBuiltNamedWidget *gtk_built_named_widget_new(const char *, const char *, const char *); + +/* Crée une préparation pour l'affichage d'un composant nommé. */ +GtkBuiltNamedWidget *gtk_built_named_widget_new_for_panel(const char *, const char *, const char *); + +/* Fournit le constructeur facilitant l'affichage. */ +GtkBuilder *gtk_built_named_widget_get_builder(const GtkBuiltNamedWidget *); + + + +#endif /* _GTKEXT_NAMED_H */ |