--- np2/win9x/menu.cpp 2004/02/13 20:31:55 1.12 +++ np2/win9x/menu.cpp 2005/03/24 01:42:46 1.23 @@ -7,70 +7,121 @@ #include "pccore.h" + #define MFCHECK(a) ((a)?MF_CHECKED:MF_UNCHECKED) typedef struct { -const char *str; - int id; -} SMENUITEM; - -static const char smenu_toolwin[] = "&Tool Window"; -static const char smenu_keydisp[] = "&Key display"; -static const char smenu_center[] = "&Centering"; -static const char smenu_snap[] = "&Window Snap"; -static const char smenu_bg[] = "&Background"; -static const char smenu_bgsnd[] = "Background &Sound"; -static const char smenu_320x200[] = " 320x200"; -static const char smenu_480x300[] = " 480x300"; -static const char smenu_640x400[] = " 640x400"; -static const char smenu_800x500[] = " 800x500"; -static const char smenu_960x600[] = " 960x600"; -static const char smenu_1280x800[] = "1280x600"; - -static const char smenu_memdump[] = "&Memory Dump"; -static const char smenu_dbguty[] = "&Debug Utility"; - -static const SMENUITEM smenuitem[] = { - {smenu_toolwin, IDM_TOOLWIN}, - {smenu_keydisp, IDM_KEYDISP}, - {NULL, 0}, - {smenu_center, IDM_SCREENCENTER}, - {smenu_snap, IDM_SNAPENABLE}, - {smenu_bg, IDM_BACKGROUND}, - {smenu_bgsnd, IDM_BGSOUND}, - {NULL, 0}, - {smenu_320x200, IDM_SCRNMUL4}, - {smenu_480x300, IDM_SCRNMUL6}, - {smenu_640x400, IDM_SCRNMUL8}, - {smenu_800x500, IDM_SCRNMUL10}, - {smenu_960x600, IDM_SCRNMUL12}, - {smenu_1280x800, IDM_SCRNMUL16}, - {NULL, 0}}; + UINT16 id; + UINT16 str; +} MENUITEMS; -void sysmenu_initialize(void) { - HMENU hMenu; - UINT i; +// これってAPIあるのか? +void menu_addmenubar(HMENU popup, HMENU menubar) { - hMenu = GetSystemMenu(hWndMain, FALSE); - for (i=0; i<(sizeof(smenuitem)/sizeof(SMENUITEM)); i++) { - if (smenuitem[i].str) { - InsertMenu(hMenu, i, MF_BYPOSITION | MF_STRING, - smenuitem[i].id, smenuitem[i].str); + UINT cnt; + UINT pos; + UINT i; + MENUITEMINFO mii; + TCHAR str[128]; + HMENU hSubMenu; + + cnt = GetMenuItemCount(menubar); + pos = 0; + for (i=0; iid) { + insertresmenu(menu, pos, MF_BYPOSITION | MF_STRING, + item->id, item->str); } else { - InsertMenu(hMenu, i, MF_BYPOSITION | MF_SEPARATOR, 0, NULL); + InsertMenu(menu, pos, MF_BYPOSITION | MF_SEPARATOR, 0, NULL); } + item++; + pos++; } +} + + +// ---- + +static const MENUITEMS smenuitem[] = { + {IDM_TOOLWIN, IDS_TOOLWIN}, +#if defined(SUPPORT_KEYDISP) + {IDM_KEYDISP, IDS_KEYDISP}, +#endif +#if defined(SUPPORT_SOFTKBD) + {IDM_SOFTKBD, IDS_SOFTKBD}, +#endif + {0, 0}, + {IDM_SCREENCENTER, IDS_SCREENCENTER}, + {IDM_SNAPENABLE, IDS_SNAPENABLE}, + {IDM_BACKGROUND, IDS_BACKGROUND}, + {IDM_BGSOUND, IDS_BGSOUND}, + {0, 0}, + {IDM_SCRNMUL4, IDS_SCRNMUL4}, + {IDM_SCRNMUL6, IDS_SCRNMUL6}, + {IDM_SCRNMUL8, IDS_SCRNMUL8}, + {IDM_SCRNMUL10, IDS_SCRNMUL10}, + {IDM_SCRNMUL12, IDS_SCRNMUL12}, + {IDM_SCRNMUL16, IDS_SCRNMUL16}, + {0, 0}}; + +static const MENUITEMS smenuitem2[] = { +#if defined(CPUCORE_IA32) && defined(SUPPORT_MEMDBG32) + {IDM_MEMDBG32, IDS_MEMDBG32}, +#endif + {IDM_MEMORYDUMP, IDS_MEMORYDUMP}, + {IDM_DEBUGUTY, IDS_DEBUGUTY}, + {0, 0}}; + + +void sysmenu_initialize(void) { + + HMENU hMenu; + + hMenu = GetSystemMenu(hWndMain, FALSE); + insertresmenus(hMenu, 0, smenuitem, NELEMENTS(smenuitem)); if (np2oscfg.I286SAVE) { - InsertMenu(hMenu, 7, MF_BYPOSITION | MF_STRING, IDM_MEMORYDUMP, - smenu_memdump); - InsertMenu(hMenu, 8, MF_BYPOSITION | MF_STRING, IDM_DEBUGUTY, - smenu_dbguty); + insertresmenus(hMenu, 0, smenuitem2, NELEMENTS(smenuitem2)); } } -void sysmenu_settoolwin(BYTE value) { +void sysmenu_settoolwin(UINT8 value) { value &= 1; np2oscfg.toolwin = value; @@ -78,7 +129,7 @@ void sysmenu_settoolwin(BYTE value) { IDM_TOOLWIN, MFCHECK(value)); } -void sysmenu_setkeydisp(BYTE value) { +void sysmenu_setkeydisp(UINT8 value) { value &= 1; np2oscfg.keydisp = value; @@ -86,7 +137,7 @@ void sysmenu_setkeydisp(BYTE value) { IDM_KEYDISP, MFCHECK(value)); } -void sysmenu_setwinsnap(BYTE value) { +void sysmenu_setwinsnap(UINT8 value) { value &= 1; np2oscfg.WINSNAP = value; @@ -94,7 +145,7 @@ void sysmenu_setwinsnap(BYTE value) { IDM_SNAPENABLE, MFCHECK(value)); } -void sysmenu_setbackground(BYTE value) { +void sysmenu_setbackground(UINT8 value) { HMENU hmenu; @@ -111,7 +162,7 @@ void sysmenu_setbackground(BYTE value) { } } -void sysmenu_setbgsound(BYTE value) { +void sysmenu_setbgsound(UINT8 value) { np2oscfg.background &= 1; np2oscfg.background |= (value & 2); @@ -119,7 +170,7 @@ void sysmenu_setbgsound(BYTE value) { IDM_BGSOUND, MFCHECK((value & 2) ^ 2)); } -void sysmenu_setscrnmul(BYTE value) { +void sysmenu_setscrnmul(UINT8 value) { HMENU hmenu; @@ -136,84 +187,92 @@ void sysmenu_setscrnmul(BYTE value) { // ---- -// これってAPIあるのか? -void menu_addmenubar(HMENU popup, HMENU menubar) { - - UINT cnt; - UINT pos; - UINT i; - MENUITEMINFO mii; - char str[128]; - HMENU hSubMenu; - - cnt = GetMenuItemCount(menubar); - pos = 0; - for (i=0; iitem, smi->items); + insertresmenu(hMenu, pos, MF_BYPOSITION | MF_POPUP, + (UINT)hSubMenu, smi->title); } -#endif + #if defined(SUPPORT_STATSAVE) -static const char xmenu_stat[] = "S&tat"; -static const char xmenu_statsave[] = "Save %u"; -static const char xmenu_statload[] = "Load %u"; +static const TCHAR xmenu_stat[] = _T("S&tat"); +static const TCHAR xmenu_statsave[] = _T("Save %u"); +static const TCHAR xmenu_statload[] = _T("Load %u"); -static void addstatsavemenu(HMENU hMenu) { +static void addstatsavemenu(HMENU hMenu, UINT pos) { HMENU hSubMenu; UINT i; - char buf[16]; + TCHAR buf[16]; hSubMenu = CreatePopupMenu(); for (i=0; i0;) { + i--; + if (np2cfg.fddequip & (1 << i)) { + insdiskmenu(hMenu, 1, fddmenu + i); + } + } - // めにゅー追加 #if defined(SUPPORT_STATSAVE) if (np2oscfg.statsave) { - addstatsavemenu(hMenu); + addstatsavemenu(hMenu, 1); } #endif - - if (np2oscfg.I286SAVE) { - hSubMenu = GetSubMenu(hMenu, 6); - InsertMenu(hSubMenu, 10, - MF_BYPOSITION | MF_STRING, IDM_I286SAVE, xmenu_i286save); - } } void xmenu_disablewindow(void) { @@ -257,7 +340,7 @@ void xmenu_disablewindow(void) { EnableMenuItem(hmenu, IDM_FULLSCREEN, MF_GRAYED); } -void xmenu_setroltate(BYTE value) { +void xmenu_setroltate(UINT8 value) { HMENU hmenu; @@ -267,28 +350,28 @@ void xmenu_setroltate(BYTE value) { CheckMenuItem(hmenu, IDM_ROLRIGHT, MFCHECK(value == 2)); } -void xmenu_setdispmode(BYTE value) { +void xmenu_setdispmode(UINT8 value) { value &= 1; np2cfg.DISPSYNC = value; CheckMenuItem(np2class_gethmenu(hWndMain), IDM_DISPSYNC, MFCHECK(value)); } -void xmenu_setraster(BYTE value) { +void xmenu_setraster(UINT8 value) { value &= 1; np2cfg.RASTER = value; CheckMenuItem(np2class_gethmenu(hWndMain), IDM_RASTER, MFCHECK(value)); } -void xmenu_setwaitflg(BYTE value) { +void xmenu_setwaitflg(UINT8 value) { value &= 1; np2oscfg.NOWAIT = value; CheckMenuItem(np2class_gethmenu(hWndMain), IDM_NOWAIT, MFCHECK(value)); } -void xmenu_setframe(BYTE value) { +void xmenu_setframe(UINT8 value) { HMENU hmenu; @@ -301,7 +384,7 @@ void xmenu_setframe(BYTE value) { CheckMenuItem(hmenu, IDM_15FPS, MFCHECK(value == 4)); } -void xmenu_setkey(BYTE value) { +void xmenu_setkey(UINT8 value) { HMENU hmenu; @@ -315,7 +398,7 @@ void xmenu_setkey(BYTE value) { CheckMenuItem(hmenu, IDM_JOY2, MFCHECK(value == 2)); } -void xmenu_setxshift(BYTE value) { +void xmenu_setxshift(UINT8 value) { HMENU hmenu; @@ -326,7 +409,7 @@ void xmenu_setxshift(BYTE value) { CheckMenuItem(hmenu, IDM_XGRPH, MFCHECK(value & 4)); } -void xmenu_setf12copy(BYTE value) { +void xmenu_setf12copy(UINT8 value) { HMENU hmenu; @@ -344,7 +427,7 @@ void xmenu_setf12copy(BYTE value) { CheckMenuItem(hmenu, IDM_USERKEY2, MFCHECK(value == 6)); } -void xmenu_setbeepvol(BYTE value) { +void xmenu_setbeepvol(UINT8 value) { HMENU hmenu; @@ -357,7 +440,7 @@ void xmenu_setbeepvol(BYTE value) { CheckMenuItem(hmenu, IDM_BEEPHIGH, MFCHECK(value == 3)); } -void xmenu_setsound(BYTE value) { +void xmenu_setsound(UINT8 value) { HMENU hmenu; @@ -376,21 +459,21 @@ void xmenu_setsound(BYTE value) { CheckMenuItem(hmenu, IDM_AMD98, MFCHECK(value == 0x80)); } -void xmenu_setjastsound(BYTE value) { +void xmenu_setjastsound(UINT8 value) { value &= 1; np2oscfg.jastsnd = value; CheckMenuItem(np2class_gethmenu(hWndMain), IDM_JASTSOUND, MFCHECK(value)); } -void xmenu_setmotorflg(BYTE value) { +void xmenu_setmotorflg(UINT8 value) { value &= 1; np2cfg.MOTOR = value; CheckMenuItem(np2class_gethmenu(hWndMain), IDM_SEEKSND, MFCHECK(value)); } -void xmenu_setextmem(BYTE value) { +void xmenu_setextmem(UINT8 value) { HMENU hmenu; @@ -401,22 +484,34 @@ void xmenu_setextmem(BYTE value) { CheckMenuItem(hmenu, IDM_MEM16, MFCHECK(value == 1)); CheckMenuItem(hmenu, IDM_MEM36, MFCHECK(value == 3)); CheckMenuItem(hmenu, IDM_MEM76, MFCHECK(value == 7)); + CheckMenuItem(hmenu, IDM_MEM116, MFCHECK(value == 11)); + CheckMenuItem(hmenu, IDM_MEM136, MFCHECK(value == 13)); } -void xmenu_setmouse(BYTE value) { +void xmenu_setmouse(UINT8 value) { value &= 1; np2oscfg.MOUSE_SW = value; CheckMenuItem(np2class_gethmenu(hWndMain), IDM_MOUSE, MFCHECK(value)); } -void xmenu_sets98logging(BYTE value) { +#if defined(SUPPORT_S98) +void xmenu_sets98logging(UINT8 value) { CheckMenuItem(np2class_gethmenu(hWndMain), IDM_S98LOGGING, MFCHECK(value)); } +#endif + +#if defined(SUPPORT_WAVEREC) +void xmenu_setwaverec(UINT8 value) { + + CheckMenuItem(np2class_gethmenu(hWndMain), + IDM_WAVEREC, MFCHECK(value)); +} +#endif -void xmenu_setshortcut(BYTE value) { +void xmenu_setshortcut(UINT8 value) { HMENU hmenu; @@ -426,7 +521,7 @@ void xmenu_setshortcut(BYTE value) { CheckMenuItem(hmenu, IDM_ALTF4, MFCHECK(value & 2)); } -void xmenu_setdispclk(BYTE value) { +void xmenu_setdispclk(UINT8 value) { HMENU hmenu; @@ -439,28 +534,28 @@ void xmenu_setdispclk(BYTE value) { sysmng_updatecaption(3); } -void xmenu_setbtnmode(BYTE value) { +void xmenu_setbtnmode(UINT8 value) { value &= 1; np2cfg.BTN_MODE = value; CheckMenuItem(np2class_gethmenu(hWndMain), IDM_JOYX, MFCHECK(value)); } -void xmenu_setbtnrapid(BYTE value) { +void xmenu_setbtnrapid(UINT8 value) { value &= 1; np2cfg.BTN_RAPID = value; CheckMenuItem(np2class_gethmenu(hWndMain), IDM_RAPID, MFCHECK(value)); } -void xmenu_setmsrapid(BYTE value) { +void xmenu_setmsrapid(UINT8 value) { value &= 1; np2cfg.MOUSERAPID = value; CheckMenuItem(np2class_gethmenu(hWndMain), IDM_MSRAPID, MFCHECK(value)); } -void xmenu_setsstp(BYTE value) { +void xmenu_setsstp(UINT8 value) { value &= 1; np2oscfg.sstp = value;