summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCyrille Bagard <nocbos@gmail.com>2009-03-03 01:03:15 (GMT)
committerCyrille Bagard <nocbos@gmail.com>2009-03-03 01:03:15 (GMT)
commitbbd04bf5f23e7dca1917247cb92824805b22a2a4 (patch)
tree548392c1c249ae5cde936f982783f192416e080c
parentc2d9948e1e67b48d1a6c8a711024d8dd3f6ac507 (diff)
Created a system messages panel.
git-svn-id: svn://svn.gna.org/svn/chrysalide/trunk@50 abbe820e-26c8-41b2-8c08-b7b2b41f8b0a
-rw-r--r--ChangeLog32
-rw-r--r--configure.ac3
-rw-r--r--src/Makefile.am3
-rw-r--r--src/editor.c5
-rw-r--r--src/format/Makefile.am2
-rw-r--r--src/format/exe_format.c6
-rwxr-xr-xsrc/format/java/Makefile.am2
-rw-r--r--src/format/java/attribute.c11
-rw-r--r--src/pan_strings.c2
-rw-r--r--src/pan_symbols.c2
-rwxr-xr-xsrc/panel/Makefile.am17
-rw-r--r--src/panel/log.c208
-rw-r--r--src/panel/log.h55
-rw-r--r--src/panel/panels.c71
-rw-r--r--src/panel/panels.h51
15 files changed, 458 insertions, 12 deletions
diff --git a/ChangeLog b/ChangeLog
index 698079e..6342c1d 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,7 +1,35 @@
+2009-03-03 Cyrille Bagard <nocbos@gmail.com>
+
+ * configure.ac:
+ Add the new Makefile from 'src/panel' directory to AC_CONFIG_FILES.
+
+ * src/editor.c:
+ Load all registered panels and display them.
+
+ * src/format/exe_format.c:
+ * src/format/java/attribute.c:
+ * src/format/java/Makefile.am:
+ * src/format/Makefile.am:
+ Use the new panel to log system messages.
+
+ * src/Makefile.am:
+ Add panel to SUBDIRS and panel/libpanel.a to openida_LDADD.
+
+ * src/panel/log.c:
+ * src/panel/log.h:
+ * src/panel/Makefile.am:
+ * src/panel/panels.c:
+ * src/panel/panels.h:
+ New entries: create a system messages panel and register it.
+
+ * src/pan_strings.c:
+ * src/pan_symbols.c:
+ Typo.
+
2009-02-18 Cyrille Bagard <nocbos@gmail.com>
* configure.ac:
- Add the new Makefile from 'src/analysis' directories to AC_CONFIG_FILES.
+ Add the new Makefile from 'src/analysis' directory to AC_CONFIG_FILES.
* src/analysis/line.c:
* src/analysis/line.h:
@@ -85,7 +113,7 @@
2009-01-29 Cyrille Bagard <nocbos@gmail.com>
* configure.ac:
- Add the new Makefile from 'src/format/pe/' directories to AC_CONFIG_FILES.
+ Add the new Makefile from 'src/format/pe/' directory to AC_CONFIG_FILES.
* src/binary.c:
Update code.
diff --git a/configure.ac b/configure.ac
index 4bda689..86334a5 100644
--- a/configure.ac
+++ b/configure.ac
@@ -191,7 +191,8 @@ AC_CONFIG_FILES([Makefile
src/format/elf/Makefile
src/format/java/Makefile
src/format/pe/Makefile
- src/gtkext/Makefile])
+ src/gtkext/Makefile
+ src/panel/Makefile])
AC_OUTPUT
diff --git a/src/Makefile.am b/src/Makefile.am
index e2519a9..948cc32 100644
--- a/src/Makefile.am
+++ b/src/Makefile.am
@@ -36,7 +36,8 @@ openida_LDADD = $(LIBINTL) \
format/java/libformatjava.a \
format/pe/libformatpe.a \
gtkext/libgtkext.a \
+ panel/libpanel.a \
common/libcommon.a
-SUBDIRS = analysis arch common format gtkext
+SUBDIRS = analysis arch common format gtkext panel
diff --git a/src/editor.c b/src/editor.c
index e59a9a5..e6d7516 100644
--- a/src/editor.c
+++ b/src/editor.c
@@ -57,6 +57,7 @@
#include "pan_strings.h"
#include "pan_symbols.h"
#include "gtkext/gtkdockpanel.h"
+#include "panel/panels.h"
#define _(str) str
@@ -592,6 +593,7 @@ GtkWidget *create_editor(void)
gtk_paned_set_position (GTK_PANED (hpaned1), 600);
+ init_panels();
dpanel = gtk_dock_panel_new();
@@ -849,6 +851,9 @@ GtkWidget *create_editor(void)
gtk_paned_pack2(GTK_PANED(vpaned1), dpanel, FALSE, FALSE);
+ ditem = gtk_dock_item_new(_("Messages"), get_panel(PNT_LOG));
+ gtk_dock_panel_add_item(dpanel, ditem);
+
panel = build_strings_panel(G_OBJECT(result));
ditem = gtk_dock_item_new(_("Strings"), panel);
diff --git a/src/format/Makefile.am b/src/format/Makefile.am
index 67b3737..7c2c524 100644
--- a/src/format/Makefile.am
+++ b/src/format/Makefile.am
@@ -10,7 +10,7 @@ libformat_a_SOURCES = \
libformat_a_CFLAGS = $(AM_CFLAGS)
-INCLUDES =
+INCLUDES = $(LIBGTK_CFLAGS)
AM_CPPFLAGS =
diff --git a/src/format/exe_format.c b/src/format/exe_format.c
index 1077cfe..8a03243 100644
--- a/src/format/exe_format.c
+++ b/src/format/exe_format.c
@@ -29,9 +29,13 @@
#include "exe_format-int.h"
+#include "../panel/log.h"
+#define _(str) str
+
+
/* ------------------------ DETECTION DE FORMATS EXECUTABLES ------------------------ */
@@ -239,7 +243,7 @@ exe_format *load_new_exe_format(const uint8_t *content, off_t length)
for (i = 0; i < exe_formats_count && result == NULL; i++)
if (exe_formats[i].match(content, length))
{
- printf("<LOGINFO> %s is matching...\n", exe_formats[i].name);
+ log_variadic_message(LMT_INFO, _("%s is matching..."), exe_formats[i].name);
result = exe_formats[i].load(content, length);
diff --git a/src/format/java/Makefile.am b/src/format/java/Makefile.am
index e3a88b2..2cb2326 100755
--- a/src/format/java/Makefile.am
+++ b/src/format/java/Makefile.am
@@ -12,7 +12,7 @@ libformatjava_a_SOURCES = \
libformatjava_a_CFLAGS = $(AM_CFLAGS)
-INCLUDES =
+INCLUDES = $(LIBGTK_CFLAGS)
AM_CPPFLAGS =
diff --git a/src/format/java/attribute.c b/src/format/java/attribute.c
index f5947dd..0cfed92 100644
--- a/src/format/java/attribute.c
+++ b/src/format/java/attribute.c
@@ -31,6 +31,11 @@
#include "java-int.h"
#include "pool.h"
#include "../../common/endianness.h"
+#include "../../panel/log.h"
+
+
+
+#define _(str) str
@@ -231,12 +236,12 @@ bool load_java_attribute(java_format *format, java_attribute *attrib, off_t *pos
else if (result)
{
result = false;
- printf("<OIDAIMPL> Nom d'attribut non supporté : '%s'\n", name);
+ log_variadic_message(LMT_BAD_BINARY, _("Attribute name not supported: '%s'"), name);
}
if (result && attrib_length != (*pos - saved_pos))
- printf("<BADBIN> indication de la taille de l'attribut '%s' non vérifiée : %d vs %d\n",
- name, attrib_length, *pos - saved_pos);
+ log_variadic_message(LMT_BAD_BINARY, _("Size indication of the attribute '%s' not verified: %d vs %d"),
+ name, attrib_length, *pos - saved_pos);
}
diff --git a/src/pan_strings.c b/src/pan_strings.c
index 0b5a951..984d0d2 100644
--- a/src/pan_strings.c
+++ b/src/pan_strings.c
@@ -53,7 +53,7 @@ typedef enum _StringsColumn
GtkWidget *build_strings_panel(GObject *ref)
{
- GtkWidget *result; /* Pnneau à retourner */
+ GtkWidget *result; /* Panneau à retourner */
GtkTreeStore *store; /* Modèle de gestion */
GtkWidget *treeview; /* Affichage de la liste */
GtkCellRenderer *renderer; /* Moteur de rendu de colonne */
diff --git a/src/pan_symbols.c b/src/pan_symbols.c
index adc8056..a78bc44 100644
--- a/src/pan_symbols.c
+++ b/src/pan_symbols.c
@@ -64,7 +64,7 @@ void change_symbols_selection(GtkTreeSelection *, gpointer);
GtkWidget *build_symbols_panel(GObject *ref)
{
- GtkWidget *result; /* Pnneau à retourner */
+ GtkWidget *result; /* Panneau à retourner */
GtkTreeStore *store; /* Modèle de gestion */
GtkWidget *treeview; /* Affichage de la liste */
GtkCellRenderer *renderer; /* Moteur de rendu de colonne */
diff --git a/src/panel/Makefile.am b/src/panel/Makefile.am
new file mode 100755
index 0000000..cf70076
--- /dev/null
+++ b/src/panel/Makefile.am
@@ -0,0 +1,17 @@
+
+lib_LIBRARIES = libpanel.a
+
+libpanel_a_SOURCES = \
+ log.h log.c \
+ panels.h panels.c
+
+libpanel_a_CFLAGS = $(AM_CFLAGS)
+
+
+INCLUDES = $(LIBGTK_CFLAGS)
+
+AM_CPPFLAGS =
+
+AM_CFLAGS = $(DEBUG_CFLAGS) $(WARNING_FLAGS)
+
+SUBDIRS =
diff --git a/src/panel/log.c b/src/panel/log.c
new file mode 100644
index 0000000..f98953f
--- /dev/null
+++ b/src/panel/log.c
@@ -0,0 +1,208 @@
+
+/* OpenIDA - Outil d'analyse de fichiers binaires
+ * log.c - panneau d'affichage des messages système
+ *
+ * Copyright (C) 2006-2007 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 this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+
+
+#include "log.h"
+
+
+#include <malloc.h>
+#include <stdarg.h>
+#include <stdio.h>
+
+
+#include "panels.h"
+
+
+
+/* Colonnes de la liste des messages */
+typedef enum _LogColumn
+{
+ LGC_PICTURE, /* Image de représentation */
+ LGC_STRING, /* Chaîne de caractères */
+
+ LGC_COUNT /* Nombre de colonnes */
+
+} LogColumn;
+
+
+#define _(str) str
+
+
+/******************************************************************************
+* *
+* Paramètres : - *
+* *
+* Description : Construit le panneau d'affichage des messages système. *
+* *
+* Retour : Adresse du panneau mis en place. *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+GtkWidget *build_log_panel(void)
+{
+ GtkWidget *result; /* Panneau à retourner */
+ GtkTreeStore *store; /* Modèle de gestion */
+ GtkWidget *treeview; /* Affichage de la liste */
+ GtkCellRenderer *renderer; /* Moteur de rendu de colonne */
+ GtkTreeViewColumn *column; /* Colonne de la liste */
+ GtkTreeSelection *select; /* Sélection dans la liste */
+
+ result = gtk_scrolled_window_new(NULL, NULL);
+ gtk_widget_show(result);
+
+ gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(result), GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
+ gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(result), GTK_SHADOW_IN);
+
+ store = gtk_tree_store_new(LGC_COUNT, G_TYPE_STRING, G_TYPE_STRING);
+ g_object_set_data(G_OBJECT(result), "store", store);
+
+ treeview = gtk_tree_view_new_with_model(GTK_TREE_MODEL(store));
+ gtk_tree_view_set_headers_visible(GTK_TREE_VIEW(treeview), FALSE);
+ gtk_widget_show(treeview);
+ gtk_container_add(GTK_CONTAINER(result), treeview);
+
+ g_object_unref(G_OBJECT(store));
+
+ column = gtk_tree_view_column_new();
+ gtk_tree_view_column_set_visible(column, FALSE);
+ gtk_tree_view_append_column(GTK_TREE_VIEW(treeview), column);
+ gtk_tree_view_set_expander_column(GTK_TREE_VIEW(treeview), column);
+
+ column = gtk_tree_view_column_new();
+
+ renderer = gtk_cell_renderer_pixbuf_new();
+ gtk_tree_view_column_pack_start(column, renderer, FALSE);
+ gtk_tree_view_column_add_attribute(column, renderer, "stock-id", LGC_PICTURE);
+
+ renderer = gtk_cell_renderer_text_new();
+ gtk_tree_view_column_pack_start(column, renderer, TRUE);
+ gtk_tree_view_column_add_attribute(column, renderer, "text", LGC_STRING);
+
+ gtk_tree_view_append_column(GTK_TREE_VIEW(treeview), column);
+
+ return result;
+
+}
+
+
+/******************************************************************************
+* *
+* Paramètres : panel = panneau à mettre à jour. *
+* msg = message à faire apparaître à l'écran. *
+* *
+* Description : Affiche un message dans le journal des messages système. *
+* *
+* Retour : - *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+void log_simple_message(LogMessageType type, const char *msg)
+{
+ GtkWidget *panel; /* Panneau à traiter */
+ GtkTreeStore *store; /* Modèle de gestion */
+ GtkTreeIter iter; /* Point d'insertion */
+
+ panel = get_panel(PNT_LOG);
+ store = g_object_get_data(G_OBJECT(panel), "store");
+
+ gtk_tree_store_append(store, &iter, NULL);
+
+ switch (type)
+ {
+ case LMT_INFO:
+ gtk_tree_store_set(store, &iter,
+ LGC_PICTURE, "gtk-info",
+ LGC_STRING, msg,
+ -1);
+ break;
+
+ case LMT_BAD_BINARY:
+ gtk_tree_store_set(store, &iter,
+ LGC_PICTURE, "gtk-dialog-warning",
+ LGC_STRING, msg,
+ -1);
+ break;
+
+ }
+
+}
+
+
+/******************************************************************************
+* *
+* Paramètres : panel = panneau à mettre à jour. *
+* fmt = format du message à faire apparaître à l'écran. *
+* ... = éventuels arguments venant compléter le message. *
+* *
+* Description : Affiche un message dans le journal des messages système. *
+* *
+* Retour : - *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+void log_variadic_message(LogMessageType type, const char *fmt, ...)
+{
+ size_t len; /* Taille tampon disponible */
+ char *buffer; /* Tampon du msg reconstitué */
+ int ret; /* Bilan d'une impression */
+ char *ptr; /* Nouvelle allocation */
+ va_list ap; /* Liste d'arguments variable */
+
+ len = 100;
+ buffer = calloc(len, sizeof(char));
+
+ while (buffer != NULL)
+ {
+ va_start(ap, fmt);
+ ret = vsnprintf(buffer, len, fmt, ap);
+ va_end(ap);
+
+ if (ret >= 0 && ret < len) break;
+
+ else
+ {
+ if (ret > -1) len += 1; /* glibc 2.1 */
+ else len *= 2; /* glibc 2.0 */
+
+ if ((ptr = realloc(buffer, len)) == NULL)
+ {
+ free(buffer);
+ buffer = NULL;
+ }
+ else buffer = ptr;
+
+ }
+
+ }
+
+ log_simple_message(type, buffer);
+
+ free(buffer);
+
+}
diff --git a/src/panel/log.h b/src/panel/log.h
new file mode 100644
index 0000000..91e2c83
--- /dev/null
+++ b/src/panel/log.h
@@ -0,0 +1,55 @@
+
+/* OpenIDA - Outil d'analyse de fichiers binaires
+ * log.h - prototypes pour le panneau d'affichage des messages système
+ *
+ * Copyright (C) 2006-2007 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 this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+
+
+#ifndef _PANEL_LOG_H
+#define _PANEL_LOG_H
+
+
+#include <gtk/gtk.h>
+
+
+
+/* Type de messages disponibles */
+typedef enum _LogMessageType
+{
+ LMT_INFO, /* Information sur l'exécution */
+ LMT_BAD_BINARY, /* Binaire malformé */
+
+ LMT_COUNT
+
+} LogMessageType;
+
+
+/* Construit le panneau d'affichage des messages système. */
+GtkWidget *build_log_panel(void);
+
+/* Affiche un message dans le journal des messages système. */
+void log_simple_message(LogMessageType, const char *);
+
+/* Affiche un message dans le journal des messages système. */
+void log_variadic_message(LogMessageType, const char *, ...);
+
+
+
+#endif /* _PANEL_LOG_H */
diff --git a/src/panel/panels.c b/src/panel/panels.c
new file mode 100644
index 0000000..a127825
--- /dev/null
+++ b/src/panel/panels.c
@@ -0,0 +1,71 @@
+
+/* OpenIDA - Outil d'analyse de fichiers binaires
+ * panels.h - gestion des différents panneaux
+ *
+ * Copyright (C) 2006-2007 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 this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+
+
+#include "panels.h"
+
+
+#include "log.h"
+
+
+
+static GtkWidget *panel_list[PNT_COUNT];
+
+
+
+/******************************************************************************
+* *
+* Paramètres : - *
+* *
+* Description : Procède au chargement de tous les panneaux. *
+* *
+* Retour : - *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+void init_panels(void)
+{
+ panel_list[PNT_LOG] = build_log_panel();
+
+}
+
+
+/******************************************************************************
+* *
+* Paramètres : id = identifiant du panneau visé. *
+* *
+* Description : Fournit la référence d'un panneau donné. *
+* *
+* Retour : Adresse du composant GTK en place. *
+* *
+* Remarques : - *
+* *
+******************************************************************************/
+
+GtkWidget *get_panel(PanelType id)
+{
+ return panel_list[id];
+
+}
diff --git a/src/panel/panels.h b/src/panel/panels.h
new file mode 100644
index 0000000..87ddfa6
--- /dev/null
+++ b/src/panel/panels.h
@@ -0,0 +1,51 @@
+
+/* OpenIDA - Outil d'analyse de fichiers binaires
+ * panels.h - prototypes pour la gestion des différents panneaux
+ *
+ * Copyright (C) 2006-2007 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 this program; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
+
+
+#ifndef _PANEL_PANELS_H
+#define _PANEL_PANELS_H
+
+
+#include <gtk/gtk.h>
+
+
+
+/* Liste de tous les panneaux */
+typedef enum _PanelType
+{
+ PNT_LOG, /* Messages système */
+
+ PNT_COUNT
+
+} PanelType;
+
+
+/* Procède au chargement de tous les panneaux. */
+void init_panels(void);
+
+/* Fournit la référence d'un panneau donné. */
+GtkWidget *get_panel(PanelType);
+
+
+
+#endif /* _PANEL_PANELS_H */