Diff for /np2/x11/gtk2/gtk_menu.c between versions 1.2 and 1.12

version 1.2, 2004/07/15 14:24:33 version 1.12, 2008/03/13 16:27:39
Line 12 Line 12
  * 2. Redistributions in binary form must reproduce the above copyright   * 2. Redistributions in binary form must reproduce the above copyright
  *    notice, this list of conditions and the following disclaimer in the   *    notice, this list of conditions and the following disclaimer in the
  *    documentation and/or other materials provided with the distribution.   *    documentation and/or other materials provided with the distribution.
  * 3. The name of the author may not be used to endorse or promote products  
  *    derived from this software without specific prior written permission.  
  *   *
  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR   * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES   * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
Line 46 Line 44
 #include "pc9861k.h"  #include "pc9861k.h"
 #include "s98.h"  #include "s98.h"
 #include "scrnbmp.h"  #include "scrnbmp.h"
   #include "sxsi.h"
   
 #include "kdispwin.h"  #include "kdispwin.h"
 #include "toolwin.h"  #include "toolwin.h"
Line 67  static void cb_bmpsave(GtkAction *action Line 66  static void cb_bmpsave(GtkAction *action
 static void cb_change_font(GtkAction *action, gpointer user_data);  static void cb_change_font(GtkAction *action, gpointer user_data);
 static void cb_diskeject(GtkAction *action, gpointer user_data);  static void cb_diskeject(GtkAction *action, gpointer user_data);
 static void cb_diskopen(GtkAction *action, gpointer user_data);  static void cb_diskopen(GtkAction *action, gpointer user_data);
   #if defined(SUPPORT_IDEIO)
   static void cb_ataopen(GtkAction *action, gpointer user_data);
   static void cb_ataremove(GtkAction *action, gpointer user_data);
   static void cb_atapiopen(GtkAction *action, gpointer user_data);
   static void cb_atapiremove(GtkAction *action, gpointer user_data);
   #endif
 static void cb_midipanic(GtkAction *action, gpointer user_data);  static void cb_midipanic(GtkAction *action, gpointer user_data);
 static void cb_newdisk(GtkAction *action, gpointer user_data);  static void cb_newdisk(GtkAction *action, gpointer user_data);
 static void cb_reset(GtkAction *action, gpointer user_data);  static void cb_reset(GtkAction *action, gpointer user_data);
   #if !defined(SUPPORT_IDEIO)
 static void cb_sasiopen(GtkAction *action, gpointer user_data);  static void cb_sasiopen(GtkAction *action, gpointer user_data);
 static void cb_sasiremove(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_dialog(GtkAction *action, gpointer user_data);
 static void cb_radio(GtkRadioAction *action, GtkRadioAction *current, gpointer user_data);  static void cb_radio(GtkRadioAction *action, GtkRadioAction *current, gpointer user_data);
Line 84  static GtkActionEntry menu_entries[] = { Line 95  static GtkActionEntry menu_entries[] = {
 { "ScreenMenu",   NULL, "Screen",   NULL, NULL, NULL },  { "ScreenMenu",   NULL, "Screen",   NULL, NULL, NULL },
 { "DeviceMenu",   NULL, "Device",   NULL, NULL, NULL },  { "DeviceMenu",   NULL, "Device",   NULL, NULL, NULL },
 { "OtherMenu",    NULL, "Other",    NULL, NULL, NULL },  { "OtherMenu",    NULL, "Other",    NULL, NULL, NULL },
   { "StatMenu",     NULL, "Stat",     NULL, NULL, NULL },
   
 /* Submenu */  /* Submenu */
 { "Drive1Menu",   NULL, "Drive_1",   NULL, NULL, NULL },  { "Drive1Menu",   NULL, "Drive_1",   NULL, NULL, NULL },
 { "Drive2Menu",   NULL, "Drive_2",   NULL, NULL, NULL },  { "Drive2Menu",   NULL, "Drive_2",   NULL, NULL, NULL },
 { "Drive3Menu",   NULL, "Drive_3",   NULL, NULL, NULL },  { "Drive3Menu",   NULL, "Drive_3",   NULL, NULL, NULL },
 { "Drive4Menu",   NULL, "Drive_4",   NULL, NULL, NULL },  { "Drive4Menu",   NULL, "Drive_4",   NULL, NULL, NULL },
   #if defined(SUPPORT_IDEIO)
   { "ATA00Menu",    NULL, "IDE0-_0",   NULL, NULL, NULL },
   { "ATA01Menu",    NULL, "IDE0-_1",   NULL, NULL, NULL },
   { "ATAPIMenu",    NULL, "_CD-ROM",   NULL, NULL, NULL },
   #endif
 { "KeyboardMenu", NULL, "_Keyboard", NULL, NULL, NULL },  { "KeyboardMenu", NULL, "_Keyboard", NULL, NULL, NULL },
 { "MemoryMenu",   NULL, "M_emory",   NULL, NULL, NULL },  { "MemoryMenu",   NULL, "M_emory",   NULL, NULL, NULL },
   #if !defined(SUPPORT_IDEIO)
 { "SASI1Menu",    NULL, "SASI-_1",   NULL, NULL, NULL },  { "SASI1Menu",    NULL, "SASI-_1",   NULL, NULL, NULL },
 { "SASI2Menu",    NULL, "SASI-_2",   NULL, NULL, NULL },  { "SASI2Menu",    NULL, "SASI-_2",   NULL, NULL, NULL },
   #endif
   { "ScrnSizeMenu", NULL, "Size",      NULL, NULL, NULL },
 { "SoundMenu",    NULL, "_Sound",    NULL, NULL, NULL },  { "SoundMenu",    NULL, "_Sound",    NULL, NULL, NULL },
   
 /* MenuItem */  /* MenuItem */
Line 111  static GtkActionEntry menu_entries[] = { Line 131  static GtkActionEntry menu_entries[] = {
 { "disk4open",   NULL, "_Open...",          NULL, NULL, G_CALLBACK(cb_diskopen), },  { "disk4open",   NULL, "_Open...",          NULL, NULL, G_CALLBACK(cb_diskopen), },
 { "exit",        NULL, "E_xit",             NULL, NULL, G_CALLBACK(gtk_main_quit) },  { "exit",        NULL, "E_xit",             NULL, NULL, G_CALLBACK(gtk_main_quit) },
 { "font",        NULL, "_Font...",          NULL, NULL, G_CALLBACK(cb_change_font), },  { "font",        NULL, "_Font...",          NULL, NULL, G_CALLBACK(cb_change_font), },
   #if defined(SUPPORT_IDEIO)
   { "ata00open",   NULL, "_Open...",          NULL, NULL, G_CALLBACK(cb_ataopen), },
   { "ata00remove", NULL, "_Remove",           NULL, NULL, G_CALLBACK(cb_ataremove), },
   { "ata01open",   NULL, "_Open...",          NULL, NULL, G_CALLBACK(cb_ataopen), },
   { "ata01remove", NULL, "_Remove",           NULL, NULL, G_CALLBACK(cb_ataremove), },
   { "atapiopen",   NULL, "_Open...",          NULL, NULL, G_CALLBACK(cb_atapiopen), },
   { "atapiremove", NULL, "_Remove",           NULL, NULL, G_CALLBACK(cb_atapiremove), },
   #endif
 { "midiopt",     NULL, "MIDI _option...",   NULL, NULL, G_CALLBACK(cb_dialog) },  { "midiopt",     NULL, "MIDI _option...",   NULL, NULL, G_CALLBACK(cb_dialog) },
 { "midipanic",   NULL, "MIDI _panic",       NULL, NULL, G_CALLBACK(cb_midipanic) },  { "midipanic",   NULL, "MIDI _panic",       NULL, NULL, G_CALLBACK(cb_midipanic) },
 { "newdisk",     NULL, "_New disk...",      NULL, NULL, G_CALLBACK(cb_newdisk), },  { "newdisk",     NULL, "_New disk...",      NULL, NULL, G_CALLBACK(cb_newdisk), },
   #if !defined(SUPPORT_IDEIO)
 { "sasi1open",   NULL, "_Open...",          NULL, NULL, G_CALLBACK(cb_sasiopen), },  { "sasi1open",   NULL, "_Open...",          NULL, NULL, G_CALLBACK(cb_sasiopen), },
 { "sasi1remove", NULL, "_Remove",           NULL, NULL, G_CALLBACK(cb_sasiremove), },  { "sasi1remove", NULL, "_Remove",           NULL, NULL, G_CALLBACK(cb_sasiremove), },
 { "sasi2open",   NULL, "_Open...",          NULL, NULL, G_CALLBACK(cb_sasiopen), },  { "sasi2open",   NULL, "_Open...",          NULL, NULL, G_CALLBACK(cb_sasiopen), },
 { "sasi2remove", NULL, "_Remove",           NULL, NULL, G_CALLBACK(cb_sasiremove), },  { "sasi2remove", NULL, "_Remove",           NULL, NULL, G_CALLBACK(cb_sasiremove), },
   #endif
 { "screenopt",   NULL, "Screen _option...", NULL, NULL, G_CALLBACK(cb_dialog) },  { "screenopt",   NULL, "Screen _option...", NULL, NULL, G_CALLBACK(cb_dialog) },
 { "serialopt",   NULL, "Se_rial option...", NULL, NULL, G_CALLBACK(cb_dialog) },  { "serialopt",   NULL, "Se_rial option...", NULL, NULL, G_CALLBACK(cb_dialog) },
 { "soundopt",    NULL, "So_und 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) },  { "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);  static const guint n_menu_entries = G_N_ELEMENTS(menu_entries);
   
Line 239  static GtkRadioActionEntry rotate_entrie Line 291  static GtkRadioActionEntry rotate_entrie
 };  };
 static const guint n_rotate_entries = G_N_ELEMENTS(rotate_entries);  static const guint n_rotate_entries = G_N_ELEMENTS(rotate_entries);
   
   static GtkRadioActionEntry screensize_entries[] = {
   { "320x200",  NULL, "320x200",  NULL, NULL, 4 },
   { "480x300",  NULL, "480x300",  NULL, NULL, 6 },
   { "640x400",  NULL, "640x400",  NULL, NULL, 8 },
   { "800x500",  NULL, "800x500",  NULL, NULL, 10 },
   { "960x600",  NULL, "960x600",  NULL, NULL, 12 },
   { "1280x800", NULL, "1280x800", NULL, NULL, 16 },
   };
   static const guint n_screensize_entries = G_N_ELEMENTS(screensize_entries);
   
 static void cb_beepvol(gint idx);  static void cb_beepvol(gint idx);
 static void cb_f12key(gint idx);  static void cb_f12key(gint idx);
 static void cb_framerate(gint idx);  static void cb_framerate(gint idx);
Line 246  static void cb_joykey(gint idx); Line 308  static void cb_joykey(gint idx);
 static void cb_memory(gint idx);  static void cb_memory(gint idx);
 static void cb_rotate(gint idx);  static void cb_rotate(gint idx);
 static void cb_screenmode(gint idx);  static void cb_screenmode(gint idx);
   static void cb_screensize(gint idx);
 static void cb_soundboard(gint idx);  static void cb_soundboard(gint idx);
   
 static const struct {  static const struct {
Line 260  static const struct { Line 323  static const struct {
         { memory_entries, G_N_ELEMENTS(memory_entries), cb_memory },          { memory_entries, G_N_ELEMENTS(memory_entries), cb_memory },
         { rotate_entries, G_N_ELEMENTS(rotate_entries), cb_rotate },          { rotate_entries, G_N_ELEMENTS(rotate_entries), cb_rotate },
         { screenmode_entries, G_N_ELEMENTS(screenmode_entries), cb_screenmode },          { screenmode_entries, G_N_ELEMENTS(screenmode_entries), cb_screenmode },
           { screensize_entries, G_N_ELEMENTS(screensize_entries), cb_screensize },
         { soundboard_entries, G_N_ELEMENTS(soundboard_entries), cb_soundboard },          { soundboard_entries, G_N_ELEMENTS(soundboard_entries), cb_soundboard },
 };  };
 static const guint n_radiomenu_entries = G_N_ELEMENTS(radiomenu_entries);  static const guint n_radiomenu_entries = G_N_ELEMENTS(radiomenu_entries);
Line 274  static const gchar *ui_info = Line 338  static const gchar *ui_info =
 "   <menuitem action='configure'/>\n"  "   <menuitem action='configure'/>\n"
 "   <menuitem action='newdisk'/>\n"  "   <menuitem action='newdisk'/>\n"
 "   <menuitem action='font'/>\n"  "   <menuitem action='font'/>\n"
 "   <menuitem action='configure'/>\n"  
 "   <separator/>\n"  "   <separator/>\n"
 "   <menuitem action='exit'/>\n"  "   <menuitem action='exit'/>\n"
 "  </menu>\n"  "  </menu>\n"
 "  <menu name='FDD' action='FDDMenu'>\n"  "  <menu name='FDD' action='FDDMenu'>\n"
 "  </menu>\n"  "  </menu>\n"
 "  <menu name='HardDisk' action='HardDiskMenu'>\n"  "  <menu name='HardDisk' action='HardDiskMenu'>\n"
   #if defined(SUPPORT_IDEIO)
   "   <menu name='ATA00' action='ATA00Menu'>\n"
   "    <menuitem action='ata00open'/>\n"
   "    <menuitem action='ata00remove'/>\n"
   "   </menu>\n"
   "   <menu name='ATA01' action='ATA01Menu'>\n"
   "    <menuitem action='ata01open'/>\n"
   "    <menuitem action='ata01remove'/>\n"
   "   </menu>\n"
   "   <menu name='ATAPI' action='ATAPIMenu'>\n"
   "    <menuitem action='atapiopen'/>\n"
   "    <menuitem action='atapiremove'/>\n"
   "   </menu>\n"
   #else   /* !SUPPORT_IDEIO */
 "   <menu name='SASI1' action='SASI1Menu'>\n"  "   <menu name='SASI1' action='SASI1Menu'>\n"
 "    <menuitem action='sasi1open'/>\n"  "    <menuitem action='sasi1open'/>\n"
 "    <menuitem action='sasi1remove'/>\n"  "    <menuitem action='sasi1remove'/>\n"
Line 289  static const gchar *ui_info = Line 366  static const gchar *ui_info =
 "    <menuitem action='sasi2open'/>\n"  "    <menuitem action='sasi2open'/>\n"
 "    <menuitem action='sasi2remove'/>\n"  "    <menuitem action='sasi2remove'/>\n"
 "   </menu>\n"  "   </menu>\n"
   #endif  /* SUPPORT_IDEIO */
 "  </menu>\n"  "  </menu>\n"
 "  <menu name='Screen' action='ScreenMenu'>\n"  "  <menu name='Screen' action='ScreenMenu'>\n"
 "   <menuitem action='fullscreen'/>\n"  "   <menuitem action='fullscreen'/>\n"
Line 301  static const gchar *ui_info = Line 379  static const gchar *ui_info =
 "   <menuitem action='dispvsync'/>\n"  "   <menuitem action='dispvsync'/>\n"
 "   <menuitem action='realpalettes'/>\n"  "   <menuitem action='realpalettes'/>\n"
 "   <menuitem action='nowait'/>\n"  "   <menuitem action='nowait'/>\n"
 "   <menuitem name='framerate' action='autoframe'/>\n"  "   <menuitem action='autoframe'/>\n"
 "   <menuitem action='fullframe'/>\n"  "   <menuitem action='fullframe'/>\n"
 "   <menuitem action='1/2 frame'/>\n"  "   <menuitem action='1/2 frame'/>\n"
 "   <menuitem action='1/3 frame'/>\n"  "   <menuitem action='1/3 frame'/>\n"
 "   <menuitem action='1/4 frame'/>\n"  "   <menuitem action='1/4 frame'/>\n"
   #if defined(SUPPORT_SCREENSIZE)
   "   <separator/>\n"
   "   <menu name='Size' action='ScrnSizeMenu'>\n"
   "    <menuitem action='320x200'/>\n"
   "    <menuitem action='480x300'/>\n"
   "    <menuitem action='640x400'/>\n"
   "    <menuitem action='800x500'/>\n"
   "    <menuitem action='960x600'/>\n"
   "    <menuitem action='1280x800'/>\n"
   "   </menu>\n"
   #endif
 "   <separator/>\n"  "   <separator/>\n"
 "   <menuitem action='screenopt'/>\n"  "   <menuitem action='screenopt'/>\n"
 "  </menu>\n"  "  </menu>\n"
Line 379  static const gchar *ui_info = Line 468  static const gchar *ui_info =
 "   <separator/>\n"  "   <separator/>\n"
 "   <menuitem action='about'/>\n"  "   <menuitem action='about'/>\n"
 "  </menu>\n"  "  </menu>\n"
   #if defined(SUPPORT_STATSAVE)
   "  <menu name='Stat' action='StatMenu'>\n"
   "   <menuitem action='stat00save'/>\n"
   "   <menuitem action='stat01save'/>\n"
   "   <menuitem action='stat02save'/>\n"
   "   <menuitem action='stat03save'/>\n"
   "   <menuitem action='stat04save'/>\n"
   "   <menuitem action='stat05save'/>\n"
   "   <menuitem action='stat06save'/>\n"
   "   <menuitem action='stat07save'/>\n"
   "   <menuitem action='stat08save'/>\n"
   "   <menuitem action='stat09save'/>\n"
   "   <separator/>\n"
   "   <menuitem action='stat00load'/>\n"
   "   <menuitem action='stat01load'/>\n"
   "   <menuitem action='stat02load'/>\n"
   "   <menuitem action='stat03load'/>\n"
   "   <menuitem action='stat04load'/>\n"
   "   <menuitem action='stat05load'/>\n"
   "   <menuitem action='stat06load'/>\n"
   "   <menuitem action='stat07load'/>\n"
   "   <menuitem action='stat08load'/>\n"
   "   <menuitem action='stat09load'/>\n"
   "  </menu>\n"
   #endif
 " </menubar>\n"  " </menubar>\n"
 "</ui>\n";  "</ui>\n";
   
Line 447  xmenu_select_item_by_index(MENU_HDL hdl, Line 561  xmenu_select_item_by_index(MENU_HDL hdl,
         xmenu_select_item_by_index(NULL, rotate_entries, n_rotate_entries, v);          xmenu_select_item_by_index(NULL, rotate_entries, n_rotate_entries, v);
 #define xmenu_select_screenmode(v) \  #define xmenu_select_screenmode(v) \
         xmenu_select_item_by_index(NULL, screenmode_entries, n_screenmode_entries, v);          xmenu_select_item_by_index(NULL, screenmode_entries, n_screenmode_entries, v);
   #define xmenu_select_screensize(v) \
           xmenu_select_item_by_index(NULL, screensize_entries, n_screensize_entries, v);
 #define xmenu_select_soundboard(v) \  #define xmenu_select_soundboard(v) \
         xmenu_select_item_by_index(NULL, soundboard_entries, n_soundboard_entries, v);          xmenu_select_item_by_index(NULL, soundboard_entries, n_soundboard_entries, v);
   
Line 485  cb_bmpsave(GtkAction *action, gpointer u Line 601  cb_bmpsave(GtkAction *action, gpointer u
   
         g_object_set(G_OBJECT(dialog), "show-hidden", TRUE, NULL);          g_object_set(G_OBJECT(dialog), "show-hidden", TRUE, NULL);
         gtk_file_chooser_set_select_multiple(GTK_FILE_CHOOSER(dialog), FALSE);          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);          utf8 = g_filename_to_utf8(bmpfilefolder, -1, NULL, NULL, NULL);
         if (utf8) {          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);                  g_free(utf8);
         }          }
   
Line 720  end: Line 840  end:
         install_idle_process();          install_idle_process();
 }  }
   
   #if defined(SUPPORT_IDEIO)
   static void
   cb_ataopen(GtkAction *action, gpointer user_data)
   {
           GtkWidget *dialog = NULL;
           GtkFileFilter *filter;
           gchar *utf8, *path;
           struct stat sb;
           const gchar *name = gtk_action_get_name(action);
           guint channel, drive;
   
           UNUSED(user_data);
   
           /* "ata??open" */
           if ((strlen(name) < 5)
            || (!g_ascii_isdigit(name[3]))
            || (!g_ascii_isdigit(name[4]))) {
                   return;
           }
   
           channel = g_ascii_digit_value(name[3]);
           drive = g_ascii_digit_value(name[4]);
           if (channel != 0 || drive >= 2)
                   return;
   
           uninstall_idle_process();
   
           dialog = gtk_file_chooser_dialog_new("Open a IDE disk image",
               GTK_WINDOW(main_window), GTK_FILE_CHOOSER_ACTION_OPEN, 
               GTK_STOCK_OPEN, GTK_RESPONSE_OK,
               GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
               NULL);
           if (dialog == NULL)
                   goto end;
   
           g_object_set(G_OBJECT(dialog), "show-hidden", TRUE, NULL);
           gtk_file_chooser_set_select_multiple(GTK_FILE_CHOOSER(dialog), FALSE);
           utf8 = g_filename_to_utf8(hddfolder, -1, NULL, NULL, NULL);
           if (utf8) {
                   gtk_file_chooser_set_filename(GTK_FILE_CHOOSER(dialog), utf8);
                   g_free(utf8);
           }
   
           filter = gtk_file_filter_new();
           if (filter) {
                   gtk_file_filter_set_name(filter, "All files");
                   gtk_file_filter_add_pattern(filter, "*");
                   gtk_file_chooser_add_filter(GTK_FILE_CHOOSER(dialog), filter);
           }
           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);
           }
           gtk_file_chooser_set_filter(GTK_FILE_CHOOSER(dialog), filter);
   
           if (gtk_dialog_run(GTK_DIALOG(dialog)) != GTK_RESPONSE_OK)
                   goto end;
   
           utf8 = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dialog));
           if (utf8) {
                   path = g_filename_from_utf8(utf8, -1, NULL, NULL, NULL);
                   if (path) {
                           if ((stat(path, &sb) == 0) && S_ISREG(sb.st_mode) && (sb.st_mode & S_IRUSR)) {
                                   file_cpyname(hddfolder, path, sizeof(hddfolder));
                                   diskdrv_sethdd(2 * channel + drive, path);
                                   sysmng_update(SYS_UPDATEOSCFG);
                           }
                           g_free(path);
                   }
                   g_free(utf8);
           }
   
   end:
           if (dialog)
                   gtk_widget_destroy(dialog);
           install_idle_process();
   }
   
   static void
   cb_ataremove(GtkAction *action, gpointer user_data)
   {
           const gchar *name = gtk_action_get_name(GTK_ACTION(action));
           guint channel, drive;
   
           UNUSED(user_data);
   
           /* "ata??open" */
           if ((strlen(name) < 5)
            || (!g_ascii_isdigit(name[3]))
            || (!g_ascii_isdigit(name[4]))) {
                   return;
           }
   
           channel = g_ascii_digit_value(name[3]);
           drive = g_ascii_digit_value(name[4]);
           if (channel == 0 && drive < 2) {
                   if (2 * channel + drive < 4) {
                           diskdrv_sethdd(2 * channel + drive, "");
                   }
           }
   }
   
   static void
   cb_atapiopen(GtkAction *action, gpointer user_data)
   {
           GtkWidget *dialog = NULL;
           GtkFileFilter *filter;
           gchar *utf8, *path;
           struct stat sb;
   
           UNUSED(action);
           UNUSED(user_data);
   
           uninstall_idle_process();
   
           dialog = gtk_file_chooser_dialog_new("Open a ATAPI CD-ROM image",
               GTK_WINDOW(main_window), GTK_FILE_CHOOSER_ACTION_OPEN, 
               GTK_STOCK_OPEN, GTK_RESPONSE_OK,
               GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL,
               NULL);
           if (dialog == NULL)
                   goto end;
   
           g_object_set(G_OBJECT(dialog), "show-hidden", TRUE, NULL);
           gtk_file_chooser_set_select_multiple(GTK_FILE_CHOOSER(dialog), FALSE);
           utf8 = g_filename_to_utf8(hddfolder, -1, NULL, NULL, NULL);
           if (utf8) {
                   gtk_file_chooser_set_filename(GTK_FILE_CHOOSER(dialog), utf8);
                   g_free(utf8);
           }
   
           filter = gtk_file_filter_new();
           if (filter) {
                   gtk_file_filter_set_name(filter, "All files");
                   gtk_file_filter_add_pattern(filter, "*");
                   gtk_file_chooser_add_filter(GTK_FILE_CHOOSER(dialog), filter);
           }
           filter = gtk_file_filter_new();
           if (filter) {
                   gtk_file_filter_set_name(filter, "ISO CD-ROM image files");
                   gtk_file_filter_add_pattern(filter, "*.[iI][sS][oO]");
                   gtk_file_chooser_add_filter(GTK_FILE_CHOOSER(dialog), filter);
           }
           gtk_file_chooser_set_filter(GTK_FILE_CHOOSER(dialog), filter);
           filter = gtk_file_filter_new();
           if (filter) {
                   gtk_file_filter_set_name(filter, "CUE CD-ROM image files");
                   gtk_file_filter_add_pattern(filter, "*.[cC][uU][eE]");
                   gtk_file_chooser_add_filter(GTK_FILE_CHOOSER(dialog), filter);
           }
   
           if (gtk_dialog_run(GTK_DIALOG(dialog)) != GTK_RESPONSE_OK)
                   goto end;
   
           utf8 = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dialog));
           if (utf8) {
                   path = g_filename_from_utf8(utf8, -1, NULL, NULL, NULL);
                   if (path) {
                           if ((stat(path, &sb) == 0) && S_ISREG(sb.st_mode) && (sb.st_mode & S_IRUSR)) {
                                   file_cpyname(hddfolder, path, sizeof(hddfolder));
                                   sxsi_devopen(0x02, path);
                                   sysmng_update(SYS_UPDATEOSCFG);
                           }
                           g_free(path);
                   }
                   g_free(utf8);
           }
   
   end:
           if (dialog)
                   gtk_widget_destroy(dialog);
           install_idle_process();
   }
   
   static void
   cb_atapiremove(GtkAction *action, gpointer user_data)
   {
   
           UNUSED(action);
           UNUSED(user_data);
   
           sxsi_devclose(0x02);
   }
   #endif  /* SUPPORT_IDEIO */
   
 static void  static void
 cb_midipanic(GtkAction *action, gpointer user_data)  cb_midipanic(GtkAction *action, gpointer user_data)
 {  {
Line 770  cb_newdisk(GtkAction *action, gpointer u Line 1079  cb_newdisk(GtkAction *action, gpointer u
   
         g_object_set(G_OBJECT(dialog), "show-hidden", TRUE, NULL);          g_object_set(G_OBJECT(dialog), "show-hidden", TRUE, NULL);
         gtk_file_chooser_set_select_multiple(GTK_FILE_CHOOSER(dialog), FALSE);          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);          utf8 = g_filename_to_utf8(fddfolder, -1, NULL, NULL, NULL);
         if (utf8) {          if (utf8) {
                 gtk_file_chooser_set_current_folder(GTK_FILE_CHOOSER(dialog), utf8);                  gtk_file_chooser_set_current_folder(GTK_FILE_CHOOSER(dialog), utf8);
Line 814  cb_newdisk(GtkAction *action, gpointer u Line 1127  cb_newdisk(GtkAction *action, gpointer u
                 goto end;                  goto end;
   
         utf8 = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dialog));          utf8 = gtk_file_chooser_get_filename(GTK_FILE_CHOOSER(dialog));
         if (utf8) {          if (utf8 == NULL)
                 path = g_filename_from_utf8(utf8, -1, NULL, NULL, NULL);                  goto end;
                 if (path) {  
                         kind = -1;  
                         ext = file_getext(path);  
                         for (i = 0; i < NELEMENTS(exttbl); i++) {  
                                 if (g_ascii_strcasecmp(ext, exttbl[i].name) == 0) {  
                                         kind = exttbl[i].kind;  
                                         break;  
                                 }  
                         }  
                         if (i == NELEMENTS(exttbl)) {  
                                 f = gtk_file_chooser_get_filter(GTK_FILE_CHOOSER(dialog));  
                                 for (i = 0; i < NELEMENTS(filter); i++) {  
                                         if (f == filter[i]) {  
                                                 kind = i;  
                                                 tmp = g_strjoin(".", path, extname[i]);  
                                                 if (tmp) {  
                                                         g_free(path);  
                                                         path = tmp;  
                                                 }  
                                                 break;  
                                         }  
                                 }  
                         }  
   
                         uninstall_idle_process();  
                         switch (kind) {  
                         case 0: /* D88 */  
                                 create_newdisk_fd_dialog(path);  
                                 break;  
   
                         case 1: /* HDI */          path = g_filename_from_utf8(utf8, -1, NULL, NULL, NULL);
                         case 2: /* THD */          g_free(utf8);
                         case 3: /* NHD */          if (path == NULL)
                                 create_newdisk_hd_dialog(path, kind);                  goto end;
                                 break;  
   
                         default:          kind = -1;
           ext = file_getext(path);
           for (i = 0; i < NELEMENTS(exttbl); i++) {
                   if (g_ascii_strcasecmp(ext, exttbl[i].name) == 0) {
                           kind = exttbl[i].kind;
                           break;
                   }
           }
           if (i == NELEMENTS(exttbl)) {
                   f = gtk_file_chooser_get_filter(GTK_FILE_CHOOSER(dialog));
                   for (i = 0; i < NELEMENTS(filter); i++) {
                           if (f == filter[i]) {
                                   kind = i;
                                   tmp = g_strjoin(".", path, extname[i], NULL);
                                   if (tmp) {
                                           g_free(path);
                                           path = tmp;
                                   }
                                 break;                                  break;
                         }                          }
                         install_idle_process();  
   
                         g_free(path);  
                 }                  }
                 g_free(utf8);  
         }          }
   
           /* XXX system has only one modal dialog? */
           gtk_widget_destroy(dialog);
   
           switch (kind) {
           case 0: /* D88 */
                   create_newdisk_fd_dialog(path);
                   break;
   
           case 1: /* HDI */
           case 2: /* THD */
           case 3: /* NHD */
                   create_newdisk_hd_dialog(path, kind);
                   break;
   
           default:
                   break;
           }
           g_free(path);
   
           install_idle_process();
           return;
   
 end:  end:
         if (dialog)          if (dialog)
                 gtk_widget_destroy(dialog);                  gtk_widget_destroy(dialog);
Line 879  cb_reset(GtkAction *action, gpointer use Line 1197  cb_reset(GtkAction *action, gpointer use
         pccore_reset();          pccore_reset();
 }  }
   
   #if !defined(SUPPORT_IDEIO)
 static void  static void
 cb_sasiopen(GtkAction *action, gpointer user_data)  cb_sasiopen(GtkAction *action, gpointer user_data)
 {  {
Line 968  cb_sasiremove(GtkAction *action, gpointe Line 1287  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  static void
 cb_dialog(GtkAction *action, gpointer user_data)  cb_dialog(GtkAction *action, gpointer user_data)
Line 1413  cb_screenmode(gint idx) Line 1775  cb_screenmode(gint idx)
 }  }
   
 static void  static void
   cb_screensize(gint idx)
   {
           guint value;
   
           if (idx >= 0) {
                   value = screensize_entries[idx].value;
           } else {
                   value = 0;
           }
           scrnmng_setmultiple(value);
   }
   
   static void
 cb_soundboard(gint idx)  cb_soundboard(gint idx)
 {  {
         guint value;          guint value;
Line 1455  cb_radio(GtkRadioAction *action, GtkRadi Line 1830  cb_radio(GtkRadioAction *action, GtkRadi
 /*  /*
  * create menubar   * create menubar
  */   */
   static GtkWidget *menubar;
   static guint menubar_timerid;
   
   #define EVENT_MASK      (GDK_ENTER_NOTIFY_MASK|GDK_LEAVE_NOTIFY_MASK)
   
   static gboolean
   menubar_timeout(gpointer p)
   {
   
           UNUSED(p);
   
           if (menubar_timerid) {
                   g_source_remove(menubar_timerid);
                   menubar_timerid = 0;
           }
   
           if (scrnmode & SCRNMODE_FULLSCREEN) {
                   xmenu_hide();
           }
   
           return TRUE;
   }
   
   /*
    - Signal: gboolean GtkWidget::enter_notify_event (GtkWidget *widget,
             GdkEventCrossing *event, gpointer user_data)
   */
   static gboolean
   enter_notify_evhandler(GtkWidget *w, GdkEventCrossing *ev, gpointer p)
   {
   
           UNUSED(w);
           UNUSED(ev);
           UNUSED(p);
   
           if (menubar_timerid) {
                   g_source_remove(menubar_timerid);
                   menubar_timerid = 0;
           }
   
           return TRUE;
   }
   
   /*
    - Signal: gboolean GtkWidget::leave_notify_event (GtkWidget *widget,
             GdkEventCrossing *event, gpointer user_data)
   */
   static gboolean
   leave_notify_evhandler(GtkWidget *w, GdkEventCrossing *ev, gpointer p)
   {
   
           UNUSED(w);
           UNUSED(ev);
           UNUSED(p);
   
           if (menubar_timerid) {
                   g_source_remove(menubar_timerid);
                   menubar_timerid = 0;
           }
   
           if (scrnmode & SCRNMODE_FULLSCREEN) {
                   menubar_timerid = g_timeout_add(1000, menubar_timeout, NULL);
           }
   
           return TRUE;
   }
   
 static void  static void
 equip_fddrive(GtkUIManager *ui_manager, guint no)  equip_fddrive(GtkUIManager *ui_manager, guint no)
 {  {
Line 1488  equip_fddrive(GtkUIManager *ui_manager,  Line 1930  equip_fddrive(GtkUIManager *ui_manager, 
 GtkWidget *  GtkWidget *
 create_menu(void)  create_menu(void)
 {  {
         GtkWidget *menubar;  
         GError *err = NULL;          GError *err = NULL;
         gint rv;          gint rv;
         guint i;          guint i;
Line 1545  create_menu(void) Line 1986  create_menu(void)
         xmenu_select_memory(np2cfg.EXTMEM);          xmenu_select_memory(np2cfg.EXTMEM);
         xmenu_select_rotate(scrnmode & SCRNMODE_ROTATEMASK);          xmenu_select_rotate(scrnmode & SCRNMODE_ROTATEMASK);
         xmenu_select_screenmode(scrnmode & SCRNMODE_FULLSCREEN);          xmenu_select_screenmode(scrnmode & SCRNMODE_FULLSCREEN);
           xmenu_select_screensize(SCREEN_DEFMUL);
         xmenu_select_soundboard(np2cfg.SOUND_SW);          xmenu_select_soundboard(np2cfg.SOUND_SW);
   
         if (np2cfg.fddequip) {          if (np2cfg.fddequip) {
Line 1556  create_menu(void) Line 1998  create_menu(void)
         }          }
   
         menubar = gtk_ui_manager_get_widget(menu_hdl.ui_manager, "/MainMenu");          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_signal_connect(GTK_OBJECT(menubar), "leave_notify_event",
                       GTK_SIGNAL_FUNC(leave_notify_evhandler), NULL);
   
         return menubar;          return menubar;
 }  }
   
   void
   xmenu_hide(void)
   {
   
           gtk_widget_hide(menubar);
   }
   
   void
   xmenu_show(void)
   {
   
           gtk_widget_show(menubar);
   }
   
   void
   xmenu_toggle_menu(void)
   {
   
           if (GTK_WIDGET_VISIBLE(menubar))
                   xmenu_hide();
           else
                   xmenu_show();
   }
   
   void
   xmenu_select_screen(UINT8 mode)
   {
   
           xmenu_select_rotate(mode & SCRNMODE_ROTATEMASK);
           xmenu_select_screenmode(mode & SCRNMODE_FULLSCREEN);
   }

Removed from v.1.2  
changed lines
  Added in v.1.12


RetroPC.NET-CVS <cvs@retropc.net>