--- np2/x11/gtk2/gtk_menu.c 2007/02/04 11:51:14 1.10 +++ np2/x11/gtk2/gtk_menu.c 2008/03/18 15:03:48 1.13 @@ -1,4 +1,4 @@ -/* $Id: gtk_menu.c,v 1.10 2007/02/04 11:51:14 monaka Exp $ */ +/* $Id: gtk_menu.c,v 1.13 2008/03/18 15:03:48 monaka Exp $ */ /* * Copyright (c) 2004 NONAKA Kimihiro (aw9k-nnk@asahi-net.or.jp) @@ -60,6 +60,9 @@ #include "gtk2/gtk_menu.h" #include "gtk2/gtk_keyboard.h" +#ifndef NSTATSAVE +#define NSTATSAVE 10 +#endif /* normal */ static void cb_bmpsave(GtkAction *action, gpointer user_data); @@ -79,6 +82,10 @@ static void cb_reset(GtkAction *action, static void cb_sasiopen(GtkAction *action, gpointer user_data); static void cb_sasiremove(GtkAction *action, gpointer user_data); #endif +#if defined(SUPPORT_STATSAVE) +static void cb_statsave(GtkAction *action, gpointer user_data); +static void cb_statload(GtkAction *action, gpointer user_data); +#endif static void cb_dialog(GtkAction *action, gpointer user_data); static void cb_radio(GtkRadioAction *action, GtkRadioAction *current, gpointer user_data); @@ -91,6 +98,7 @@ static GtkActionEntry menu_entries[] = { { "ScreenMenu", NULL, "Screen", NULL, NULL, NULL }, { "DeviceMenu", NULL, "Device", NULL, NULL, NULL }, { "OtherMenu", NULL, "Other", NULL, NULL, NULL }, +{ "StatMenu", NULL, "Stat", NULL, NULL, NULL }, /* Submenu */ { "Drive1Menu", NULL, "Drive_1", NULL, NULL, NULL }, @@ -147,6 +155,28 @@ static GtkActionEntry menu_entries[] = { { "serialopt", NULL, "Se_rial option...", NULL, NULL, G_CALLBACK(cb_dialog) }, { "soundopt", NULL, "So_und option...", NULL, NULL, G_CALLBACK(cb_dialog) }, { "reset", NULL, "_Reset", NULL, NULL, G_CALLBACK(cb_reset) }, +#if defined(SUPPORT_STATSAVE) +{ "stat00save", NULL, "Save 0", NULL, NULL, G_CALLBACK(cb_statsave), }, +{ "stat01save", NULL, "Save 1", NULL, NULL, G_CALLBACK(cb_statsave), }, +{ "stat02save", NULL, "Save 2", NULL, NULL, G_CALLBACK(cb_statsave), }, +{ "stat03save", NULL, "Save 3", NULL, NULL, G_CALLBACK(cb_statsave), }, +{ "stat04save", NULL, "Save 4", NULL, NULL, G_CALLBACK(cb_statsave), }, +{ "stat05save", NULL, "Save 5", NULL, NULL, G_CALLBACK(cb_statsave), }, +{ "stat06save", NULL, "Save 6", NULL, NULL, G_CALLBACK(cb_statsave), }, +{ "stat07save", NULL, "Save 7", NULL, NULL, G_CALLBACK(cb_statsave), }, +{ "stat08save", NULL, "Save 8", NULL, NULL, G_CALLBACK(cb_statsave), }, +{ "stat09save", NULL, "Save 9", NULL, NULL, G_CALLBACK(cb_statsave), }, +{ "stat00load", NULL, "Load 0", NULL, NULL, G_CALLBACK(cb_statload), }, +{ "stat01load", NULL, "Load 1", NULL, NULL, G_CALLBACK(cb_statload), }, +{ "stat02load", NULL, "Load 2", NULL, NULL, G_CALLBACK(cb_statload), }, +{ "stat03load", NULL, "Load 3", NULL, NULL, G_CALLBACK(cb_statload), }, +{ "stat04load", NULL, "Load 4", NULL, NULL, G_CALLBACK(cb_statload), }, +{ "stat05load", NULL, "Load 5", NULL, NULL, G_CALLBACK(cb_statload), }, +{ "stat06load", NULL, "Load 6", NULL, NULL, G_CALLBACK(cb_statload), }, +{ "stat07load", NULL, "Load 7", NULL, NULL, G_CALLBACK(cb_statload), }, +{ "stat08load", NULL, "Load 8", NULL, NULL, G_CALLBACK(cb_statload), }, +{ "stat09load", NULL, "Load 9", NULL, NULL, G_CALLBACK(cb_statload), }, +#endif }; static const guint n_menu_entries = G_N_ELEMENTS(menu_entries); @@ -314,6 +344,10 @@ static const gchar *ui_info = " \n" " \n" " \n" +#if defined(SUPPORT_STATSAVE) +" \n" +" \n" +#endif " \n" " \n" " \n" @@ -840,6 +874,8 @@ cb_ataopen(GtkAction *action, gpointer u filter = gtk_file_filter_new(); if (filter) { gtk_file_filter_set_name(filter, "IDE disk image files"); + gtk_file_filter_add_pattern(filter, "*.[tT][hH][dD]"); + gtk_file_filter_add_pattern(filter, "*.[hH][dD][iI]"); gtk_file_filter_add_pattern(filter, "*.[nN][hH][dD]"); gtk_file_chooser_add_filter(GTK_FILE_CHOOSER(dialog), filter); } @@ -1235,6 +1271,48 @@ cb_sasiremove(GtkAction *action, gpointe } #endif /* !SUPPORT_IDEIO */ +#if defined(SUPPORT_STATSAVE) +static void +cb_statsave(GtkAction *action, gpointer user_data) +{ + const gchar *name = gtk_action_get_name(GTK_ACTION(action)); + char ext[4]; + guint n; + + UNUSED(user_data); + + /* name = "stat??save" */ + if ((strlen(name) >= 6) + && (g_ascii_isdigit(name[4])) + && (g_ascii_isdigit(name[5]))) { + n = g_ascii_digit_value(name[4]) * 10; + n += g_ascii_digit_value(name[5]); + g_snprintf(ext, sizeof(ext), np2flagext, n); + flagsave(ext); + } +} + +static void +cb_statload(GtkAction *action, gpointer user_data) +{ + const gchar *name = gtk_action_get_name(GTK_ACTION(action)); + char ext[4]; + guint n; + + UNUSED(user_data); + + /* name = "stat??load" */ + if ((strlen(name) >= 6) + && (g_ascii_isdigit(name[4])) + && (g_ascii_isdigit(name[5]))) { + n = g_ascii_digit_value(name[4]) * 10; + n += g_ascii_digit_value(name[5]); + g_snprintf(ext, sizeof(ext), np2flagext, n); + flagload(ext, "Status Load", TRUE); + } +} +#endif + static void cb_dialog(GtkAction *action, gpointer user_data) { @@ -1801,10 +1879,50 @@ leave_notify_evhandler(GtkWidget *w, Gdk return TRUE; } +#if defined(SUPPORT_STATSAVE) +static void +create_menu_statsave(GtkUIManager *ui_manager, int num) +{ + char *name, *action; + guint id; + int i; + + if (num <= 0) + return; + + /* Save %d */ + for (i = 0; i < num; i++) { + id = gtk_ui_manager_new_merge_id(ui_manager); + name = g_strdup_printf("Save %d", i); + action = g_strdup_printf("stat%02dsave", i); + gtk_ui_manager_add_ui(ui_manager, id, "/MainMenu/Stat", + name, action, GTK_UI_MANAGER_MENUITEM, FALSE); + g_free(action); + g_free(name); + } + + /* separator */ + id = gtk_ui_manager_new_merge_id(ui_manager); + gtk_ui_manager_add_ui(ui_manager, id, "/MainMenu/Stat", + "", "", GTK_UI_MANAGER_SEPARATOR, FALSE); + + /* Load %d */ + for (i = 0; i < num; i++) { + id = gtk_ui_manager_new_merge_id(ui_manager); + name = g_strdup_printf("Load %d", i); + action = g_strdup_printf("stat%02dload", i); + gtk_ui_manager_add_ui(ui_manager, id, "/MainMenu/Stat", + name, action, GTK_UI_MANAGER_MENUITEM, FALSE); + g_free(action); + g_free(name); + } +} +#endif + static void equip_fddrive(GtkUIManager *ui_manager, guint no) { - char path[32], name[32], action[32]; + char *path, *name, *action; guint id; if (no >= 4) @@ -1812,23 +1930,32 @@ equip_fddrive(GtkUIManager *ui_manager, no++; id = gtk_ui_manager_new_merge_id(ui_manager); - g_snprintf(name, sizeof(name), "Drive%d", no); - g_snprintf(action, sizeof(action), "Drive%dMenu", no); + name = g_strdup_printf("Drive%d", no); + action = g_strdup_printf("Drive%dMenu", no); gtk_ui_manager_add_ui(ui_manager, id, "/MainMenu/FDD", name, action, GTK_UI_MANAGER_MENU, FALSE); + g_free(action); + g_free(name); + + path = g_strdup_printf("/MainMenu/FDD/Drive%d", no); - g_snprintf(path, sizeof(path), "/MainMenu/FDD/Drive%d", no); id = gtk_ui_manager_new_merge_id(ui_manager); - g_snprintf(name, sizeof(name), "Drive%dOpen", no); - g_snprintf(action, sizeof(action), "disk%dopen", no); + name = g_strdup_printf("Drive%dOpen", no); + action = g_strdup_printf("disk%dopen", no); gtk_ui_manager_add_ui(ui_manager, id, path, name, action, GTK_UI_MANAGER_MENUITEM, FALSE); + g_free(action); + g_free(name); id = gtk_ui_manager_new_merge_id(ui_manager); - g_snprintf(name, sizeof(name), "Drive%dEject", no); - g_snprintf(action, sizeof(action), "disk%deject", no); + name = g_strdup_printf("Drive%dEject", no); + action = g_strdup_printf("disk%deject", no); gtk_ui_manager_add_ui(ui_manager, id, path, name, action, GTK_UI_MANAGER_MENUITEM, FALSE); + g_free(action); + g_free(name); + + g_free(path); } GtkWidget * @@ -1864,6 +1991,19 @@ create_menu(void) return NULL; } +#if defined(SUPPORT_STATSAVE) + if (np2oscfg.statsave) { + create_menu_statsave(menu_hdl.ui_manager, NSTATSAVE); + } +#endif + if (np2cfg.fddequip) { + for (i = 0; i < 4; i++) { + if (np2cfg.fddequip & (1 << i)) { + equip_fddrive(menu_hdl.ui_manager, i); + } + } + } + xmenu_toggle_item(NULL, "dispvsync", np2cfg.DISPSYNC); xmenu_toggle_item(NULL, "joyrapid", np2cfg.BTN_RAPID); xmenu_toggle_item(NULL, "joyreverse", np2cfg.BTN_MODE); @@ -1893,14 +2033,6 @@ create_menu(void) xmenu_select_screensize(SCREEN_DEFMUL); xmenu_select_soundboard(np2cfg.SOUND_SW); - if (np2cfg.fddequip) { - for (i = 0; i < 4; i++) { - if (np2cfg.fddequip & (1 << i)) { - equip_fddrive(menu_hdl.ui_manager, i); - } - } - } - menubar = gtk_ui_manager_get_widget(menu_hdl.ui_manager, "/MainMenu"); gtk_widget_add_events(menubar, EVENT_MASK);