X-Git-Url: http://gitweb.hugovil.com/?a=blobdiff_plain;f=src%2Femugtk.c;h=097e7ae3f36e1078040fcc0d8bad51841f9c2d34;hb=5905b40585298defb8e4230adfe90dfbccb465b9;hp=f3e6e375cd0f4b502e9c53523dd828d854e53595;hpb=8dc9dd02e68db51bf93d4061233399e55957d48e;p=emu8051.git diff --git a/src/emugtk.c b/src/emugtk.c index f3e6e37..097e7ae 100644 --- a/src/emugtk.c +++ b/src/emugtk.c @@ -29,6 +29,7 @@ #include "common.h" #include "cpu8051.h" +#include "memory.h" #include "options.h" #include "hexfile.h" @@ -49,12 +50,27 @@ static int running; static int running_function_tag; +static int restart_gui = true; GtkWidget *mainwin; extern struct app_config_t *cfg; extern struct options_t options; +void +emugtk_UpdateDisplay(void) +{ + log_debug("UpdateDisplay()"); + regwin_refresh(); + pgmwin_refresh(); + + if (cfg->view_int_memory) + memwin_refresh(INT_MEM_ID); + + if (cfg->view_ext_memory) + memwin_refresh(EXT_MEM_ID); +} + /* Step out of running state */ static void emugtk_stop_running() @@ -63,9 +79,7 @@ emugtk_stop_running() log_info("StopRunning()"); g_source_remove(running_function_tag); running = 0; - regwin_Show(); - pgmwin_Disasm(); - memwin_DumpD("00"); + emugtk_UpdateDisplay(); } } @@ -116,9 +130,7 @@ static void emugtk_Reset(void) { cpu8051_Reset(); - regwin_Show(); - pgmwin_Disasm(); - memwin_DumpD("00"); + emugtk_UpdateDisplay(); } /* Signal ResetEvent (ResetButton) */ @@ -135,9 +147,7 @@ static void emugtk_Step(void) { cpu8051_Exec(); - regwin_Show(); - pgmwin_Disasm(); - memwin_DumpD("00"); + emugtk_UpdateDisplay(); } /* Signal RunEvent (RunButton) */ @@ -243,17 +253,77 @@ mainwin_configure_event(GtkWindow *window, GdkEvent *event, gpointer data) static void hpaned_notify_event(GtkWindow *window, GdkEvent *event, gpointer data) { - GtkWidget *hpaned = data; + GtkWidget *paned = data; - cfg->hpane_pos = gtk_paned_get_position(GTK_PANED(hpaned)); + cfg->hpane_pos = gtk_paned_get_position(GTK_PANED(paned)); } static void vpaned_notify_event(GtkWindow *window, GdkEvent *event, gpointer data) { - GtkWidget *vpaned = data; + GtkWidget *paned = data; - cfg->vpane_pos = gtk_paned_get_position(GTK_PANED(vpaned)); + cfg->vpane_pos = gtk_paned_get_position(GTK_PANED(paned)); +} + +static void +main_paned_notify_event(GtkWindow *window, GdkEvent *event, gpointer data) +{ + GtkWidget *paned = data; + + cfg->main_pane_pos = gtk_paned_get_position(GTK_PANED(paned)); +} + +void +emugtk_restart_gui(void) +{ + emugtk_stop_running(); + + gtk_widget_destroy(mainwin); + + restart_gui = true; +} + +void +emugtk_quit_gui(void) +{ + gtk_main_quit(); + + restart_gui = false; +} + +static GtkWidget * +emugtk_create_memory_paned(void) +{ + GtkWidget *vpaned; + GtkWidget *scrollwin; + + /* Create vpaned (memory windows) only if necessary. */ + if (cfg->view_int_memory || cfg->view_ext_memory) { + vpaned = gtk_vpaned_new(); + gtk_paned_set_position(GTK_PANED(vpaned), cfg->vpane_pos); + g_signal_connect(G_OBJECT(vpaned), "notify::position", + G_CALLBACK(vpaned_notify_event), vpaned); + + /* Internal memory dump frame. */ + if (cfg->view_int_memory) { + scrollwin = memwin_init("Internal memory (IRAM)", + INT_MEM_ID); + gtk_paned_pack1(GTK_PANED(vpaned), scrollwin, + FALSE, FALSE); + } + + /* External memory dump frame. */ + if (cfg->view_ext_memory) { + scrollwin = memwin_init("External memory (XRAM)", + EXT_MEM_ID); + gtk_paned_pack2(GTK_PANED(vpaned), scrollwin, + TRUE, FALSE); + } + + return vpaned; + } else + return NULL; } /* @@ -277,7 +347,7 @@ vpaned_notify_event(GtkWindow *window, GdkEvent *event, gpointer data) * | | | | * | |---------------------------------------------------------------| | * | | | | - * | | vpaned | | + * | | main_paned | | * | | +---------------------------------------------------------+ | | * | | | | | | * | | | hpaned | | | @@ -292,9 +362,21 @@ vpaned_notify_event(GtkWindow *window, GdkEvent *event, gpointer data) * | | | | | | * | | |--------------------------***----------------------------- | | * | | | | | | - * | | | scrollwin | | | + * | | | vpaned | | | * | | | +---------------------------------------------------+ | | | - * | | | | Memory window | | | | + * | | | | | | | | + * | | | | scrollwin | | | | + * | | | | +---------------------------------------------+ | | | | + * | | | | | Internal memory window | | | | | + * | | | | +---------------------------------------------+ | | | | + * | | | | | | | | + * | | | +-----------------------***-------------------------| | | | + * | | | | | | | | + * | | | | scrollwin | | | | + * | | | | +---------------------------------------------+ | | | | + * | | | | | External memory window | | | | | + * | | | | +---------------------------------------------+ | | | | + * | | | | | | | | * | | | +---------------------------------------------------+ | | | * | | | | | | * | | +---------------------------------------------------------+ | | @@ -314,6 +396,7 @@ emugtk_window_init(void) GtkWidget *scrollwin; GtkWidget *hpaned; GtkWidget *vpaned; + GtkWidget *main_paned; mainwin = gtk_window_new(GTK_WINDOW_TOPLEVEL); gtk_window_set_title(GTK_WINDOW(mainwin), PACKAGE); @@ -328,31 +411,11 @@ emugtk_window_init(void) g_signal_connect(G_OBJECT(mainwin), "configure-event", G_CALLBACK(mainwin_configure_event), NULL); - /* - * vbox contains the menu bar and body_vbox (for all remaining - * items). - */ - vbox = gtk_vbox_new(FALSE, 1); - /* Creating the menu bar. */ menu_bar = AddMenu(); - /* Adding menu bar to vbox */ - gtk_box_pack_start(GTK_BOX(vbox), menu_bar, FALSE, FALSE, 1); /* Creating the buttons bar. */ buttons_bar = AddButtons(); - /* Adding buttons bar to vbox */ - gtk_box_pack_start(GTK_BOX(vbox), buttons_bar, FALSE, FALSE, 1); - - /* - * vpaned will contain: - * Top: registers and disassembly windows. - * Bottom: memory window - */ - vpaned = gtk_vpaned_new(); - gtk_paned_set_position(GTK_PANED(vpaned), cfg->vpane_pos); - g_signal_connect(G_OBJECT(vpaned), "notify::position", - G_CALLBACK(vpaned_notify_event), vpaned); /* hpaned will contain registers and disassembly windows. */ hpaned = gtk_hpaned_new(); @@ -368,28 +431,41 @@ emugtk_window_init(void) scrollwin = pgmwin_init(); gtk_paned_pack2(GTK_PANED(hpaned), scrollwin, TRUE, FALSE); - gtk_paned_pack1(GTK_PANED(vpaned), hpaned, FALSE, FALSE); + /* + * main_paned will contain two groups: + * group1: registers and disassembly windows. + * group2: memory windows + */ + if (cfg->layout == UI_LAYOUT1) + main_paned = gtk_vpaned_new(); + else + main_paned = gtk_hpaned_new(); + + gtk_paned_set_position(GTK_PANED(main_paned), cfg->main_pane_pos); + g_signal_connect(G_OBJECT(main_paned), "notify::position", + G_CALLBACK(main_paned_notify_event), main_paned); + gtk_paned_pack1(GTK_PANED(main_paned), hpaned, FALSE, FALSE); - /* Memory dump frame. */ - scrollwin = memwin_init(); - gtk_paned_pack2(GTK_PANED(vpaned), scrollwin, TRUE, FALSE); + vpaned = emugtk_create_memory_paned(); + if (vpaned != NULL) + gtk_paned_pack2(GTK_PANED(main_paned), vpaned, + TRUE, FALSE); - /* Adding vpaned window to vbox */ - gtk_box_pack_start(GTK_BOX(vbox), vpaned, true, true, 1); + /* + * vbox contains the menu bar and body_vbox (for all remaining + * items). + */ + vbox = gtk_vbox_new(FALSE, 1); + gtk_box_pack_start(GTK_BOX(vbox), menu_bar, FALSE, FALSE, 1); + gtk_box_pack_start(GTK_BOX(vbox), buttons_bar, FALSE, FALSE, 1); + gtk_box_pack_start(GTK_BOX(vbox), main_paned, true, true, 1); /* Adding the vbox to the main window. */ gtk_container_add(GTK_CONTAINER(mainwin), vbox); - gtk_widget_show_all(mainwin); -} + g_signal_connect(mainwin, "destroy", G_CALLBACK(emugtk_quit_gui), NULL); -static void -emugtk_UpdateDisplay(void) -{ - log_debug("UpdateDisplay()"); - regwin_Show(); - pgmwin_Disasm(); - memwin_DumpD("00"); + gtk_widget_show_all(mainwin); } void @@ -408,7 +484,9 @@ emugtk_new_file(char *file) LoadHexFile(file); - emugtk_Reset(); + if (cfg->clear_ram_on_file_load) + emugtk_Reset(); + emugtk_UpdateDisplay(); } @@ -424,14 +502,18 @@ main(int argc, char **argv) gtk_init(&argc, &argv); - emugtk_window_init(); - if (options.filename != NULL) - emugtk_new_file(options.filename); - else - emugtk_Reset(); + LoadHexFile(options.filename); - gtk_main(); + cpu8051_Reset(); + + while (restart_gui == true) { + log_info("Init GUI"); + + emugtk_window_init(); + emugtk_UpdateDisplay(); + gtk_main(); + } log_info("Terminate");