/* Chrysalide - Outil d'analyse de fichiers binaires * editem.c - gestion des différents éléments réactifs de l'éditeurs * * Copyright (C) 2010-2013 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 */ #include "editem.h" #include "editem-int.h" /* ------------------------- ELEMENT INDIVIDUEL D'INTERFACE ------------------------- */ /* Initialise la classe des éléments réactifs de l'éditeur. */ static void g_editor_item_class_init(GEditorItemClass *); /* Initialise une instance d'élément réactif pour l'éditeur. */ static void g_editor_item_init(GEditorItem *); /* ---------------------------- MANIPULATION D'ENSEMBLES ---------------------------- */ /* liste des éléments enregistrés */ static GEditorItem *_editem_list = NULL; /* ---------------------------------------------------------------------------------- */ /* ELEMENT INDIVIDUEL D'INTERFACE */ /* ---------------------------------------------------------------------------------- */ /* Indique le type défini pour un élément réactif d'éditeur. */ G_DEFINE_TYPE(GEditorItem, g_editor_item, G_TYPE_OBJECT); /****************************************************************************** * * * Paramètres : klass = classe à initialiser. * * * * Description : Initialise la classe des éléments réactifs de l'éditeur. * * * * Retour : - * * * * Remarques : - * * * ******************************************************************************/ static void g_editor_item_class_init(GEditorItemClass *klass) { } /****************************************************************************** * * * Paramètres : item = instance à initialiser. * * * * Description : Initialise une instance d'élément réactif pour l'éditeur. * * * * Retour : - * * * * Remarques : - * * * ******************************************************************************/ static void g_editor_item_init(GEditorItem *item) { DL_LIST_ITEM_INIT(&item->link); } /****************************************************************************** * * * Paramètres : item = instance à consulter. * * * * Description : Fournit l'adresse de l'espace de référencement global. * * * * Retour : - * * * * Remarques : - * * * ******************************************************************************/ GObject *g_editor_item_get_global_ref(const GEditorItem *item) { return item->ref; } /****************************************************************************** * * * Paramètres : item = instance à consulter. * * * * Description : Fournit le composant GTK associé à l'élément réactif. * * * * Retour : - * * * * Remarques : - * * * ******************************************************************************/ GtkWidget *g_editor_item_get_widget(const GEditorItem *item) { return item->widget; } /****************************************************************************** * * * Paramètres : item = instance à consulter. * * * * Description : Fournit le gestionnaire du binaire courant. * * * * Retour : Instance en place ou NULL si aucune. * * * * Remarques : - * * * ******************************************************************************/ GLoadedBinary *g_editor_item_get_current_binary(const GEditorItem *item) { return g_object_get_data(item->ref, "current_binary"); } /****************************************************************************** * * * Paramètres : item = instance à consulter. * * * * Description : Fournit l'affichage de binaire courant. * * * * Retour : Instance en place ou NULL si aucune. * * * * Remarques : - * * * ******************************************************************************/ GtkViewPanel *g_editor_item_get_current_view(const GEditorItem *item) { return g_object_get_data(item->ref, "current_view"); } /* ---------------------------------------------------------------------------------- */ /* MANIPULATION D'ENSEMBLES */ /* ---------------------------------------------------------------------------------- */ /****************************************************************************** * * * Paramètres : - * * * * Description : Procède à l'enregistrement d'un élément reactif de l'éditeur.* * * * Retour : - * * * * Remarques : - * * * ******************************************************************************/ void register_editor_item(GEditorItem *item) { editem_list_add_tail(item, &_editem_list); } /****************************************************************************** * * * Paramètres : ref = espace de référencement global. * * binary = nouvelle instance de binaire analysé. * * * * Description : Lance une actualisation du fait d'un changement de binaire. * * * * Retour : - * * * * Remarques : - * * * ******************************************************************************/ void change_editor_items_current_binary(GObject *ref, GLoadedBinary *binary) { GEditorItem *iter; /* Boucle de parcours */ GEditorItemClass *klass; /* Classe correspondante */ g_object_set_data(ref, "current_binary", binary); editem_list_for_each(iter, _editem_list) { klass = G_EDITOR_ITEM_GET_CLASS(iter); if (klass->update_binary != NULL) klass->update_binary(iter, binary); } } /****************************************************************************** * * * Paramètres : view = nouveau panneau d'affichage nouveau. * * created = fait état d'une création ou d'une destruction. * * * * Description : Lance une actualisation liée à une modification du cheptel. * * * * Retour : - * * * * Remarques : - * * * ******************************************************************************/ void manage_editor_items_view(GtkViewPanel *view, bool created) { GEditorItem *iter; /* Boucle de parcours */ GEditorItemClass *klass; /* Classe correspondante */ editem_list_for_each(iter, _editem_list) { klass = G_EDITOR_ITEM_GET_CLASS(iter); if (klass->manage_view != NULL) klass->manage_view(iter, view, created); } } /****************************************************************************** * * * Paramètres : ref = espace de référencement global. * * view = nouveau panneau d'affichage actif. * * * * Description : Lance une actualisation du fait d'un changement de vue. * * * * Retour : - * * * * Remarques : - * * * ******************************************************************************/ void change_editor_items_current_view(GObject *ref, GtkViewPanel *view) { GEditorItem *iter; /* Boucle de parcours */ GEditorItemClass *klass; /* Classe correspondante */ g_object_set_data(ref, "current_view", view); editem_list_for_each(iter, _editem_list) { klass = G_EDITOR_ITEM_GET_CLASS(iter); if (klass->update_view != NULL) klass->update_view(iter, view); } } /****************************************************************************** * * * Paramètres : ref = espace de référencement global. * * view = nouveau panneau d'affichage actif. * * * * Description : Lance une actualisation du fait d'un changement de contenu. * * * * Retour : - * * * * Remarques : - * * * ******************************************************************************/ void change_editor_items_current_view_content(GtkViewPanel *view) { GEditorItem *iter; /* Boucle de parcours */ GEditorItemClass *klass; /* Classe correspondante */ editem_list_for_each(iter, _editem_list) { klass = G_EDITOR_ITEM_GET_CLASS(iter); if (klass->update_content != NULL) klass->update_content(iter, view); } } /****************************************************************************** * * * Paramètres : binary = binaire contenant l'adresse à représenter. * * addr = adresse mémoire à mettre en avant. * * source = composant à l'origine du changement. * * * * Description : Concentre l'attention de l'ensemble sur une adresse donnée. * * * * Retour : - * * * * Remarques : - * * * ******************************************************************************/ void focus_address_in_editor_items(GLoadedBinary *binary, const vmpa2t *addr, GEditorItem *source) { GEditorItem *iter; /* Boucle de parcours */ GEditorItemClass *klass; /* Classe correspondante */ editem_list_for_each(iter, _editem_list) { klass = G_EDITOR_ITEM_GET_CLASS(iter); if (klass->focus_addr != NULL && iter != source) klass->focus_addr(iter, binary, addr); } } /****************************************************************************** * * * Paramètres : project = projet concerné par l'évolution. * * * * Description : Lance une actualisation relative à l'étendue du projet. * * * * Retour : - * * * * Remarques : - * * * ******************************************************************************/ void update_project_area(GStudyProject *project) { GEditorItem *iter; /* Boucle de parcours */ GEditorItemClass *klass; /* Classe correspondante */ editem_list_for_each(iter, _editem_list) { klass = G_EDITOR_ITEM_GET_CLASS(iter); if (klass->update_project != NULL) klass->update_project(iter, project); } }