summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/gui/dialogs/Makefile.am1
-rw-r--r--src/gui/dialogs/shellcode.c805
-rw-r--r--src/gui/dialogs/shellcode.h37
-rw-r--r--src/gui/menus/project.c88
4 files changed, 0 insertions, 931 deletions
diff --git a/src/gui/dialogs/Makefile.am b/src/gui/dialogs/Makefile.am
index 792f1db..77b97ac 100644
--- a/src/gui/dialogs/Makefile.am
+++ b/src/gui/dialogs/Makefile.am
@@ -16,7 +16,6 @@ libguidialogs_la_SOURCES = \
identity.h identity.c \
plugins.h plugins.c \
resources.h resources.c \
- shellcode.h shellcode.c \
storage.h storage.c
libguidialogs_la_LDFLAGS =
diff --git a/src/gui/dialogs/shellcode.c b/src/gui/dialogs/shellcode.c
deleted file mode 100644
index f4b0892..0000000
--- a/src/gui/dialogs/shellcode.c
+++ /dev/null
@@ -1,805 +0,0 @@
-
-/* Chrysalide - Outil d'analyse de fichiers binaires
- * export.c - assistant d'exportation de contenu binaire
- *
- * Copyright (C) 2015-2017 Cyrille Bagard
- *
- * This file is part of Chrysalide.
- *
- * Chrysalide 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.
- *
- * Chrysalide 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 Chrysalide. If not, see <http://www.gnu.org/licenses/>.
- */
-
-
-#include "shellcode.h"
-
-
-#include <i18n.h>
-
-
-#include <malloc.h>
-#include <regex.h>
-#include <stdio.h>
-#include <string.h>
-
-
-#include "../../gtkext/easygtk.h"
-
-
-
-
-#include "../../analysis/roptions.h" // A garder ?
-
-
-
-
-
-
-/* ------------------------ PARTIE PRINCIPALE DE L'ASSISTANT ------------------------ */
-
-
-/* Ferme l'assistant sans dérouler la procédure. */
-static void export_assistant_cancel(GtkAssistant *, gpointer);
-
-/* Ferme l'assistant et déroule la procédure. */
-static void export_assistant_close(GtkAssistant *, GObject *);
-
-
-
-/* -------------------------- RECUPERATION DU CODE BINAIRE -------------------------- */
-
-
-/* Ajoute le panneau de consitution du code binaire. */
-static void register_bincode_panel(GtkAssistant *);
-
-/* Fournit si possible le code binaire utilisateur. */
-static bool extract_shell_code(GObject *, bin_t **, off_t *);
-
-/* Réagit à une modification du code binaire. */
-static void on_bincode_changed(GtkTextBuffer *, GObject *);
-
-
-
-/* ----------------------- DEFINITION DE L'ARCHITECTURE VISEE ----------------------- */
-
-
-/* Ajoute le panneau de spécification de l'architecture. */
-static void register_archi_panel(GtkAssistant *);
-
-
-
-
-
-/* -------------------- DEFINITION DES REGLAGES DE L'EXPORTATION -------------------- */
-
-
-/* Ajoute le panneau de choix du type de sortie. */
-static void register_output_panel(GtkAssistant *);
-
-/* Réagit un changement du nom de fichier pour l'exportation. */
-static void on_export_filename_changed(GtkEntry *, GtkAssistant *);
-
-/* Sélectionne ou non un nouveau fichier de sortie. */
-static void on_filename_browsing_clicked(GtkButton *, GObject *);
-
-
-
-/* ------------------------- SELECTION DU CONTENU A TRAITER ------------------------- */
-
-
-/* Ajoute le panneau de sélection du contenu à exporter. */
-static void register_content_panel(GtkAssistant *);
-
-
-
-/* ---------------------------------------------------------------------------------- */
-/* PARTIE PRINCIPALE DE L'ASSISTANT */
-/* ---------------------------------------------------------------------------------- */
-
-
-/******************************************************************************
-* *
-* Paramètres : project = projet courant à compléter. *
-* parent = fenêtre principale de l'éditeur. *
-* *
-* Description : Crée et affiche un assistant d'ajout de binaire. *
-* *
-* Retour : - *
-* *
-* Remarques : - *
-* *
-******************************************************************************/
-
-void run_shellcode_assistant(GStudyProject *project, GtkWindow *parent)
-{
- GtkWidget *assistant; /* Fenêtre à afficher */
- GObject *ref; /* Espace de référencement */
-
- assistant = gtk_assistant_new();
- gtk_window_set_title(GTK_WINDOW(assistant), _("Shellcode assistant"));
- gtk_widget_set_size_request(assistant, 450, 300);
- gtk_window_set_position(GTK_WINDOW(assistant), GTK_WIN_POS_CENTER);
-
- gtk_window_set_modal(GTK_WINDOW(assistant), TRUE);
- gtk_window_set_transient_for(GTK_WINDOW(assistant), parent);
-
- ref = G_OBJECT(assistant);
- //g_object_set_data(ref, "binary", binary);
-
- register_bincode_panel(GTK_ASSISTANT(assistant));
- register_archi_panel(GTK_ASSISTANT(assistant));
- //register_output_panel(GTK_ASSISTANT(assistant));
- //register_content_panel(GTK_ASSISTANT(assistant));
-
- g_signal_connect(G_OBJECT(assistant), "cancel", G_CALLBACK(export_assistant_cancel), NULL);
- g_signal_connect(G_OBJECT(assistant), "close", G_CALLBACK(export_assistant_close), ref);
-
- gtk_widget_show_all(assistant);
-
-}
-
-
-/******************************************************************************
-* *
-* Paramètres : assistant = fenêtre à compléter et référencement global. *
-* data = adresse non utilisée ici. *
-* *
-* Description : Ferme l'assistant sans dérouler la procédure. *
-* *
-* Retour : - *
-* *
-* Remarques : - *
-* *
-******************************************************************************/
-
-static void export_assistant_cancel(GtkAssistant *assistant, gpointer data)
-{
- gtk_widget_destroy(GTK_WIDGET(assistant));
-
-}
-
-
-/******************************************************************************
-* *
-* Paramètres : assistant = fenêtre à compléter et référencement global. *
-* ref = adresse de l'espace de référencement global. *
-* *
-* Description : Ferme l'assistant et déroule la procédure. *
-* *
-* Retour : - *
-* *
-* Remarques : - *
-* *
-******************************************************************************/
-
-static void export_assistant_close(GtkAssistant *assistant, GObject *ref)
-{
- GLoadedBinary *binary; /* Binaire chargé à parcourir */
- GExeFormat *format; /* Format du binaire */
- GRenderingOptions *options; /* Options d'exportation */
- GtkToggleButton *checkbutton; /* Coche à retrouver */
- gboolean state; /* Valeur à prendre en compte */
- GtkEntry *entry; /* Zone de saisie */
- const gchar *filename; /* Chemin d'accès du fichier */
-
- binary = NULL;//G_LOADED_BINARY(g_object_get_data(ref, "binary"));
-
- format = g_loaded_binary_get_format(binary);
- options = g_rendering_options_new(format);
-
- /* Eléments à afficher */
-
- checkbutton = GTK_TOGGLE_BUTTON(g_object_get_data(ref, "virtual_addr"));
- state = gtk_toggle_button_get_active(checkbutton);
- g_rendering_options_show_address(options, MRD_BLOCK, state);
-
- checkbutton = GTK_TOGGLE_BUTTON(g_object_get_data(ref, "binary_code"));
- state = gtk_toggle_button_get_active(checkbutton);
- g_rendering_options_show_code(options, MRD_BLOCK, state);
-
- checkbutton = GTK_TOGGLE_BUTTON(g_object_get_data(ref, "assembly_code"));
- state = gtk_toggle_button_get_active(checkbutton);
-
- /* Programmation de la tâche */
- /*
- entry = GTK_ENTRY(g_object_get_data(ref, "filename"));
- filename = gtk_entry_get_text(entry);
-
- export = g_delayed_export_new(filename, binary, options);
-
- queue = get_work_queue();
- g_work_queue_schedule_work(queue, G_DELAYED_WORK(export));
- */
- gtk_widget_destroy(GTK_WIDGET(assistant));
-
- g_object_unref(G_OBJECT(format));
-
-}
-
-
-
-/* ---------------------------------------------------------------------------------- */
-/* RECUPERATION DU CODE BINAIRE */
-/* ---------------------------------------------------------------------------------- */
-
-
-/******************************************************************************
-* *
-* Paramètres : assistant = fenêtre à compléter et référencement global. *
-* *
-* Description : Ajoute le panneau de consitution du code binaire. *
-* *
-* Retour : - *
-* *
-* Remarques : - *
-* *
-******************************************************************************/
-
-static void register_bincode_panel(GtkAssistant *assistant)
-{
- GtkWidget *vbox; /* Support principal */
- GtkWidget *scrolledwindow; /* Support avec défilement */
- GtkWidget *textview; /* Zone de texte */
- GtkWidget *label; /* Etiquette du bilan */
-
- vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 8);
- qck_set_margins(vbox, 8, 8, 8, 8);
- gtk_widget_show(vbox);
-
- /* Réception du code */
-
- label = qck_create_label(NULL, NULL, _("Paste here the raw C code containing the shellcode.\r\n"
- "All content between quotes will be extracted."));
- gtk_box_pack_start(GTK_BOX(vbox), label, FALSE, FALSE, 0);
-
- scrolledwindow = gtk_scrolled_window_new(NULL, NULL);
- gtk_widget_show(scrolledwindow);
- gtk_box_pack_start(GTK_BOX(vbox), scrolledwindow, TRUE, TRUE, 0);
- gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolledwindow),
- GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
- gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(scrolledwindow), GTK_SHADOW_IN);
-
- textview = qck_create_textview(G_OBJECT(assistant), "bincode",
- G_CALLBACK(on_bincode_changed), assistant);
- gtk_container_add(GTK_CONTAINER(scrolledwindow), textview);
-
- /* Validation */
-
- label = qck_create_label(G_OBJECT(assistant), "status", _("No code"));
- gtk_widget_set_halign(label, GTK_ALIGN_CENTER);
- gtk_box_pack_start(GTK_BOX(vbox), label, FALSE, FALSE, 0);
-
- /* Intégration */
-
- gtk_assistant_append_page(assistant, vbox);
- gtk_assistant_set_page_title(assistant, vbox, _("Code"));
- gtk_assistant_set_page_type(assistant, vbox, GTK_ASSISTANT_PAGE_INTRO);
-
- gtk_assistant_set_page_complete(assistant, vbox, TRUE);
-
-}
-
-
-/******************************************************************************
-* *
-* Paramètres : ref = espace de référencement global. *
-* code = code binaire recomposé. [OUT] *
-* length = taille de ce code. [OUT] *
-* *
-* Description : Fournit si possible le code binaire utilisateur. *
-* *
-* Retour : Bilan de l'opération. *
-* *
-* Remarques : - *
-* *
-******************************************************************************/
-
-static bool extract_shell_code(GObject *ref, bin_t **code, off_t *length)
-{
- bool result; /* Bilan à retourner */
- GtkTextView *textview; /* Zone de texte */
- GtkTextBuffer *buffer; /* Tampon gérant le texte */
- GtkTextIter start; /* Début de la zone à traiter */
- GtkTextIter end; /* Fin de la zone à traiter */
- gchar *bincode; /* Code à filtrer */
- regex_t preg; /* Recherche d'un bloc */
- int ret; /* Bilan d'un appel */
- regoff_t pos; /* Point de départ de lecture */
- regmatch_t pmatch[3]; /* Localisation de trouvailles */
- regoff_t i; /* Boucle de parcours */
- char hex[3]; /* Valeur hexadécimale */
-
- result = true;
-
- *code = NULL;
- *length = 0;
-
- /* Détermination des cibles */
-
- ret = regcomp(&preg, "[^'\"]*(['\"])([^'\"]*)\\1", REG_EXTENDED);
- if (ret != 0) return false;
-
- /* Constitution du contexte */
-
- textview = GTK_TEXT_VIEW(g_object_get_data(ref, "bincode"));
- buffer = gtk_text_view_get_buffer(textview);
-
- gtk_text_buffer_get_bounds(buffer, &start, &end);
- bincode = gtk_text_buffer_get_text(buffer, &start, &end, FALSE);
-
- /* Recomposition du code */
-
- pos = 0;
-
- ret = regexec(&preg, &bincode[pos], 3, pmatch, 0);
-
- while (ret != REG_NOMATCH && result)
- {
- bincode[pos + pmatch[2].rm_eo] = '\0';
-
- for (i = pos + pmatch[2].rm_so; i < (pos + pmatch[2].rm_eo) && result; i++)
- {
- *code = (bin_t *)realloc(*code, ++(*length) * sizeof(bin_t));
-
- switch (bincode[i])
- {
- case '\\':
- if (++i >= (pos + pmatch[2].rm_eo))
- {
- result = false;
- break;
- }
-
- if (bincode[i] == 'x')
- {
- if (++i >= (pos + pmatch[2].rm_eo))
- {
- result = false;
- break;
- }
-
- if ((i + 2) > (pos + pmatch[2].rm_eo))
- {
- result = false;
- break;
- }
-
- memcpy(hex, &bincode[i], 2);
- hex[2] = '\0';
-
- (*code)[*length - 1] = strtol(hex, NULL, 16);
-
- i++;
-
- }
- else (*code)[*length - 1] = bincode[i];
-
- break;
-
- default:
- (*code)[*length - 1] = bincode[i];
- break;
-
- }
-
- }
-
- if (result)
- {
- pos += pmatch[2].rm_eo + 1;
- ret = regexec(&preg, &bincode[pos], 3, pmatch, 0);
- }
-
- }
-
- g_free(bincode);
-
- if (!result && *code != NULL)
- {
- *length = 0;
- free(*code);
- }
-
- return result;
-
-}
-
-
-/******************************************************************************
-* *
-* Paramètres : textbuffer = composant concerné par l'action. *
-* ref = espace de référencement global. *
-* *
-* Description : Réagit à une modification du code binaire. *
-* *
-* Retour : - *
-* *
-* Remarques : - *
-* *
-******************************************************************************/
-
-static void on_bincode_changed(GtkTextBuffer *textbuffer, GObject *ref)
-{
- bin_t *code; /* Code binaire extrait */
- off_t length; /* Taille des données lues */
- bool status; /* Bilan de l'extraction */
- GtkLabel *label; /* Etiquette à mettre à jour */
- char *markup; /* Affichage étendu */
- GtkAssistant *assistant; /* Assistant en première ligne */
- gint index; /* Indice de la page courante */
- GtkWidget *page; /* Cotenu de la page courante */
-
- status = extract_shell_code(ref, &code, &length);
-
- label = GTK_LABEL(g_object_get_data(ref, "status"));
-
- if (!status)
- gtk_label_set_markup(label, _("<span color=\"red\"><b>Error while decoding</b></span>"));
-
- else if (length > 0)
- {
- markup = g_markup_printf_escaped(_("<span color=\"#00cc00\"><b>Decoding OK ("
- OFF_FMT " %s)</b></span>"),
- OFF_CAST(length), length > 1 ? _("bytes") : _("byte"));
- gtk_label_set_markup(label, markup);
- g_free(markup);
- }
-
- else
- {
- gtk_label_set_markup(label, _("No code"));
- status = false;
- }
-
- if (length > 0)
- free(code);
-
- /* Poursuite des opérations ? */
-
- assistant = GTK_ASSISTANT(ref);
-
- index = gtk_assistant_get_current_page(assistant);
- page = gtk_assistant_get_nth_page(assistant, index);
-
- gtk_assistant_set_page_complete(assistant, page, status);
-
-}
-
-
-
-/* ---------------------------------------------------------------------------------- */
-/* DEFINITION DE L'ARCHITECTURE VISEE */
-/* ---------------------------------------------------------------------------------- */
-
-
-/******************************************************************************
-* *
-* Paramètres : assistant = fenêtre à compléter et référencement global. *
-* *
-* Description : Ajoute le panneau de spécification de l'architecture. *
-* *
-* Retour : - *
-* *
-* Remarques : - *
-* *
-******************************************************************************/
-
-static void register_archi_panel(GtkAssistant *assistant)
-{
- GtkWidget *vbox; /* Support principal */
- GtkWidget *label; /* Etiquette d'indication */
- GtkWidget *combobox; /* Sélection du format */
-
- vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 8);
- qck_set_margins(vbox, 8, 8, 8, 8);
- gtk_widget_show(vbox);
-
- /* Choix de l'architecture */
-
- label = qck_create_label(NULL, NULL, _("Architecture:"));
- gtk_box_pack_start(GTK_BOX(vbox), label, FALSE, FALSE, 0);
-
- combobox = qck_create_combobox(G_OBJECT(assistant), "archi", G_CALLBACK(NULL), NULL);
- gtk_box_pack_start(GTK_BOX(vbox), combobox, TRUE, FALSE, 0);
-
- gtk_combo_box_text_append_text(GTK_COMBO_BOX_TEXT(combobox), _("x86"));
-
- gtk_combo_box_set_active(GTK_COMBO_BOX(combobox), 0);
-
- /* Taille de registre */
-
- label = qck_create_label(NULL, NULL, _("Register size:"));
- gtk_box_pack_start(GTK_BOX(vbox), label, FALSE, FALSE, 0);
-
- combobox = qck_create_combobox(G_OBJECT(assistant), "rsize", G_CALLBACK(NULL), NULL);
- gtk_box_pack_start(GTK_BOX(vbox), combobox, TRUE, FALSE, 0);
-
- gtk_combo_box_text_append_text(GTK_COMBO_BOX_TEXT(combobox), _("32 bits"));
- gtk_combo_box_text_append_text(GTK_COMBO_BOX_TEXT(combobox), _("16 bits"));
-
- gtk_combo_box_set_active(GTK_COMBO_BOX(combobox), 0);
-
- /* Intégration */
-
- gtk_assistant_append_page(assistant, vbox);
- gtk_assistant_set_page_title(assistant, vbox, _("Architecture"));
- gtk_assistant_set_page_type(assistant, vbox, GTK_ASSISTANT_PAGE_CONFIRM);
-
- gtk_assistant_set_page_complete(assistant, vbox, TRUE);
-
-}
-
-
-
-
-
-
-
-
-
-
-/* ---------------------------------------------------------------------------------- */
-/* DEFINITION DES REGLAGES DE L'EXPORTATION */
-/* ---------------------------------------------------------------------------------- */
-
-
-/******************************************************************************
-* *
-* Paramètres : assistant = fenêtre à compléter et référencement global. *
-* *
-* Description : Ajoute le panneau de choix du type de sortie. *
-* *
-* Retour : - *
-* *
-* Remarques : - *
-* *
-******************************************************************************/
-
-static void register_output_panel(GtkAssistant *assistant)
-{
- GtkWidget *vbox; /* Support principal #1 */
- GtkWidget *hbox; /* Support principal #2 */
- GtkWidget *label; /* Etiquette d'indication */
- GtkWidget *combobox; /* Sélection du format */
- GtkWidget *entry; /* Zone de saisie de texte */
- GtkWidget *button; /* Sélection de fichier */
- GLoadedBinary *binary; /* Binaire chargé à parcourir */
- const char *filename; /* Chemin d'accès par défaut */
-
- vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 8);
- qck_set_margins(vbox, 8, 8, 8, 8);
- gtk_widget_show(vbox);
-
- /* Format de sortie */
-
- hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 8);
- gtk_widget_show(hbox);
- gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, FALSE, 0);
-
- label = qck_create_label(NULL, NULL, _("Format : "));
- gtk_box_pack_start(GTK_BOX(hbox), label, FALSE, FALSE, 0);
-
- combobox = qck_create_combobox(NULL, NULL, G_CALLBACK(NULL), NULL);
- gtk_box_pack_start(GTK_BOX(hbox), combobox, TRUE, TRUE, 0);
-
- gtk_combo_box_text_append_text(GTK_COMBO_BOX_TEXT(combobox), _("Simple text"));
-
- gtk_combo_box_set_active(GTK_COMBO_BOX(combobox), 0);
-
- /* Fichier de sortie */
-
- hbox = gtk_box_new(GTK_ORIENTATION_HORIZONTAL, 8);
- gtk_widget_show(hbox);
- gtk_box_pack_start(GTK_BOX(vbox), hbox, FALSE, FALSE, 0);
-
- label = qck_create_label(NULL, NULL, _("File : "));
- gtk_box_pack_start(GTK_BOX(hbox), label, FALSE, FALSE, 0);
-
- entry = qck_create_entry(G_OBJECT(assistant), "filename", NULL);
- gtk_box_pack_start(GTK_BOX(hbox), entry, TRUE, TRUE, 0);
-
- button = qck_create_button(NULL, NULL, "...", G_CALLBACK(on_filename_browsing_clicked), assistant);
- gtk_box_pack_start(GTK_BOX(hbox), button, FALSE, FALSE, 0);
-
- /* Intégration */
-
- gtk_assistant_append_page(assistant, vbox);
- gtk_assistant_set_page_title(assistant, vbox, _("Output"));
- gtk_assistant_set_page_type(assistant, vbox, GTK_ASSISTANT_PAGE_CONTENT);
-
- gtk_assistant_set_page_complete(assistant, vbox, TRUE);
-
- /* Choix par défaut */
- /*
- binary = G_LOADED_BINARY(g_object_get_data(G_OBJECT(assistant), "binary"));
- filename = g_loaded_binary_get_name(binary);
-
- gtk_entry_set_text(GTK_ENTRY(entry), filename);
- gtk_entry_append_text(GTK_ENTRY(entry), ".txt");
-
- g_signal_connect(G_OBJECT(entry), "changed", G_CALLBACK(on_export_filename_changed), assistant);
- */
-}
-
-
-/******************************************************************************
-* *
-* Paramètres : entry = zone de texte dont le contenu vient de changer. *
-* assistant = fenêtre affichée et référencement global. *
-* *
-* Description : Réagit un changement du nom de fichier pour l'exportation. *
-* *
-* Retour : - *
-* *
-* Remarques : - *
-* *
-******************************************************************************/
-
-static void on_export_filename_changed(GtkEntry *entry, GtkAssistant *assistant)
-{
- const gchar *text; /* Texte saisi dans la zone */
- gint num; /* Etape courante */
- GtkWidget *page; /* Support de cette étape */
-
- text = gtk_entry_get_text(entry);
-
- num = gtk_assistant_get_current_page(assistant);
- page = gtk_assistant_get_nth_page(assistant, num);
-
- gtk_assistant_set_page_complete(assistant, page, (strlen(text) > 0));
-
-}
-
-
-/******************************************************************************
-* *
-* Paramètres : button = bouton d'édition de la sélection. *
-* ref = espace de référencement principal. *
-* *
-* Description : Sélectionne ou non un nouveau fichier de sortie. *
-* *
-* Retour : - *
-* *
-* Remarques : - *
-* *
-******************************************************************************/
-
-static void on_filename_browsing_clicked(GtkButton *button, GObject *ref)
-{
- GtkWidget *dialog; /* Boîte à afficher */
- gchar *filename; /* Nom du fichier à intégrer */
- GtkEntry *entry; /* Zone de saisie à maj. */
-
- dialog = gtk_file_chooser_dialog_new(_("Choose an output filename"), GTK_WINDOW(ref),
- GTK_FILE_CHOOSER_ACTION_SAVE,
- _("_Cancel"), GTK_RESPONSE_CANCEL,
- _("_Save"), GTK_RESPONSE_ACCEPT,
- NULL);
-
- entry = GTK_ENTRY(g_object_get_data(ref, "filename"));
- gtk_file_chooser_set_filename(dialog, gtk_entry_get_text(entry));
-
- if (gtk_dialog_run(GTK_DIALOG(dialog)) == GTK_RESPONSE_ACCEPT)
- {
- filename = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dialog));
-
- gtk_entry_set_text(GTK_ENTRY(entry), filename);
-
- g_free(filename);
-
- }
-
- gtk_widget_destroy(dialog);
-
-}
-
-
-
-/* ---------------------------------------------------------------------------------- */
-/* SELECTION DU CONTENU A TRAITER */
-/* ---------------------------------------------------------------------------------- */
-
-
-/******************************************************************************
-* *
-* Paramètres : assistant = fenêtre à compléter et référencement global. *
-* *
-* Description : Ajoute le panneau de sélection du contenu à exporter. *
-* *
-* Retour : - *
-* *
-* Remarques : - *
-* *
-******************************************************************************/
-
-static void register_content_panel(GtkAssistant *assistant)
-{
- GtkWidget *vbox; /* Support principal */
- GtkWidget *frame; /* Support avec encadrement */
- GtkWidget *subvbox; /* Support secondaire */
- GtkWidget *checkbutton; /* Coche pour une option */
-
- vbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 8);
- qck_set_margins(vbox, 8, 8, 8, 8);
- gtk_widget_show(vbox);
-
- /* Lignes à traiter */
-
- subvbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 8);
- gtk_widget_show(subvbox);
-
- frame = qck_create_frame(_("<b>Lines to process</b>"), subvbox, 0, 0, 12, 0);
- gtk_box_pack_start(GTK_BOX(vbox), frame, FALSE, FALSE, 0);
-
- checkbutton = qck_create_check_button(G_OBJECT(assistant), "prologue", _("Prologue"), NULL, NULL);
- gtk_box_pack_start(GTK_BOX(subvbox), checkbutton, FALSE, FALSE, 0);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbutton), TRUE);
-
- checkbutton = qck_create_check_button(G_OBJECT(assistant), "code", _("Code"), NULL, NULL);
- gtk_box_pack_start(GTK_BOX(subvbox), checkbutton, FALSE, FALSE, 0);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbutton), TRUE);
-
- checkbutton = qck_create_check_button(G_OBJECT(assistant), "comments", _("Comments"), NULL, NULL);
- gtk_box_pack_start(GTK_BOX(subvbox), checkbutton, FALSE, FALSE, 0);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbutton), TRUE);
-
- /* Eléments à afficher */
-
- subvbox = gtk_box_new(GTK_ORIENTATION_VERTICAL, 8);
- gtk_widget_show(subvbox);
-
- frame = qck_create_frame(_("<b>Items to display</b>"), subvbox, 0, 0, 12, 0);
- gtk_box_pack_start(GTK_BOX(vbox), frame, FALSE, FALSE, 0);
-
- checkbutton = qck_create_check_button(G_OBJECT(assistant), "virtual_addr", _("Virtual address"), NULL, NULL);
- gtk_box_pack_start(GTK_BOX(subvbox), checkbutton, FALSE, FALSE, 0);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbutton), TRUE);
-
- checkbutton = qck_create_check_button(G_OBJECT(assistant), "binary_code", _("Binary code"), NULL, NULL);
- gtk_box_pack_start(GTK_BOX(subvbox), checkbutton, FALSE, FALSE, 0);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbutton), TRUE);
-
- checkbutton = qck_create_check_button(G_OBJECT(assistant), "assembly_code", _("Assembly code"), NULL, NULL);
- gtk_box_pack_start(GTK_BOX(subvbox), checkbutton, FALSE, FALSE, 0);
- gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(checkbutton), TRUE);
-
- /* Intégration */
-
- gtk_assistant_append_page(assistant, vbox);
- gtk_assistant_set_page_title(assistant, vbox, _("Exported content"));
- gtk_assistant_set_page_type(assistant, vbox, GTK_ASSISTANT_PAGE_CONFIRM);
-
- gtk_assistant_set_page_complete(assistant, vbox, TRUE);
-
-}
-
-
-
-
-
-
-
-
- /* Choix par défaut */
- /*
- binary = G_LOADED_BINARY(g_object_get_data(G_OBJECT(assistant), "binary"));
- filename = g_loaded_binary_get_name(binary);
-
- gtk_entry_set_text(GTK_ENTRY(entry), filename);
- gtk_entry_append_text(GTK_ENTRY(entry), ".txt");
-
- g_signal_connect(G_OBJECT(entry), "changed", G_CALLBACK(on_export_filename_changed), assistant);
- */
-
-
-
diff --git a/src/gui/dialogs/shellcode.h b/src/gui/dialogs/shellcode.h
deleted file mode 100644
index 7c1706b..0000000
--- a/src/gui/dialogs/shellcode.h
+++ /dev/null
@@ -1,37 +0,0 @@
-
-/* Chrysalide - Outil d'analyse de fichiers binaires
- * export.h - prototypes pour l'assistant d'exportation de contenu binaire
- *
- * Copyright (C) 2015-2017 Cyrille Bagard
- *
- * This file is part of Chrysalide.
- *
- * Chrysalide 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.
- *
- * Chrysalide 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 Chrysalide. If not, see <http://www.gnu.org/licenses/>.
- */
-
-
-#ifndef _GUI_DIALOGS_EXPORT_H
-#define _GUI_DIALOGS_EXPORT_H
-
-
-#include "../../analysis/project.h"
-
-
-
-/* Crée et affiche un assistant d'ajout de binaire. */
-void run_shellcode_assistant(GStudyProject *, GtkWindow *);
-
-
-
-#endif /* _GUI_DIALOGS_EXPORT_H */
diff --git a/src/gui/menus/project.c b/src/gui/menus/project.c
index 5a28a7e..20da138 100644
--- a/src/gui/menus/project.c
+++ b/src/gui/menus/project.c
@@ -32,7 +32,6 @@
#include "../editem-int.h"
-#include "../dialogs/shellcode.h"
#include "../../analysis/loading.h"
#include "../../analysis/contents/file.h"
#include "../../core/global.h"
@@ -40,9 +39,6 @@
-/* Affiche la boîte d'ajout d'un shellcode au projet courant. */
-static void mcb_project_add_shellcode(GtkMenuItem *, GMenuBar *);
-
/* Affiche la boîte d'ajout d'un binaire au projet courant. */
static void mcb_project_add_binary_file(GtkMenuItem *, GMenuBar *);
@@ -83,10 +79,6 @@ GtkWidget *build_menu_project(GObject *ref, GtkAccelGroup *accgroup, GMenuBar *b
deepmenubar = qck_create_menu(GTK_MENU_ITEM(submenuitem));
- deepmenuitem = qck_create_menu_item(NULL, NULL, _("Shellcode"),
- G_CALLBACK(mcb_project_add_shellcode), bar);
- gtk_container_add(GTK_CONTAINER(deepmenubar), deepmenuitem);
-
deepmenuitem = qck_create_menu_item(ref, "mnu_project_add_binary", _("File"),
G_CALLBACK(mcb_project_add_binary_file), bar);
gtk_container_add(GTK_CONTAINER(deepmenubar), deepmenuitem);
@@ -173,86 +165,6 @@ void update_menu_project_for_project(GtkWidget *widget, GStudyProject *project,
* Paramètres : menuitem = élément de menu sélectionné. *
* bar = barre de menu parente. *
* *
-* Description : Affiche la boîte d'ajout d'un shellcode au projet courant. *
-* *
-* Retour : - *
-* *
-* Remarques : - *
-* *
-******************************************************************************/
-
-static void mcb_project_add_shellcode(GtkMenuItem *menuitem, GMenuBar *bar)
-{
- GStudyProject *project; /* Projet courant */
- GtkWindow *parent; /* Respect de la hiérarchie */
- //GtkWidget *dialog; /* Boîte à afficher */
-
- project = get_current_project();
- parent = GTK_WINDOW(G_EDITOR_ITEM(bar)->ref);
-
- //dialog = NULL;
-
- run_shellcode_assistant(project, parent);
-
- //if (run_shellcode_assistant(project, parent)) == GTK_RESPONSE_ACCEPT)
- {
-
- ;
-
-
- }
-
- g_object_unref(G_OBJECT(project));
-
-#if 0
- GtkWidget *dialog; /* Boîte à afficher */
- char *dir; /* Répertoire courant */
- gchar *filename; /* Nom du fichier à intégrer */
- GLoadedBinary *binary; /* Représentation chargée */
-
- dialog = gtk_file_chooser_dialog_new(_("Open a binary file"),
- GTK_WINDOW(G_EDITOR_ITEM(bar)->ref),
- GTK_FILE_CHOOSER_ACTION_OPEN,
- GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
- GTK_STOCK_OPEN, GTK_RESPONSE_ACCEPT,
- NULL);
-
- if (g_study_project_get_filename(get_current_project()) != NULL)
- {
- dir = strdup(g_study_project_get_filename(get_current_project()));
- dir = dirname(dir);
- gtk_file_chooser_set_current_folder(GTK_FILE_CHOOSER(dialog), dir);
- free(dir);
- }
-
- if (gtk_dialog_run(GTK_DIALOG(dialog)) == GTK_RESPONSE_ACCEPT)
- {
- filename = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dialog));
-
- binary = g_file_binary_new_from_file(filename);
-
- if (binary != NULL)
- {
- g_signal_connect_swapped(binary, "disassembly-done",
- G_CALLBACK(g_study_project_attach_binary), get_current_project());
- g_loaded_binary_analyse(binary);
- }
-
- g_free(filename);
-
- }
-
- gtk_widget_destroy(dialog);
-#endif
-}
-
-
-
-/******************************************************************************
-* *
-* Paramètres : menuitem = élément de menu sélectionné. *
-* bar = barre de menu parente. *
-* *
* Description : Affiche la boîte d'ajout d'un binaire au projet courant. *
* *
* Retour : - *