/* OpenIDA - Outil d'analyse de fichiers binaires * gtkblockview.c - affichage d'un fragment de code d'assemblage * * Copyright (C) 2008-2012 Cyrille Bagard * * This file is part of OpenIDA. * * 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 Foobar. If not, see . */ #include "gtkblockview.h" #include "gtkbufferview-int.h" /* -------------------------- INTERACTION DIRECTE AVEC GTK -------------------------- */ /* Composant d'affichage de bloc d'assembleur (instance) */ struct _GtkBlockView { GtkBufferView parent; /* A laisser en premier */ }; /* Composant d'affichage de code d'assembleur (classe) */ struct _GtkBlockViewClass { GtkBufferViewClass parent; /* A laisser en premier */ }; /* Procède à l'initialisation des afficheurs de bloc assembleur. */ static void gtk_block_view_class_init(GtkBlockViewClass *); /* Procède à l'initialisation de l'afficheur de bloc assembleur. */ static void gtk_block_view_init(GtkBlockView *); /* Assure la gestion des clics de souris sur le composant. */ static gboolean gtk_block_view_button_press_event(GtkBlockView *, GdkEventButton *, gpointer); /* Redessine l'affichage suite à un changement visuel. */ static gboolean gtk_block_view_need_redraw(GBufferView *, GtkBlockView *); /* Prend acte de l'association d'un binaire chargé. */ static void gtk_block_view_attach_binary(GtkBlockView *, GLoadedBinary *, bool *, bool *); /* ---------------------------------------------------------------------------------- */ /* INTERACTION DIRECTE AVEC GTK */ /* ---------------------------------------------------------------------------------- */ /* Détermine le type du composant d'affichage de bloc en langage d'assemblage. */ G_DEFINE_TYPE(GtkBlockView, gtk_block_view, GTK_TYPE_BUFFER_VIEW) /****************************************************************************** * * * Paramètres : class = classe GTK à initialiser. * * * * Description : Procède à l'initialisation des afficheurs de bloc assembleur.* * * * Retour : - * * * * Remarques : - * * * ******************************************************************************/ static void gtk_block_view_class_init(GtkBlockViewClass *class) { } /****************************************************************************** * * * Paramètres : view = composant GTK à initialiser. * * * * Description : Procède à l'initialisation de l'afficheur de bloc assembleur.* * * * Retour : - * * * * Remarques : - * * * ******************************************************************************/ static void gtk_block_view_init(GtkBlockView *view) { GtkViewPanel *panel; /* Instance parente */ panel = GTK_VIEW_PANEL(view); panel->attach = (attach_binary_fc)gtk_block_view_attach_binary; g_signal_connect(G_OBJECT(view), "button_press_event", G_CALLBACK(gtk_block_view_button_press_event), NULL); } /****************************************************************************** * * * Paramètres : - * * * * Description : Crée un nouveau composant pour l'affichage de bloc en ASM. * * * * Retour : Composant GTK créé. * * * * Remarques : - * * * ******************************************************************************/ GtkWidget *gtk_block_view_new(void) { GtkBlockView *result; /* Composant à retourner */ result = g_object_new(GTK_TYPE_BLOCK_VIEW, NULL); return GTK_WIDGET(result); } /****************************************************************************** * * * Paramètres : view = composant GTK visé par l'opération. * * event = informations liées à l'événement. * * data = donnée non utilisée ici. * * * * Description : Assure la gestion des clics de souris sur le composant. * * * * Retour : FALSE pour poursuivre la propagation de l'événement. * * * * Remarques : - * * * ******************************************************************************/ static gboolean gtk_block_view_button_press_event(GtkBlockView *view, GdkEventButton *event, gpointer data) { GtkBufferView *bview; /* Autre vision du composant */ gint real_x; /* Abscisse absolue réelle */ gint real_y; /* Ordonnée absolue réelle */ if (event->type == GDK_2BUTTON_PRESS) { printf("I feel %s clicked with button %d\n", event->type == GDK_2BUTTON_PRESS ? "double" : "triple", event->button); bview = GTK_BUFFER_VIEW(view); real_x = event->x; real_y = event->y; gtk_buffer_view_compute_real_coord(bview, &real_x, &real_y); g_buffer_view_highlight_segments(gtk_buffer_view_get_buffer(bview), real_x, real_y); } return FALSE; } /****************************************************************************** * * * Paramètres : view = composant GLib interne. * * block = composant GTK d'affichage. * * * * Description : Redessine l'affichage suite à un changement visuel. * * * * Retour : FALSE pour poursuivre la propagation de l'événement. * * * * Remarques : - * * * ******************************************************************************/ static gboolean gtk_block_view_need_redraw(GBufferView *view, GtkBlockView *block) { gtk_widget_queue_draw(GTK_WIDGET(block)); return FALSE; } /****************************************************************************** * * * Paramètres : view = composant GTK à mettre à jour. * * binary = binaire associé à intégrer. * * addr = indique si les positions doivent être affichées. * * code = indique si le code binaire doit être affiché. * * * * Description : Prend acte de l'association d'un binaire chargé. * * * * Retour : - * * * * Remarques : - * * * ******************************************************************************/ static void gtk_block_view_attach_binary(GtkBlockView *view, GLoadedBinary *binary, bool *addr, bool *code) { GCodeBuffer *buffer; /* Tampon par défaut */ GBufferView *bview; /* Vue sur ce même tampon */ buffer = g_loaded_binary_get_disassembled_buffer(binary); bview = g_buffer_view_new(buffer); gtk_buffer_view_attach_buffer(GTK_BUFFER_VIEW(view), bview, addr, code); g_signal_connect(G_OBJECT(bview), "need-redraw", G_CALLBACK(gtk_block_view_need_redraw), view); }