summaryrefslogtreecommitdiff
path: root/src/gui
diff options
context:
space:
mode:
authorCyrille Bagard <nocbos@gmail.com>2014-09-11 18:44:09 (GMT)
committerCyrille Bagard <nocbos@gmail.com>2014-09-11 18:44:09 (GMT)
commitd1dd9ae74ba56b04ad8f79d926b2282c6c7fa0fd (patch)
treef25c3914e514eb3c5959f91979ae18eaf0e35b8e /src/gui
parentbe1f2f147e8ce15f20ec4de439088714ffa50e8a (diff)
Updated the code and activated back the toolbar items.
git-svn-id: svn://svn.gna.org/svn/chrysalide/trunk@402 abbe820e-26c8-41b2-8c08-b7b2b41f8b0a
Diffstat (limited to 'src/gui')
-rw-r--r--src/gui/tb/Makefile.am3
-rw-r--r--src/gui/tb/portions.c159
-rw-r--r--src/gui/tb/portions.h20
-rw-r--r--src/gui/tb/source.c153
-rw-r--r--src/gui/tb/source.h22
-rw-r--r--src/gui/tb/tbitem-int.h55
-rw-r--r--src/gui/tb/tbitem.c (renamed from src/gui/tb/toolbar.c)48
-rw-r--r--src/gui/tb/tbitem.h (renamed from src/gui/tb/toolbar.h)11
8 files changed, 358 insertions, 113 deletions
diff --git a/src/gui/tb/Makefile.am b/src/gui/tb/Makefile.am
index 52033c3..60aa031 100644
--- a/src/gui/tb/Makefile.am
+++ b/src/gui/tb/Makefile.am
@@ -4,7 +4,8 @@ noinst_LTLIBRARIES = libguitb.la
libguitb_la_SOURCES = \
portions.h portions.c \
source.h source.c \
- toolbar.h toolbar.c
+ tbitem-int.h \
+ tbitem.h tbitem.c
libguitb_la_LDFLAGS =
diff --git a/src/gui/tb/portions.c b/src/gui/tb/portions.c
index bbc31b9..53d9dd4 100644
--- a/src/gui/tb/portions.c
+++ b/src/gui/tb/portions.c
@@ -28,72 +28,127 @@
#include <i18n.h>
-#include "toolbar.h"
-#include "../editem-int.h"
+#include "tbitem-int.h"
#include "../../format/format.h"
#include "../../gtkext/gtkbinarystrip.h"
-/* Construit l'élément GTK pour une barre d'outils. */
-static GtkWidget *build_portions_tb_widget(GObject *);
+/* Elément réactif présentant des portions de binaire (instance) */
+struct _GPortionsTbItem
+{
+ GToolbarItem parent; /* A laisser en premier */
-/* Fait suivre un changement d'adresse dans la barre. */
-static void track_address_on_binary_strip(GtkBinaryStrip *, vmpa_t, GObject *);
+};
+
+
+/* Elément réactif présentant des portions de binaire (classe) */
+struct _GPortionsTbItemClass
+{
+ GToolbarItemClass parent; /* A laisser en premier */
+
+};
+
+
+
+/* Initialise la classe des éléments réactifs de l'éditeur. */
+static void g_portions_tbitem_class_init(GPortionsTbItemClass *);
+
+/* Initialise une instance d'élément réactif pour l'éditeur. */
+static void g_portions_tbitem_init(GPortionsTbItem *);
+
+/* Supprime toutes les références externes. */
+static void g_portions_tbitem_dispose(GPortionsTbItem *);
+
+/* Procède à la libération totale de la mémoire. */
+static void g_portions_tbitem_finalize(GPortionsTbItem *);
/* Réagit à un changement du binaire courant. */
static void update_portions_item_binary(GEditorItem *, GLoadedBinary *);
+/* Fait suivre un changement d'adresse dans la barre. */
+static void track_address_on_binary_strip(GtkBinaryStrip *, vmpa_t, GObject *);
+
+
+
+/* Indique le type défini pour un affichage de portions destiné à une barre d'outils. */
+G_DEFINE_TYPE(GPortionsTbItem, g_portions_tbitem, G_TYPE_TOOLBAR_ITEM);
/******************************************************************************
* *
-* Paramètres : ref = espace de référencement global. *
+* Paramètres : klass = classe à initialiser. *
* *
-* Description : Construit l'élément GTK pour une barre d'outils. *
+* Description : Initialise la classe des éléments réactifs de l'éditeur. *
* *
-* Retour : Adresse du composant mis en place. *
+* Retour : - *
* *
* Remarques : - *
* *
******************************************************************************/
-static GtkWidget *build_portions_tb_widget(GObject *ref)
+static void g_portions_tbitem_class_init(GPortionsTbItemClass *klass)
{
- GtkWidget *result; /* Composant à retourner */
+ GObjectClass *object; /* Autre version de la classe */
+ GEditorItemClass *item; /* Encore une autre vision */
+
+ object = G_OBJECT_CLASS(klass);
+ item = G_EDITOR_ITEM_CLASS(klass);
+
+ object->dispose = (GObjectFinalizeFunc/* ! */)g_portions_tbitem_dispose;
+ object->finalize = (GObjectFinalizeFunc)g_portions_tbitem_finalize;
+
+ item->update_binary = update_portions_item_binary;
+
+}
+
+
+/******************************************************************************
+* *
+* Paramètres : item = instance à initialiser. *
+* *
+* Description : Initialise une instance d'élément réactif pour l'éditeur. *
+* *
+* Retour : - *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+static void g_portions_tbitem_init(GPortionsTbItem *item)
+{
+ GtkWidget *widget; /* Composant principal */
GtkWidget *handlebox; /* Support relocalisable */
GtkWidget *strip; /* Bande pour binaire */
- result = GTK_WIDGET(gtk_tool_item_new());
- gtk_tool_item_set_expand(GTK_TOOL_ITEM(result), TRUE);
- gtk_widget_show(result);
+ widget = GTK_WIDGET(gtk_tool_item_new());
+ gtk_tool_item_set_expand(GTK_TOOL_ITEM(widget), TRUE);
+ gtk_widget_show(widget);
+
+ G_EDITOR_ITEM(item)->widget = widget;
handlebox = gtk_handle_box_new();
gtk_widget_show(handlebox);
- gtk_container_add(GTK_CONTAINER(result), handlebox);
+ gtk_container_add(GTK_CONTAINER(widget), handlebox);
strip = gtk_binary_strip_new();
gtk_widget_show(strip);
gtk_container_add(GTK_CONTAINER(handlebox), strip);
- g_object_set_data(G_OBJECT(result), "strip", strip);
+ g_object_set_data(G_OBJECT(widget), "strip", strip);
g_signal_connect(strip, "select-address",
G_CALLBACK(track_address_on_binary_strip),
- ref);
-
- return result;
+ item);
}
/******************************************************************************
* *
-* Paramètres : strip = composant d'affichage parcouru. *
-* addr = nouvelle adresse du curseur courant. *
-* ref = espace de référencement global. *
+* Paramètres : item = instance d'objet GLib à traiter. *
* *
-* Description : Fait suivre un changement d'adresse dans la barre. *
+* Description : Supprime toutes les références externes. *
* *
* Retour : - *
* *
@@ -101,12 +156,29 @@ static GtkWidget *build_portions_tb_widget(GObject *ref)
* *
******************************************************************************/
-static void track_address_on_binary_strip(GtkBinaryStrip *strip, vmpa_t addr, GObject *ref)
+static void g_portions_tbitem_dispose(GPortionsTbItem *item)
{
+ G_OBJECT_CLASS(g_portions_tbitem_parent_class)->dispose(G_OBJECT(item));
- printf("===> CHANGE TO 0x%08llx\n", addr);
+}
+/******************************************************************************
+* *
+* Paramètres : item = instance d'objet GLib à traiter. *
+* *
+* Description : Procède à la libération totale de la mémoire. *
+* *
+* Retour : - *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+static void g_portions_tbitem_finalize(GPortionsTbItem *item)
+{
+ G_OBJECT_CLASS(g_portions_tbitem_parent_class)->finalize(G_OBJECT(item));
+
}
@@ -114,7 +186,7 @@ static void track_address_on_binary_strip(GtkBinaryStrip *strip, vmpa_t addr, GO
* *
* Paramètres : ref = espace de référencement global. *
* *
-* Description : Crée une sélection de fichier réactive pour barre d'outils. *
+* Description : Crée un élément réactif présentant des portions de binaire. *
* *
* Retour : Adresse de la structure d'encadrement mise en place. *
* *
@@ -124,17 +196,11 @@ static void track_address_on_binary_strip(GtkBinaryStrip *strip, vmpa_t addr, GO
GEditorItem *create_portions_tb_item(GObject *ref)
{
- GEditorItem *result; /* Structure à retourner */
- GtkWidget *widget; /* Composant affiché à l'écran */
-
- widget = build_portions_tb_widget(ref);
-
- result = g_toolbar_item_new(ref, "portions", widget, _("Portions"));
+ GPortionsTbItem *result; /* Structure à retourner */
- /* FIXME */
- //G_EDITOR_ITEM_GET_CLASS(result)->update_binary = update_portions_item_binary;
+ result = g_object_new(G_TYPE_PORTIONS_TBITEM, NULL);
- return result;
+ return g_toolbar_item_setup(G_TOOLBAR_ITEM(result), ref, "portions", _("Portions"));
}
@@ -161,3 +227,26 @@ static void update_portions_item_binary(GEditorItem *item, GLoadedBinary *binary
gtk_binary_strip_attach(strip, binary);
}
+
+
+/******************************************************************************
+* *
+* Paramètres : strip = composant d'affichage parcouru. *
+* addr = nouvelle adresse du curseur courant. *
+* ref = espace de référencement global. *
+* *
+* Description : Fait suivre un changement d'adresse dans la barre. *
+* *
+* Retour : - *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+static void track_address_on_binary_strip(GtkBinaryStrip *strip, vmpa_t addr, GObject *ref)
+{
+
+ printf("===> CHANGE TO 0x%08llx\n", 123);
+
+
+}
diff --git a/src/gui/tb/portions.h b/src/gui/tb/portions.h
index 6f3c3b6..18e1f7d 100644
--- a/src/gui/tb/portions.h
+++ b/src/gui/tb/portions.h
@@ -26,10 +26,28 @@
#define _GUI_TB_PORTIONS_H
-#include "../editem.h"
+#include "tbitem.h"
+#define G_TYPE_PORTIONS_TBITEM g_portions_tbitem_get_type()
+#define G_PORTIONS_TBITEM(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj), g_portions_tbitem_get_type(), GToolbarItem))
+#define G_IS_PORTIONS_TBITEM(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), g_portions_tbitem_get_type()))
+#define G_PORTIONS_TBITEM_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass), G_TYPE_PORTIONS_TBITEM, GToolbarItemClass))
+#define G_IS_PORTIONS_TBITEM_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), G_TYPE_PORTIONS_TBITEM))
+#define G_PORTIONS_TBITEM_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj), G_TYPE_PORTIONS_TBITEM, GToolbarItemClass))
+
+
+/* Elément réactif présentant des portions de binaire (instance) */
+typedef struct _GPortionsTbItem GPortionsTbItem;
+
+/* Elément réactif présentant des portions de binaire (classe) */
+typedef struct _GPortionsTbItemClass GPortionsTbItemClass;
+
+
+/* Indique le type défini pour un affichage de portions destiné à une barre d'outils. */
+GType g_portions_tbitem_get_type(void);
+
/* Crée une sélection de fichier réactive pour barre d'outils. */
GEditorItem *create_portions_tb_item(GObject *ref);
diff --git a/src/gui/tb/source.c b/src/gui/tb/source.c
index bac6b0f..9f041a1 100644
--- a/src/gui/tb/source.c
+++ b/src/gui/tb/source.c
@@ -28,8 +28,7 @@
#include <i18n.h>
-#include "toolbar.h"
-#include "../editem-int.h"
+#include "tbitem-int.h"
#include "../../format/format.h"
#include "../../gtkext/easygtk.h"
#include "../../gtkext/gtkbufferview.h"
@@ -37,8 +36,34 @@
-/* Construit l'élément GTK pour une barre d'outils. */
-static GtkWidget *build_source_tb_widget(GObject *);
+/* Elément réactif listant les fichiers décompilés (instance) */
+struct _GSourceTbItem
+{
+ GToolbarItem parent; /* A laisser en premier */
+
+};
+
+
+/* Elément réactif listant les fichiers décompilés (classe) */
+struct _GSourceTbItemClass
+{
+ GToolbarItemClass parent; /* A laisser en premier */
+
+};
+
+
+
+/* Initialise la classe des éléments réactifs de l'éditeur. */
+static void g_source_tbitem_class_init(GSourceTbItemClass *);
+
+/* Initialise une instance d'élément réactif pour l'éditeur. */
+static void g_source_tbitem_init(GSourceTbItem *);
+
+/* Supprime toutes les références externes. */
+static void g_source_tbitem_dispose(GSourceTbItem *);
+
+/* Procède à la libération totale de la mémoire. */
+static void g_source_tbitem_finalize(GSourceTbItem *);
/* Réagit à un changement du binaire courant. */
static void update_source_item_binary(GEditorItem *, GLoadedBinary *);
@@ -47,49 +72,120 @@ static void update_source_item_binary(GEditorItem *, GLoadedBinary *);
static void update_source_item_view(GEditorItem *, GtkViewPanel *);
/* Réagit à un changement de sélection de la source courante. */
-static void change_selected_source(GtkComboBox *, GObject *);
+static void change_selected_source(GtkComboBox *, GSourceTbItem *);
+
+/* Indique le type défini pour une liste de fichiers destinée à une barre d'outils. */
+G_DEFINE_TYPE(GSourceTbItem, g_source_tbitem, G_TYPE_TOOLBAR_ITEM);
+
/******************************************************************************
* *
-* Paramètres : ref = espace de référencement global. *
+* Paramètres : klass = classe à initialiser. *
+* *
+* Description : Initialise la classe des éléments réactifs de l'éditeur. *
+* *
+* Retour : - *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+static void g_source_tbitem_class_init(GSourceTbItemClass *klass)
+{
+ GObjectClass *object; /* Autre version de la classe */
+ GEditorItemClass *item; /* Encore une autre vision */
+
+ object = G_OBJECT_CLASS(klass);
+ item = G_EDITOR_ITEM_CLASS(klass);
+
+ object->dispose = (GObjectFinalizeFunc/* ! */)g_source_tbitem_dispose;
+ object->finalize = (GObjectFinalizeFunc)g_source_tbitem_finalize;
+
+ item->update_binary = update_source_item_binary;
+ item->update_view = update_source_item_view;
+
+}
+
+
+/******************************************************************************
+* *
+* Paramètres : item = instance à initialiser. *
* *
-* Description : Construit l'élément GTK pour une barre d'outils. *
+* Description : Initialise une instance d'élément réactif pour l'éditeur. *
* *
-* Retour : Adresse du composant mis en place. *
+* Retour : - *
* *
* Remarques : - *
* *
******************************************************************************/
-static GtkWidget *build_source_tb_widget(GObject *ref)
+static void g_source_tbitem_init(GSourceTbItem *item)
{
- GtkWidget *result; /* Composant à retourner */
+ GtkWidget *widget; /* Composant principal */
GtkWidget *handlebox; /* Support relocalisable */
GtkWidget *hbox; /* Support interne */
GtkWidget *label; /* Etiquette d'introduction */
GtkWidget *comboboxentry; /* Liste de fichiers */
- result = GTK_WIDGET(gtk_tool_item_new());
- gtk_widget_show(result);
+ widget = GTK_WIDGET(gtk_tool_item_new());
+ gtk_widget_show(widget);
+
+ G_EDITOR_ITEM(item)->widget = widget;
handlebox = gtk_handle_box_new();
gtk_widget_show(handlebox);
- gtk_container_add(GTK_CONTAINER(result), handlebox);
+ gtk_container_add(GTK_CONTAINER(widget), handlebox);
hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 8);
gtk_widget_show(hbox);
gtk_container_add(GTK_CONTAINER(handlebox), hbox);
- label = qck_create_label(G_OBJECT(result), "label", _(" Source: "));
+ label = qck_create_label(G_OBJECT(widget), "label", _(" Source: "));
gtk_box_pack_start(GTK_BOX(hbox), label, FALSE, FALSE, 0);
- comboboxentry = qck_create_combobox2(G_OBJECT(result), "combo",
- G_CALLBACK(change_selected_source), ref);
+ comboboxentry = qck_create_combobox2(G_OBJECT(widget), "combo",
+ G_CALLBACK(change_selected_source), item);
gtk_box_pack_start(GTK_BOX(hbox), comboboxentry, TRUE, TRUE, 0);
- return result;
+}
+
+
+/******************************************************************************
+* *
+* Paramètres : item = instance d'objet GLib à traiter. *
+* *
+* Description : Supprime toutes les références externes. *
+* *
+* Retour : - *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+static void g_source_tbitem_dispose(GSourceTbItem *item)
+{
+ G_OBJECT_CLASS(g_source_tbitem_parent_class)->dispose(G_OBJECT(item));
+
+}
+
+
+/******************************************************************************
+* *
+* Paramètres : item = instance d'objet GLib à traiter. *
+* *
+* Description : Procède à la libération totale de la mémoire. *
+* *
+* Retour : - *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+static void g_source_tbitem_finalize(GSourceTbItem *item)
+{
+ G_OBJECT_CLASS(g_source_tbitem_parent_class)->finalize(G_OBJECT(item));
}
@@ -98,7 +194,7 @@ static GtkWidget *build_source_tb_widget(GObject *ref)
* *
* Paramètres : ref = espace de référencement global. *
* *
-* Description : Crée une sélection de fichier réactive pour barre d'outils. *
+* Description : Crée un élément réactif présentant des source de binaire. *
* *
* Retour : Adresse de la structure d'encadrement mise en place. *
* *
@@ -108,18 +204,11 @@ static GtkWidget *build_source_tb_widget(GObject *ref)
GEditorItem *create_source_tb_item(GObject *ref)
{
- GEditorItem *result; /* Structure à retourner */
- GtkWidget *widget; /* Composant affiché à l'écran */
-
- widget = build_source_tb_widget(ref);
-
- result = g_toolbar_item_new(ref, "source", widget, _("Source files"));
+ GSourceTbItem *result; /* Structure à retourner */
- /* FIXME */
- //G_EDITOR_ITEM_GET_CLASS(result)->update_binary = update_source_item_binary;
- //G_EDITOR_ITEM_GET_CLASS(result)->update_view = update_source_item_view;
+ result = g_object_new(G_TYPE_SOURCE_TBITEM, NULL);
- return result;
+ return g_toolbar_item_setup(G_TOOLBAR_ITEM(result), ref, "source", _("Source files"));
}
@@ -152,7 +241,7 @@ static void update_source_item_binary(GEditorItem *item, GLoadedBinary *binary)
/* Réinitialisation */
- g_signal_handlers_block_by_func(combo, G_CALLBACK(change_selected_source), item->ref);
+ g_signal_handlers_block_by_func(combo, G_CALLBACK(change_selected_source), item);
/* FIXME : 3.0 */
//gtk_combo_box_text_remove_all(combo);
@@ -172,7 +261,7 @@ static void update_source_item_binary(GEditorItem *item, GLoadedBinary *binary)
/* Réactivation */
- g_signal_handlers_unblock_by_func(combo, G_CALLBACK(change_selected_source), item->ref);
+ g_signal_handlers_unblock_by_func(combo, G_CALLBACK(change_selected_source), item);
//gtk_combo_box_set_active(combo, defsrc);
@@ -202,7 +291,7 @@ static void update_source_item_view(GEditorItem *item, GtkViewPanel *view)
/******************************************************************************
* *
* Paramètres : widget = composant GTK en cause. *
-* ref = espace de référencement global. *
+* item = élément réactif associé. *
* *
* Description : Réagit à un changement de sélection de la source courante. *
* *
@@ -212,7 +301,7 @@ static void update_source_item_view(GEditorItem *item, GtkViewPanel *view)
* *
******************************************************************************/
-static void change_selected_source(GtkComboBox *widget, GObject *ref)
+static void change_selected_source(GtkComboBox *widget, GSourceTbItem *item)
{
#if 0
gint index; /* Nouvelle source ciblée */
diff --git a/src/gui/tb/source.h b/src/gui/tb/source.h
index 2d9c54e..ca2205f 100644
--- a/src/gui/tb/source.h
+++ b/src/gui/tb/source.h
@@ -2,7 +2,7 @@
/* Chrysalide - Outil d'analyse de fichiers binaires
* source.h - prototypes pour la sélection du fichier ciblé lors d'une décompilation
*
- * Copyright (C) 2010 Cyrille Bagard
+ * Copyright (C) 2010-2014 Cyrille Bagard
*
* This file is part of Chrysalide.
*
@@ -26,10 +26,28 @@
#define _GUI_TB_SOURCE_H
-#include "../editem.h"
+#include "tbitem.h"
+#define G_TYPE_SOURCE_TBITEM g_source_tbitem_get_type()
+#define G_SOURCE_TBITEM(obj) (G_TYPE_CHECK_INSTANCE_CAST((obj), g_source_tbitem_get_type(), GToolbarItem))
+#define G_IS_SOURCE_TBITEM(obj) (G_TYPE_CHECK_INSTANCE_TYPE((obj), g_source_tbitem_get_type()))
+#define G_SOURCE_TBITEM_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass), G_TYPE_SOURCE_TBITEM, GToolbarItemClass))
+#define G_IS_SOURCE_TBITEM_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), G_TYPE_SOURCE_TBITEM))
+#define G_SOURCE_TBITEM_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj), G_TYPE_SOURCE_TBITEM, GToolbarItemClass))
+
+
+/* Elément réactif listant les fichiers décompilés (instance) */
+typedef struct _GSourceTbItem GSourceTbItem;
+
+/* Elément réactif listant les fichiers décompilés (classe) */
+typedef struct _GSourceTbItemClass GSourceTbItemClass;
+
+
+/* Indique le type défini pour une liste de fichiers destinée à une barre d'outils. */
+GType g_source_tbitem_get_type(void);
+
/* Crée une sélection de fichier réactive pour barre d'outils. */
GEditorItem *create_source_tb_item(GObject *ref);
diff --git a/src/gui/tb/tbitem-int.h b/src/gui/tb/tbitem-int.h
new file mode 100644
index 0000000..8caa596
--- /dev/null
+++ b/src/gui/tb/tbitem-int.h
@@ -0,0 +1,55 @@
+
+/* Chrysalide - Outil d'analyse de fichiers binaires
+ * tbitem.h - prototypes pour la gestion des éléments réactifs spécifiques à la barre d'outils
+ *
+ * Copyright (C) 2014 Cyrille Bagard
+ *
+ * This file is part of Chrysalide.
+ *
+ * OpenIDA 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.
+ *
+ * OpenIDA 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 this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+
+
+#ifndef _GUI_TBITEM_INT_H
+#define _GUI_TBITEM_INT_H
+
+
+#include "../editem-int.h"
+
+
+
+/* Elément réactif pour barre d'outils de l'éditeur (instance) */
+struct _GToolbarItem
+{
+ GEditorItem parent; /* A laisser en premier */
+
+};
+
+
+/* Elément réactif pour barre d'outils de l'éditeur (classe) */
+struct _GToolbarItemClass
+{
+ GEditorItemClass parent; /* A laisser en premier */
+
+};
+
+
+
+/* Termine la préparation d'un élément de barre d'outils. */
+GEditorItem *g_toolbar_item_setup(GToolbarItem *, GObject *, const char *, const char *);
+
+
+
+#endif /* _GUI_TBITEM_INT_H */
diff --git a/src/gui/tb/toolbar.c b/src/gui/tb/tbitem.c
index 62eb436..c3ffcdf 100644
--- a/src/gui/tb/toolbar.c
+++ b/src/gui/tb/tbitem.c
@@ -1,6 +1,6 @@
/* Chrysalide - Outil d'analyse de fichiers binaires
- * toolbar.c - gestion des éléments réactifs spécifiques à la barre d'outils
+ * tbitem.c - gestion des éléments réactifs spécifiques à la barre d'outils
*
* Copyright (C) 2010-2012 Cyrille Bagard
*
@@ -22,32 +22,16 @@
*/
-#include "toolbar.h"
+#include "tbitem.h"
#include <gtk/gtkcontainer.h>
-#include "../editem-int.h"
+#include "tbitem-int.h"
-/* Elément réactif pour barre d'outils de l'éditeur (instance) */
-struct _GToolbarItem
-{
- GEditorItem parent; /* A laisser en premier */
-
-};
-
-
-/* Elément réactif pour barre d'outils de l'éditeur (classe) */
-struct _GToolbarItemClass
-{
- GEditorItemClass parent; /* A laisser en premier */
-
-};
-
-
/* Initialise la classe des éléments réactifs de l'éditeur. */
static void g_toolbar_item_class_init(GToolbarItemClass *);
@@ -98,12 +82,12 @@ static void g_toolbar_item_init(GToolbarItem *item)
/******************************************************************************
* *
-* Paramètres : ref = espace de référencement global. *
+* Paramètres : tbitem = élément de barre d'outils à finaliser. *
+* ref = espace de référencement global. *
* name = nom associé à l'élément. *
-* widget = composant à présenter à l'affichage. *
* label = étiquette destinée au menu. *
* *
-* Description : Crée un élément de barre d'outils réactif. *
+* Description : Termine la préparation d'un élément de barre d'outils. *
* *
* Retour : Adresse de la structure mise en place. *
* *
@@ -111,31 +95,25 @@ static void g_toolbar_item_init(GToolbarItem *item)
* *
******************************************************************************/
-GEditorItem *g_toolbar_item_new(GObject *ref, const char *name, GtkWidget *widget, const char *label)
+GEditorItem *g_toolbar_item_setup(GToolbarItem *tbitem, GObject *ref, const char *name, const char *label)
{
- GToolbarItem *result; /* Structure à retourner */
- GEditorItem *item; /* Autre version de l'élément */
+ GEditorItem *result; /* Structure à retourner */
GtkContainer *toolbar; /* Barre d'outils visée */
- result = g_object_new(G_TYPE_TOOLBAR_ITEM, NULL);
+ result = G_EDITOR_ITEM(tbitem);
/* Initialisation générique */
- item = G_EDITOR_ITEM(result);
-
g_object_ref(ref);
- item->ref = ref;
-
- item->name = name;
+ result->ref = ref;
- g_object_ref(widget);
- item->widget = widget;
+ result->name = name;
/* Intégration dans la barre */
toolbar = GTK_CONTAINER(g_object_get_data(ref, "toolbar"));
- gtk_container_add(toolbar, widget);
+ gtk_container_add(toolbar, result->widget);
- return G_EDITOR_ITEM(result);
+ return result;
}
diff --git a/src/gui/tb/toolbar.h b/src/gui/tb/tbitem.h
index cf4d5af..4f0d3a7 100644
--- a/src/gui/tb/toolbar.h
+++ b/src/gui/tb/tbitem.h
@@ -1,6 +1,6 @@
/* Chrysalide - Outil d'analyse de fichiers binaires
- * toolbar.h - prototypes pour la gestion des éléments réactifs spécifiques à la barre d'outils
+ * tbitem.h - prototypes pour la gestion des éléments réactifs spécifiques à la barre d'outils
*
* Copyright (C) 2010 Cyrille Bagard
*
@@ -22,8 +22,8 @@
*/
-#ifndef _GUI_TOOLBAR_H
-#define _GUI_TOOLBAR_H
+#ifndef _GUI_TBITEM_H
+#define _GUI_TBITEM_H
#include "../editem.h"
@@ -48,9 +48,6 @@ typedef struct _GToolbarItemClass GToolbarItemClass;
/* Indique le type défini pour un élément destiné à une barre d'outils. */
GType g_toolbar_item_get_type(void);
-/* Crée un élément de barre d'outils réactif. */
-GEditorItem *g_toolbar_item_new(GObject *, const char *, GtkWidget *, const char *);
-
-#endif /* _GUI_TOOLBAR_H */
+#endif /* _GUI_TBITEM_H */