From 91e69d0a853af5de0cc47161106520d4e52ed1d9 Mon Sep 17 00:00:00 2001
From: Cyrille Bagard <nocbos@gmail.com>
Date: Thu, 12 Jul 2018 20:54:33 +0200
Subject: Removed all facilities to import shellcodes.

---
 src/gui/dialogs/Makefile.am |   1 -
 src/gui/dialogs/shellcode.c | 805 --------------------------------------------
 src/gui/dialogs/shellcode.h |  37 --
 src/gui/menus/project.c     |  88 -----
 4 files changed, 931 deletions(-)
 delete mode 100644 src/gui/dialogs/shellcode.c
 delete mode 100644 src/gui/dialogs/shellcode.h

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      : -                                                            *
-- 
cgit v0.11.2-87-g4458