summaryrefslogtreecommitdiff
path: root/src/gui/panels
diff options
context:
space:
mode:
authorCyrille Bagard <nocbos@gmail.com>2014-07-22 21:38:30 (GMT)
committerCyrille Bagard <nocbos@gmail.com>2014-07-22 21:38:30 (GMT)
commit250d2773aa372434b721a4e72bff5da7b4f3fb4e (patch)
tree3bbb6b75e1cc53c5aa189489e416e3dd92bb79c2 /src/gui/panels
parentdb863244b804cbf4c06399f7c6f8241d91c9ee9b (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.c63
-rw-r--r--src/gui/panels/strings.c87
-rw-r--r--src/gui/panels/strings.h10
-rw-r--r--src/gui/panels/symbols.c59
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);