diff options
author | Cyrille Bagard <nocbos@gmail.com> | 2014-07-22 21:38:30 (GMT) |
---|---|---|
committer | Cyrille Bagard <nocbos@gmail.com> | 2014-07-22 21:38:30 (GMT) |
commit | 250d2773aa372434b721a4e72bff5da7b4f3fb4e (patch) | |
tree | 3bbb6b75e1cc53c5aa189489e416e3dd92bb79c2 /src/gui/panels | |
parent | db863244b804cbf4c06399f7c6f8241d91c9ee9b (diff) |
Used in the right way some features of GLib classes in the GUI code.
git-svn-id: svn://svn.gna.org/svn/chrysalide/trunk@382 abbe820e-26c8-41b2-8c08-b7b2b41f8b0a
Diffstat (limited to 'src/gui/panels')
-rw-r--r-- | src/gui/panels/glance.c | 63 | ||||
-rw-r--r-- | src/gui/panels/strings.c | 87 | ||||
-rw-r--r-- | src/gui/panels/strings.h | 10 | ||||
-rw-r--r-- | src/gui/panels/symbols.c | 59 |
4 files changed, 204 insertions, 15 deletions
diff --git a/src/gui/panels/glance.c b/src/gui/panels/glance.c index ab80ba2..97d57d1 100644 --- a/src/gui/panels/glance.c +++ b/src/gui/panels/glance.c @@ -75,6 +75,12 @@ static void g_glance_panel_class_init(GGlancePanelClass *); /* Initialise une instance de panneau d'aperçu rapide. */ static void g_glance_panel_init(GGlancePanel *); +/* Supprime toutes les références externes. */ +static void g_glance_panel_dispose(GGlancePanel *); + +/* Procède à la libération totale de la mémoire. */ +static void g_glance_panel_finalize(GGlancePanel *); + /* Définit une fois et au bon moment le fond de l'aperçu rapide. */ static void define_glance_bg(GtkWidget *, GGlancePanel *); @@ -128,6 +134,18 @@ G_DEFINE_TYPE(GGlancePanel, g_glance_panel, G_TYPE_PANEL_ITEM); static void g_glance_panel_class_init(GGlancePanelClass *klass) { + GObjectClass *object; /* Autre version de la classe */ + GEditorItemClass *editem; /* Encore une autre vision... */ + + object = G_OBJECT_CLASS(klass); + + object->dispose = (GObjectFinalizeFunc/* ! */)g_glance_panel_dispose; + object->finalize = (GObjectFinalizeFunc)g_glance_panel_finalize; + + editem = G_EDITOR_ITEM_CLASS(klass); + + editem->update_view = (update_item_view_fc)update_glance_panel_for_view; + editem->update_content = (update_item_view_fc)update_glance_panel_for_view_content; } @@ -161,9 +179,6 @@ static void g_glance_panel_init(GGlancePanel *panel) gtk_container_add(GTK_CONTAINER(base->widget), area); gtk_widget_show(base->widget); - base->update_view = (update_item_view_fc)update_glance_panel_for_view; - base->update_content = (update_item_view_fc)update_glance_panel_for_view_content; - gtk_widget_set_size_request(base->widget, 300, 300); g_signal_connect(G_OBJECT(area), "draw", @@ -180,6 +195,48 @@ static void g_glance_panel_init(GGlancePanel *panel) } + +/****************************************************************************** +* * +* Paramètres : panel = instance d'objet GLib à traiter. * +* * +* Description : Supprime toutes les références externes. * +* * +* Retour : - * +* * +* Remarques : - * +* * +******************************************************************************/ + +static void g_glance_panel_dispose(GGlancePanel *panel) +{ + if (panel->cache != NULL) + cairo_surface_destroy(panel->cache); + + G_OBJECT_CLASS(g_glance_panel_parent_class)->dispose(G_OBJECT(panel)); + +} + + +/****************************************************************************** +* * +* Paramètres : panel = instance d'objet GLib à traiter. * +* * +* Description : Procède à la libération totale de la mémoire. * +* * +* Retour : - * +* * +* Remarques : - * +* * +******************************************************************************/ + +static void g_glance_panel_finalize(GGlancePanel *panel) +{ + G_OBJECT_CLASS(g_glance_panel_parent_class)->finalize(G_OBJECT(panel)); + +} + + /****************************************************************************** * * * Paramètres : ref = espace de référencement global. * diff --git a/src/gui/panels/strings.c b/src/gui/panels/strings.c index aac5f6f..630b175 100644 --- a/src/gui/panels/strings.c +++ b/src/gui/panels/strings.c @@ -72,6 +72,18 @@ typedef enum _StringsColumn } StringsColumn; +/* Initialise la classe des panneaux d'affichage de chaînes. */ +static void g_strings_panel_class_init(GStringsPanelClass *); + +/* Initialise une instance de panneau d'affichage des chaînes. */ +static void g_strings_panel_init(GStringsPanel *); + +/* Supprime toutes les références externes. */ +static void g_strings_panel_dispose(GStringsPanel *); + +/* Procède à la libération totale de la mémoire. */ +static void g_strings_panel_finalize(GStringsPanel *); + /* Réagit à un changement d'affichage principal de contenu. */ static void change_strings_panel_current_binary(GStringsPanel *, GLoadedBinary *); @@ -93,7 +105,7 @@ static void mcb_strings_copy(GtkMenuItem *, GtkTreeView *); /* ---------------------------------------------------------------------------------- */ -/* Indique le type définit pour un panneau d'aperçu de graphiques. */ +/* Indique le type définit pour un panneau d'affichage des chaînes. */ G_DEFINE_TYPE(GStringsPanel, g_strings_panel, G_TYPE_PANEL_ITEM); @@ -101,7 +113,7 @@ G_DEFINE_TYPE(GStringsPanel, g_strings_panel, G_TYPE_PANEL_ITEM); * * * Paramètres : klass = classe à initialiser. * * * -* Description : Initialise la classe des panneaux d'aperçu de graphiques. * +* Description : Initialise la classe des panneaux d'affichage de chaînes. * * * * Retour : - * * * @@ -111,6 +123,17 @@ G_DEFINE_TYPE(GStringsPanel, g_strings_panel, G_TYPE_PANEL_ITEM); static void g_strings_panel_class_init(GStringsPanelClass *klass) { + GObjectClass *object; /* Autre version de la classe */ + GEditorItemClass *editem; /* Encore une autre vision... */ + + object = G_OBJECT_CLASS(klass); + + object->dispose = (GObjectFinalizeFunc/* ! */)g_strings_panel_dispose; + object->finalize = (GObjectFinalizeFunc)g_strings_panel_finalize; + + editem = G_EDITOR_ITEM_CLASS(klass); + + editem->update_binary = (update_item_binary_fc)change_strings_panel_current_binary; } @@ -119,7 +142,7 @@ static void g_strings_panel_class_init(GStringsPanelClass *klass) * * * Paramètres : panel = instance à initialiser. * * * -* Description : Initialise une instance de panneau d'aperçu de graphiques. * +* Description : Initialise une instance de panneau d'affichage des chaînes. * * * * Retour : - * * * @@ -198,9 +221,50 @@ static void g_strings_panel_init(GStringsPanel *panel) /****************************************************************************** * * +* Paramètres : panel = instance d'objet GLib à traiter. * +* * +* Description : Supprime toutes les références externes. * +* * +* Retour : - * +* * +* Remarques : - * +* * +******************************************************************************/ + +static void g_strings_panel_dispose(GStringsPanel *panel) +{ + if (panel->binary != NULL) + g_object_unref(G_OBJECT(panel->binary)); + + G_OBJECT_CLASS(g_strings_panel_parent_class)->dispose(G_OBJECT(panel)); + +} + + +/****************************************************************************** +* * +* Paramètres : panel = instance d'objet GLib à traiter. * +* * +* Description : Procède à la libération totale de la mémoire. * +* * +* Retour : - * +* * +* Remarques : - * +* * +******************************************************************************/ + +static void g_strings_panel_finalize(GStringsPanel *panel) +{ + G_OBJECT_CLASS(g_strings_panel_parent_class)->finalize(G_OBJECT(panel)); + +} + + +/****************************************************************************** +* * * Paramètres : ref = espace de référencement global. * * * -* Description : Crée un panneau d'affichage des symboles. * +* Description : Crée un panneau d'affichage des chaînes. * * * * Retour : Adresse de la structure mise en place. * * * @@ -226,7 +290,7 @@ GEditorItem *g_strings_panel_new(GObject *ref) * * * Paramètres : ref = espace de référencement global. * * * -* Description : Construit et intègre un panneau d'affichage des symboles. * +* Description : Construit et intègre un panneau d'affichage des chaînes. * * * * Retour : Adresse du panneau mis en place. * * * @@ -241,7 +305,6 @@ GPanelItem *create_strings_panel(GObject *ref) result = g_strings_panel_new(ref); /* Enregistre correctement le tout */ - result->update_binary = (update_item_binary_fc)change_strings_panel_current_binary; register_editor_item(result); return G_PANEL_ITEM(result); @@ -274,6 +337,18 @@ static void change_strings_panel_current_binary(GStringsPanel *panel, GLoadedBin char *text; /* Version imprimable du texte */ GtkTreeIter iter; /* Point d'insertion */ + /* Basculement du binaire utilisé */ + + if (panel->binary != NULL) + g_object_unref(G_OBJECT(panel->binary)); + + panel->binary = binary; + + if (panel->binary != NULL) + g_object_ref(G_OBJECT(panel->binary)); + + /* Actualisation de l'affichage */ + store = g_object_get_data(G_OBJECT(panel), "store"); format = g_loaded_binary_get_format(binary); diff --git a/src/gui/panels/strings.h b/src/gui/panels/strings.h index 04558fb..556dcbe 100644 --- a/src/gui/panels/strings.h +++ b/src/gui/panels/strings.h @@ -44,20 +44,20 @@ #define G_STRINGS_PANEL_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj), G_TYPE_STRINGS_PANEL, GStringsPanelClass)) -/* Panneau d'affichage des symboles (instance) */ +/* Panneau d'affichage des chaînes (instance) */ typedef struct _GStringsPanel GStringsPanel; -/* Panneau d'affichage des symboles (classe) */ +/* Panneau d'affichage des chaînes (classe) */ typedef struct _GStringsPanelClass GStringsPanelClass; -/* Indique le type définit pour un panneau d'affichage des symboles. */ +/* Indique le type définit pour un panneau d'affichage des chaînes. */ GType g_strings_panel_get_type(void); -/* Crée un panneau d'affichage des symboles. */ +/* Crée un panneau d'affichage des chaînes. */ GEditorItem *g_strings_panel_new(GObject *); -/* Construit et intègre un panneau d'affichage des symboles. */ +/* Construit et intègre un panneau d'affichage des chaînes. */ GPanelItem *create_strings_panel(GObject *); diff --git a/src/gui/panels/symbols.c b/src/gui/panels/symbols.c index 064c31d..959fb2c 100644 --- a/src/gui/panels/symbols.c +++ b/src/gui/panels/symbols.c @@ -87,6 +87,12 @@ static void g_symbols_panel_class_init(GSymbolsPanelClass *); /* Initialise une instance de panneau d'aperçu de graphiques. */ static void g_symbols_panel_init(GSymbolsPanel *); +/* Supprime toutes les références externes. */ +static void g_symbols_panel_dispose(GSymbolsPanel *); + +/* Procède à la libération totale de la mémoire. */ +static void g_symbols_panel_finalize(GSymbolsPanel *); + /* Réagit au changement d'affichage des symboles. */ static void on_symbols_display_change(GtkToggleToolButton *, GSymbolsPanel *); @@ -166,6 +172,17 @@ G_DEFINE_TYPE(GSymbolsPanel, g_symbols_panel, G_TYPE_PANEL_ITEM); static void g_symbols_panel_class_init(GSymbolsPanelClass *klass) { + GObjectClass *object; /* Autre version de la classe */ + GEditorItemClass *editem; /* Encore une autre vision... */ + + object = G_OBJECT_CLASS(klass); + + object->dispose = (GObjectFinalizeFunc/* ! */)g_symbols_panel_dispose; + object->finalize = (GObjectFinalizeFunc)g_symbols_panel_finalize; + + editem = G_EDITOR_ITEM_CLASS(klass); + + editem->update_binary = (update_item_binary_fc)change_symbols_panel_current_binary; } @@ -326,6 +343,47 @@ static void g_symbols_panel_init(GSymbolsPanel *panel) /****************************************************************************** * * +* Paramètres : panel = instance d'objet GLib à traiter. * +* * +* Description : Supprime toutes les références externes. * +* * +* Retour : - * +* * +* Remarques : - * +* * +******************************************************************************/ + +static void g_symbols_panel_dispose(GSymbolsPanel *panel) +{ + if (panel->binary != NULL) + g_object_unref(G_OBJECT(panel->binary)); + + G_OBJECT_CLASS(g_symbols_panel_parent_class)->dispose(G_OBJECT(panel)); + +} + + +/****************************************************************************** +* * +* Paramètres : panel = instance d'objet GLib à traiter. * +* * +* Description : Procède à la libération totale de la mémoire. * +* * +* Retour : - * +* * +* Remarques : - * +* * +******************************************************************************/ + +static void g_symbols_panel_finalize(GSymbolsPanel *panel) +{ + G_OBJECT_CLASS(g_symbols_panel_parent_class)->finalize(G_OBJECT(panel)); + +} + + +/****************************************************************************** +* * * Paramètres : ref = espace de référencement global. * * * * Description : Crée un panneau d'affichage des symboles. * @@ -369,7 +427,6 @@ GPanelItem *create_symbols_panel(GObject *ref) result = g_symbols_panel_new(ref); /* Enregistre correctement le tout */ - result->update_binary = (update_item_binary_fc)change_symbols_panel_current_binary; register_editor_item(result); return G_PANEL_ITEM(result); |