Registers window can now be edited
[emu8051.git] / src / emugtk.c
index 7742788..f3e6e37 100644 (file)
 
 static int running;
 static int running_function_tag;
-static GtkWidget *mainwin;
 
-extern struct app_config_t *cfg;
-
-/* Signal DestroyEvent */
-static void
-WindowDestroyEvent(GtkWidget *widget, gpointer data)
-{
-#ifdef EMU8051_DEBUG
-       g_print("emugtk_DestroyEvent(...)\n");
-#endif
+GtkWidget *mainwin;
 
-       gtk_main_quit();
-}
+extern struct app_config_t *cfg;
+extern struct options_t options;
 
 /* Step out of running state */
 static void
 emugtk_stop_running()
 {
        if (running) {
-#ifdef EMU8051_DEBUG
-               printf("emugtk_StopRunning()\n");
-#endif
+               log_info("StopRunning()");
                g_source_remove(running_function_tag);
                running = 0;
                regwin_Show();
@@ -86,9 +75,7 @@ emugtk_running(gpointer data)
 {
        cpu8051_Exec();
        if (IsBreakpoint(cpu8051.pc)) {
-#ifdef EMU8051_DEBUG
-               g_print("Breakpoint Hit, stopping!\n");
-#endif
+               log_info("Breakpoint Hit");
                emugtk_stop_running();
        }
 
@@ -100,9 +87,7 @@ static void
 emugtk_start_running(void)
 {
        if (!running) {
-#ifdef EMU8051_DEBUG
-               printf("emugtk_StartRunning()\n");
-#endif
+               log_info("StartRunning()");
                running_function_tag = g_idle_add(emugtk_running, 0);
                running = 1;
        }
@@ -140,9 +125,7 @@ emugtk_Reset(void)
 static void
 emugtk_ResetEvent(GtkWidget *widget, GdkEvent *event, gpointer data)
 {
-#ifdef EMU8051_DEBUG
-       g_print("emugtk_ResetEvent(...)\n");
-#endif
+       log_info("ResetEvent()");
        emugtk_stop_running();
        emugtk_Reset();
 }
@@ -161,9 +144,8 @@ emugtk_Step(void)
 static void
 emugtk_RunEvent(GtkWidget *widget, GdkEvent *event, gpointer data)
 {
-#ifdef EMU8051_DEBUG
-       g_print("emugtk_RunEvent(...)\n");
-#endif
+       log_info("RunEvent()");
+
        if (running)
                emugtk_stop_running();
        else
@@ -174,9 +156,7 @@ emugtk_RunEvent(GtkWidget *widget, GdkEvent *event, gpointer data)
 static void
 emugtk_StopEvent(GtkWidget *widget, GdkEvent *event, gpointer data)
 {
-#ifdef EMU8051_DEBUG
-       g_print("emugtk_StopEvent(...)\n");
-#endif
+       log_info("StopEvent()");
        emugtk_stop_running();
 }
 
@@ -184,9 +164,7 @@ emugtk_StopEvent(GtkWidget *widget, GdkEvent *event, gpointer data)
 static void
 emugtk_StepEvent(GtkWidget *widget, GdkEvent *event, gpointer data)
 {
-#ifdef EMU8051_DEBUG
-       g_print("emugtk_StepEvent(...)\n");
-#endif
+       log_info("StepEvent()");
        emugtk_stop_running();
        emugtk_Step();
 }
@@ -245,16 +223,12 @@ AddMenu(void)
        /* Adding the 'Help' submenu */
        HelpAddMenu(menu_bar);
 
-       gtk_widget_show_all(GTK_WIDGET(menu_bar));
-
        return menu_bar;
 }
 
 static int
 mainwin_configure_event(GtkWindow *window, GdkEvent *event, gpointer data)
 {
-       //event->configure.x;
-       //event->configure.y;
        cfg->win_width = event->configure.width;
        cfg->win_height = event->configure.height;
 
@@ -349,7 +323,7 @@ emugtk_window_init(void)
 
        /* Window DESTROY event. */
        g_signal_connect(mainwin, "destroy",
-                        G_CALLBACK(WindowDestroyEvent), NULL);
+                        G_CALLBACK(gtk_main_quit), NULL);
 
        g_signal_connect(G_OBJECT(mainwin), "configure-event",
                         G_CALLBACK(mainwin_configure_event), NULL);
@@ -412,10 +386,7 @@ emugtk_window_init(void)
 static void
 emugtk_UpdateDisplay(void)
 {
-#ifdef EMU8051_DEBUG
-       g_print("emugtk_UpdateDisplay()\n");
-#endif
-
+       log_debug("UpdateDisplay()");
        regwin_Show();
        pgmwin_Disasm();
        memwin_DumpD("00");
@@ -444,10 +415,7 @@ emugtk_new_file(char *file)
 int
 main(int argc, char **argv)
 {
-       char *hex_file;
-
-       ParseCommandLineOptions(argc, argv);
-
+       parse_command_line_options(argc, argv);
        app_config_load();
 
        cpu8051_init();
@@ -458,16 +426,14 @@ main(int argc, char **argv)
 
        emugtk_window_init();
 
-       hex_file = get_hex_filename();
-
-       if (hex_file != NULL)
-               emugtk_new_file(hex_file);
+       if (options.filename != NULL)
+               emugtk_new_file(options.filename);
+       else
+               emugtk_Reset();
 
        gtk_main();
 
-#ifdef EMU8051_DEBUG
-       printf("End of program.\n");
-#endif
+       log_info("Terminate");
 
        app_config_save();