diff options
author | Cyrille Bagard <nocbos@gmail.com> | 2014-09-11 18:44:09 (GMT) |
---|---|---|
committer | Cyrille Bagard <nocbos@gmail.com> | 2014-09-11 18:44:09 (GMT) |
commit | d1dd9ae74ba56b04ad8f79d926b2282c6c7fa0fd (patch) | |
tree | f25c3914e514eb3c5959f91979ae18eaf0e35b8e /src/gui/tb/source.c | |
parent | be1f2f147e8ce15f20ec4de439088714ffa50e8a (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/tb/source.c')
-rw-r--r-- | src/gui/tb/source.c | 153 |
1 files changed, 121 insertions, 32 deletions
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 */ |