--- np2/x11/gtk2/gtk_menu.c 2007/01/24 14:09:32 1.9
+++ np2/x11/gtk2/gtk_menu.c 2010/08/16 14:26:55 1.16
@@ -1,4 +1,4 @@
-/* $Id: gtk_menu.c,v 1.9 2007/01/24 14:09:32 monaka Exp $ */
+/* $Id: gtk_menu.c,v 1.16 2010/08/16 14:26:55 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"
+#endif
" \n"
" \n"
@@ -547,9 +583,13 @@ cb_bmpsave(GtkAction *action, gpointer u
g_object_set(G_OBJECT(dialog), "show-hidden", TRUE, NULL);
gtk_file_chooser_set_select_multiple(GTK_FILE_CHOOSER(dialog), FALSE);
+ if (strlen(bmpfilefolder) == 0) {
+ g_strlcpy(bmpfilefolder, modulefile, sizeof(bmpfilefolder));
+ file_cutname(bmpfilefolder);
+ }
utf8 = g_filename_to_utf8(bmpfilefolder, -1, NULL, NULL, NULL);
if (utf8) {
- gtk_file_chooser_set_current_folder(GTK_FILE_CHOOSER(dialog), utf8);
+ gtk_file_chooser_set_filename(GTK_FILE_CHOOSER(dialog), utf8);
g_free(utf8);
}
@@ -834,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);
}
@@ -1019,6 +1061,10 @@ cb_newdisk(GtkAction *action, gpointer u
g_object_set(G_OBJECT(dialog), "show-hidden", TRUE, NULL);
gtk_file_chooser_set_select_multiple(GTK_FILE_CHOOSER(dialog), FALSE);
+ if (strlen(fddfolder) == 0) {
+ g_strlcpy(fddfolder, modulefile, sizeof(fddfolder));
+ file_cutname(fddfolder);
+ }
utf8 = g_filename_to_utf8(fddfolder, -1, NULL, NULL, NULL);
if (utf8) {
gtk_file_chooser_set_current_folder(GTK_FILE_CHOOSER(dialog), utf8);
@@ -1032,7 +1078,7 @@ cb_newdisk(GtkAction *action, gpointer u
filter[0] = gtk_file_filter_new();
if (filter[0]) {
- gtk_file_filter_set_name(filter[0], "D88 floppy disk image");
+ gtk_file_filter_set_name(filter[0], "D88 floppy disk image (*.d88,*.d98,*.88d,*.98d)");
gtk_file_filter_add_pattern(filter[0], "*.[dD]88");
gtk_file_filter_add_pattern(filter[0], "*.88[dD]");
gtk_file_filter_add_pattern(filter[0], "*.[dD]98");
@@ -1041,19 +1087,19 @@ cb_newdisk(GtkAction *action, gpointer u
}
filter[1] = gtk_file_filter_new();
if (filter[1]) {
- gtk_file_filter_set_name(filter[1], "Anex86 hard disk image files");
+ gtk_file_filter_set_name(filter[1], "Anex86 hard disk image (*.hdi)");
gtk_file_filter_add_pattern(filter[1], "*.[hH][dD][iI]");
gtk_file_chooser_add_filter(GTK_FILE_CHOOSER(dialog), filter[1]);
}
filter[2] = gtk_file_filter_new();
if (filter[2]) {
- gtk_file_filter_set_name(filter[2], "T98 hard disk image files");
+ gtk_file_filter_set_name(filter[2], "T98 hard disk image (*.thd)");
gtk_file_filter_add_pattern(filter[2], "*.[tT][hH][dD]");
gtk_file_chooser_add_filter(GTK_FILE_CHOOSER(dialog), filter[2]);
}
filter[3] = gtk_file_filter_new();
if (filter[3]) {
- gtk_file_filter_set_name(filter[3], "T98-Next hard disk image files");
+ gtk_file_filter_set_name(filter[3], "T98-Next hard disk image (*.nhd)");
gtk_file_filter_add_pattern(filter[3], "*.[nN][hH][dD]");
gtk_file_chooser_add_filter(GTK_FILE_CHOOSER(dialog), filter[3]);
}
@@ -1225,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)
{
@@ -1791,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)
@@ -1802,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 *
@@ -1854,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);
@@ -1883,21 +2033,13 @@ 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);
g_signal_connect(GTK_OBJECT(menubar), "enter_notify_event",
- GTK_SIGNAL_FUNC(enter_notify_evhandler), NULL);
+ G_CALLBACK(enter_notify_evhandler), NULL);
g_signal_connect(GTK_OBJECT(menubar), "leave_notify_event",
- GTK_SIGNAL_FUNC(leave_notify_evhandler), NULL);
+ G_CALLBACK(leave_notify_evhandler), NULL);
return menubar;
}
@@ -1920,7 +2062,7 @@ void
xmenu_toggle_menu(void)
{
- if (GTK_WIDGET_VISIBLE(menubar))
+ if (gtk_widget_get_visible(menubar))
xmenu_hide();
else
xmenu_show();