/* OpenIDA - Outil d'analyse de fichiers binaires
 * gtksnippet.h - prototypes pour l'affichage d'un fragment de code d'assemblage
 *
 * Copyright (C) 2008 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 .
 */
#ifndef _GTK_SNIPPET_H
#define _GTK_SNIPPET_H
#include 
#include 
#include 
#include "analysis/line.h"
#include "arch/instruction.h"
#include "arch/processor.h"
#include "format/exe_format.h"
typedef struct _code_line_info
{
    uint64_t offset;                        /* Position de l'instruction   */
    asm_instr *instr;                       /* Eventuelle instruction      */
    char *comment;                          /* Eventuel commentaire        */
    gboolean bp_set;                        /* Point d'arrêt défini        */
} code_line_info;
/* Crée une ligne de représentation insérable. */
code_line_info *create_code_line_info(uint64_t, asm_instr *, const char *);
/* Supprime une ligne de représentation. */
void delete_code_line_info(code_line_info *);
/* Etablit la comparaison entre deux lignes de représentation. */
int compare_code_line_info(const code_line_info **, const code_line_info **);
G_BEGIN_DECLS
#define GTK_SNIPPET(obj) GTK_CHECK_CAST(obj, gtk_snippet_get_type (), GtkSnippet)
#define GTK_SNIPPET_CLASS(klass) GTK_CHECK_CLASS_CAST(klass, gtk_snippet_get_type(), GtkSnippetClass)
#define GTK_IS_SNIPPET(obj) GTK_CHECK_TYPE(obj, gtk_snippet_get_type())
typedef struct _GtkSnippet GtkSnippet;
typedef struct _GtkSnippetClass GtkSnippetClass;
/* Mode d'adressage à utiliser */
typedef enum _AdressMode
{
    ADM_32BITS,                             /* Adresses sur 32 bits        */
    ADM_64BITS                              /* Adresses sur 64 bits        */
} AdressMode;
struct _GtkSnippet {
    GtkWidget widget;                       /* Présence obligatoire en 1er */
    AdressMode mode;                        /* Mode d'affichage            */
    bool show_vaddress;                     /* Affichage des adresses ?    */
    bool show_code;                         /* Affichage du code brut ?    */
    PangoLayout *layout;                    /* Moteur de rendu du code ASM */
    GdkGC *gc;                              /* Contexte graphique du rendu */
    int line_height;                        /* Hauteur maximale des lignes */
    const exe_format *format;               /* Format du contenu bianire   */
    const asm_processor *proc;              /* Architecture utilisée       */
    code_line_info *info;                   /* Contenu à représenter       */
    unsigned int info_count;                /* Quantité d'informations     */
    rendering_line *lines;                  /* Contenu à représenter       */
  gint sel;
};
struct _GtkSnippetClass {
  GtkWidgetClass parent_class;
};
GtkType gtk_snippet_get_type(void);
void gtk_snippet_set_sel(GtkSnippet *cpu, gint sel);
GtkWidget * gtk_snippet_new();
void gtk_snippet_test(GtkSnippet *cpu);
/* Choisit d'afficher les adresses virtuelles ou non. */
void gtk_snippet_show_vaddress(GtkSnippet *, gboolean);
/* Choisit d'afficher le code brut ou non. */
void gtk_snippet_show_code(GtkSnippet *, gboolean);
/* Définit le format auquel le contenu est lié. */
void gtk_snippet_set_format(GtkSnippet *, const exe_format *);
/* Définit l'architecture à laquelle le contenu est lié. */
void gtk_snippet_set_processor(GtkSnippet *, const asm_processor *);
/* Ajoute une ligne dans le bloc de représentation. */
void gtk_snippet_add_line(GtkSnippet *, const code_line_info *);
/* Définit les lignes du bloc de représentation. */
void gtk_snippet_set_rendering_lines(GtkSnippet *, rendering_line *);
/* Définit le contenu visuel à partir des infos enregistrées. */
void gtk_snippet_build_content(GtkSnippet *);
/* Indique la position verticale d'une adresse donnée. */
gboolean gtk_snippet_get_address_vposition(GtkSnippet *, uint64_t, gint *);
G_END_DECLS
#endif  /* _GTK_SNIPPET_H */