| version 1.19, 2003/10/25 16:01:21 | version 1.34, 2003/11/11 16:33:50 | 
| Line 30 | Line 30 | 
 | #include        "mousemng.h" | #include        "mousemng.h" | 
 | #include        "configure.h" | #include        "configure.h" | 
 | #include        "screenopt.h" | #include        "screenopt.h" | 
 |  | #include        "soundopt.h" | 
 |  | #include        "macnewdisk.h" | 
 |  | #include        "fdefine.h" | 
 |  | #include        "hid.h" | 
 |  | #include        "midiopt.h" | 
 |  | #include        "macalert.h" | 
 |  | #include        "np2opening.h" | 
 |  | #include        "toolwin.h" | 
 |  | #include        "aboutdlg.h" | 
 |  |  | 
 |  |  | 
 | #define USE_RESUME |  | 
 | // #define      NP2OPENING |  | 
 |  |  | 
 | #ifdef          NP2OPENING |  | 
 | #include        <QuickTime/QuickTime.h> | #include        <QuickTime/QuickTime.h> | 
| #define         OPENING_WAIT            1500 | #define USE_RESUME | 
| #endif | #define NP2OPENING | 
|  | // #define      OPENING_WAIT    1500 | 
 |  |  | 
 |  |  | 
 | NP2OSCFG        np2oscfg = {0, 2, 0, 0, 0, 0, 1, 0}; | NP2OSCFG        np2oscfg = {0, 2, 0, 0, 0, 0, 1, 0}; | 
| Line 49 | Line 53 | 
 | static  UINT            framecnt = 0; | static  UINT            framecnt = 0; | 
 | static  UINT            waitcnt = 0; | static  UINT            waitcnt = 0; | 
 | static  UINT            framemax = 1; | static  UINT            framemax = 1; | 
| static  BYTE            scrnmode; | BYTE            scrnmode; | 
 |  |  | 
 |  |  | 
 | #define DRAG_THRESHOLD          5 | #define DRAG_THRESHOLD          5 | 
| Line 67  static const char np2resume[] = "sav"; | Line 71  static const char np2resume[] = "sav"; | 
 |  |  | 
 | // ---- おまじない | // ---- おまじない | 
 |  |  | 
 | #if TARGET_CARBON |  | 
 | #define AEProc(fn)      NewAEEventHandlerUPP((AEEventHandlerProcPtr)(fn)) | #define AEProc(fn)      NewAEEventHandlerUPP((AEEventHandlerProcPtr)(fn)) | 
 | #else |  | 
 | #define AEProc(fn)      NewAEEventHandlerProc(fn) |  | 
 | #endif |  | 
 |  |  | 
 | static void setUpCarbonEvent(void); | static void setUpCarbonEvent(void); | 
 |  | static bool setupMainWindow(void); | 
 |  | static void toggleFullscreen(void); | 
 |  |  | 
 | #ifdef TARGET_API_MAC_CARBON |  | 
 | static pascal OSErr handleQuitApp(const AppleEvent *event, AppleEvent *reply, | static pascal OSErr handleQuitApp(const AppleEvent *event, AppleEvent *reply, | 
 | long refcon) { | long refcon) { | 
 |  |  | 
| Line 84  static pascal OSErr handleQuitApp(const | Line 85  static pascal OSErr handleQuitApp(const | 
 | (void)event, (void)reply, (void)refcon; | (void)event, (void)reply, (void)refcon; | 
 | return(noErr); | return(noErr); | 
 | } | } | 
| #endif |  | 
|  | pascal OSErr OpenAppleEventHandler(const AppleEvent *event, AppleEvent *reply,long print) | 
|  | { | 
|  | long            i,ct,len; | 
|  | FSSpec          fsc,*pp; | 
|  | DescType        rtype; | 
|  | AEKeyword       key; | 
|  | AEDescList      dlist; | 
|  |  | 
|  | if(!AEGetParamDesc(event,keyDirectObject,typeAEList,&dlist))    { | 
|  | AECountItems( &dlist,&ct ); | 
|  | for( i=1;i<=ct;i++ )    { | 
|  | pp=&fsc; | 
|  | if (!AEGetNthPtr( &dlist,i,typeFSS,&key,&rtype,(Ptr)pp,(long)sizeof(FSSpec),&len))      { | 
|  | setDropFile(fsc, i-1); | 
|  | } | 
|  | } | 
|  | AEDisposeDesc( &dlist ); | 
|  | } | 
|  | return( 0 ); | 
|  | } | 
|  |  | 
 |  |  | 
 | static void InitToolBox(void) { | static void InitToolBox(void) { | 
 |  |  | 
 | #if !TARGET_CARBON |  | 
 | MaxApplZone(); |  | 
 | InitGraf(&qd.thePort); |  | 
 | InitFonts(); |  | 
 | InitWindows(); |  | 
 | InitMenus(); |  | 
 | TEInit(); |  | 
 | InitDialogs(0); |  | 
 | #endif |  | 
 | FlushEvents(everyEvent, 0); | FlushEvents(everyEvent, 0); | 
 | InitCursor(); | InitCursor(); | 
 |  |  | 
 | #ifdef TARGET_API_MAC_CARBON |  | 
 | AEInstallEventHandler(kCoreEventClass, kAEQuitApplication, | AEInstallEventHandler(kCoreEventClass, kAEQuitApplication, | 
 | AEProc(handleQuitApp), 0L, false); | AEProc(handleQuitApp), 0L, false); | 
| #endif | AEInstallEventHandler(kCoreEventClass, kAEOpenDocuments, | 
|  | AEProc(OpenAppleEventHandler), 0L, false); | 
 | } | } | 
 |  |  | 
 | static void MenuBarInit(void) { | static void MenuBarInit(void) { | 
| #if 0 | #if 1 | 
 | Handle          hMenu; | Handle          hMenu; | 
 | MenuHandle      happlemenu; | MenuHandle      happlemenu; | 
 |  |  | 
| Line 125  static void MenuBarInit(void) { | Line 138  static void MenuBarInit(void) { | 
 | InsertMenu(GetMenu(IDM_KEYBOARD), -1); | InsertMenu(GetMenu(IDM_KEYBOARD), -1); | 
 | InsertMenu(GetMenu(IDM_SOUND), -1); | InsertMenu(GetMenu(IDM_SOUND), -1); | 
 | InsertMenu(GetMenu(IDM_MEMORY), -1); | InsertMenu(GetMenu(IDM_MEMORY), -1); | 
 |  | ChangeMenuAttributes(GetMenuRef(IDM_EDIT), kMenuAttrAutoDisable, 0); | 
 |  | DisableAllMenuItems(GetMenuHandle(IDM_EDIT)); | 
 |  | SetMenuItemModifiers(GetMenuRef(IDM_FDD2), IDM_FDD2OPEN, kMenuOptionModifier); | 
 |  | SetMenuItemModifiers(GetMenuRef(IDM_FDD2), IDM_FDD2EJECT, kMenuOptionModifier); | 
 |  | SetMenuItemModifiers(GetMenuRef(IDM_SASI2), IDM_SASI2OPEN, kMenuOptionModifier); | 
 | DrawMenuBar(); | DrawMenuBar(); | 
| #endif | #else | 
 | OSStatus    err; | OSStatus    err; | 
 | IBNibRef    nibRef; | IBNibRef    nibRef; | 
 | err = CreateNibReference(CFSTR("np2"), &nibRef); | err = CreateNibReference(CFSTR("np2"), &nibRef); | 
 | if (err!=noErr) return; | if (err!=noErr) return; | 
 | err = SetMenuBarFromNib(nibRef, CFSTR("MainMenu")); | err = SetMenuBarFromNib(nibRef, CFSTR("MainMenu")); | 
 | DisposeNibReference(nibRef); | DisposeNibReference(nibRef); | 
 |  | #endif | 
 | } | } | 
 |  |  | 
 | static void changescreen(BYTE mode) { | static void changescreen(BYTE mode) { | 
 |  |  | 
| (void)mode; | BYTE    change; | 
|  | BYTE    renewal; | 
|  |  | 
|  | change = scrnmode ^ mode; | 
|  | renewal = (change & SCRNMODE_FULLSCREEN); | 
|  | if (mode & SCRNMODE_FULLSCREEN) { | 
|  | renewal |= (change & SCRNMODE_HIGHCOLOR); | 
|  | } | 
|  | else { | 
|  | renewal |= (change & SCRNMODE_ROTATEMASK); | 
|  | } | 
|  | if (renewal) { | 
|  | soundmng_stop(); | 
|  | mouse_running(MOUSE_STOP); | 
|  | scrnmng_destroy(); | 
|  | if (scrnmng_create(mode) == SUCCESS) { | 
|  | scrnmode = mode; | 
|  | } | 
|  | scrndraw_redraw(); | 
|  | mouse_running(MOUSE_CONT); | 
|  | soundmng_play(); | 
|  | } | 
|  | else { | 
|  | scrnmode = mode; | 
|  | } | 
 | } | } | 
 |  |  | 
 | static void HandleMenuChoice(long wParam) { | static void HandleMenuChoice(long wParam) { | 
 |  |  | 
 | UINT    update; | UINT    update; | 
 | Str255  applname; |  | 
 |  |  | 
 |  | soundmng_stop(); | 
 | update = 0; | update = 0; | 
 | switch(wParam) { | switch(wParam) { | 
 | case IDM_ABOUT: | case IDM_ABOUT: | 
| Line 152  static void HandleMenuChoice(long wParam | Line 195  static void HandleMenuChoice(long wParam | 
 | break; | break; | 
 |  |  | 
 | case IDM_RESET: | case IDM_RESET: | 
| pccore_cfgupdate(); | if (ResetWarningDialogProc()) { | 
| pccore_reset(); | pccore_cfgupdate(); | 
|  | pccore_reset(); | 
|  | } | 
 | break; | break; | 
 |  |  | 
 | case IDM_CONFIGURE: | case IDM_CONFIGURE: | 
 | initConfig(); | initConfig(); | 
 | break; | break; | 
 |  |  | 
| #if 0 | case IDM_NEWDISK: | 
| case IDM_NEWFDD: | newdisk(); | 
| newdisk(); |  | 
| break; |  | 
| #endif |  | 
| #if 0 |  | 
| case IDM_NEWHDD: |  | 
| newhdddisk(); |  | 
 | break; | break; | 
 | #endif |  | 
 |  |  | 
 | case IDM_FONT: | case IDM_FONT: | 
 | dialog_font(); | dialog_font(); | 
 | break; | break; | 
 |  |  | 
 | case IDM_EXIT: | case IDM_EXIT: | 
| np2running = FALSE; | taskmng_exit(); | 
 | break; | break; | 
 |  |  | 
 | case IDM_FDD1OPEN: | case IDM_FDD1OPEN: | 
| Line 185  static void HandleMenuChoice(long wParam | Line 223  static void HandleMenuChoice(long wParam | 
 |  |  | 
 | case IDM_FDD1EJECT: | case IDM_FDD1EJECT: | 
 | diskdrv_setfdd(0, NULL, 0); | diskdrv_setfdd(0, NULL, 0); | 
 |  | toolwin_setfdd(0, NULL); | 
 | break; | break; | 
 |  |  | 
 | case IDM_FDD2OPEN: | case IDM_FDD2OPEN: | 
| Line 193  static void HandleMenuChoice(long wParam | Line 232  static void HandleMenuChoice(long wParam | 
 |  |  | 
 | case IDM_FDD2EJECT: | case IDM_FDD2EJECT: | 
 | diskdrv_setfdd(1, NULL, 0); | diskdrv_setfdd(1, NULL, 0); | 
 |  | toolwin_setfdd(1, NULL); | 
 | break; | break; | 
 |  |  | 
 | case IDM_SASI1OPEN: | case IDM_SASI1OPEN: | 
| Line 211  static void HandleMenuChoice(long wParam | Line 251  static void HandleMenuChoice(long wParam | 
 | diskdrv_sethdd(1, NULL); | diskdrv_sethdd(1, NULL); | 
 | break; | break; | 
 |  |  | 
 |  | case IDM_FULLSCREEN: | 
 |  | toggleFullscreen(); | 
 |  | break; | 
 |  |  | 
 | case IDM_ROLNORMAL: | case IDM_ROLNORMAL: | 
 | menu_setrotate(0); | menu_setrotate(0); | 
 | changescreen(scrnmode & (~SCRNMODE_ROTATEMASK)); | changescreen(scrnmode & (~SCRNMODE_ROTATEMASK)); | 
| Line 268  static void HandleMenuChoice(long wParam | Line 312  static void HandleMenuChoice(long wParam | 
 | update |= SYS_UPDATECFG; | update |= SYS_UPDATECFG; | 
 | break; | break; | 
 |  |  | 
 | #if defined(NP2GCC) |  | 
 | case IDM_SCREENOPT: | case IDM_SCREENOPT: | 
 | initScreenOpt(); | initScreenOpt(); | 
 | break; | break; | 
| Line 278  static void HandleMenuChoice(long wParam | Line 321  static void HandleMenuChoice(long wParam | 
 | menu_setmouse(np2oscfg.MOUSE_SW ^ 1); | menu_setmouse(np2oscfg.MOUSE_SW ^ 1); | 
 | sysmng_update(SYS_UPDATECFG); | sysmng_update(SYS_UPDATECFG); | 
 | break; | break; | 
| #endif |  | 
|  | case IDM_MIDIOPT: | 
|  | initMidiOpt(); | 
|  | break; | 
|  |  | 
|  | case IDM_MIDIPANIC: | 
|  | rs232c_midipanic(); | 
|  | mpu98ii_midipanic(); | 
|  | pc9861k_midipanic(); | 
|  | break; | 
|  |  | 
|  | case IDM_SNDOPT: | 
|  | initSoundOpt(); | 
|  | break; | 
 |  |  | 
 | case IDM_KEY: | case IDM_KEY: | 
 | menu_setkey(0); | menu_setkey(0); | 
| Line 317  static void HandleMenuChoice(long wParam | Line 373  static void HandleMenuChoice(long wParam | 
 |  |  | 
 | case IDM_F12MOUSE: | case IDM_F12MOUSE: | 
 | menu_setf12copy(0); | menu_setf12copy(0); | 
| keystat_resetcopyhelp(); | mackbd_resetf12(); | 
 | update |= SYS_UPDATECFG; | update |= SYS_UPDATECFG; | 
 | break; | break; | 
 |  |  | 
 | case IDM_F12COPY: | case IDM_F12COPY: | 
 | menu_setf12copy(1); | menu_setf12copy(1); | 
| keystat_resetcopyhelp(); | mackbd_resetf12(); | 
 | update |= SYS_UPDATECFG; | update |= SYS_UPDATECFG; | 
 | break; | break; | 
 |  |  | 
 | case IDM_F12STOP: | case IDM_F12STOP: | 
 | menu_setf12copy(2); | menu_setf12copy(2); | 
| keystat_resetcopyhelp(); | mackbd_resetf12(); | 
|  | update |= SYS_UPDATECFG; | 
|  | break; | 
|  |  | 
|  | case IDM_F12EQU: | 
|  | menu_setf12copy(3); | 
|  | mackbd_resetf12(); | 
|  | update |= SYS_UPDATECFG; | 
|  | break; | 
|  |  | 
|  | case IDM_F12COMMA: | 
|  | menu_setf12copy(4); | 
|  | mackbd_resetf12(); | 
 | update |= SYS_UPDATECFG; | update |= SYS_UPDATECFG; | 
 | break; | break; | 
 |  |  | 
| Line 402  static void HandleMenuChoice(long wParam | Line 470  static void HandleMenuChoice(long wParam | 
 | update |= SYS_UPDATECFG; | update |= SYS_UPDATECFG; | 
 | break; | break; | 
 |  |  | 
 |  | case IDM_AMD98: | 
 |  | menu_setsound(0x80); | 
 |  | update |= SYS_UPDATECFG; | 
 |  | break; | 
 |  |  | 
 | case IDM_SEEKSND: | case IDM_SEEKSND: | 
 | menu_setmotorflg(np2cfg.MOTOR ^ 1); | menu_setmotorflg(np2cfg.MOTOR ^ 1); | 
 | update |= SYS_UPDATECFG; | update |= SYS_UPDATECFG; | 
| Line 427  static void HandleMenuChoice(long wParam | Line 500  static void HandleMenuChoice(long wParam | 
 | update |= SYS_UPDATECFG; | update |= SYS_UPDATECFG; | 
 | break; | break; | 
 |  |  | 
 |  | case IDM_BMPSAVE: | 
 |  | dialog_writebmp(); | 
 |  | break; | 
 |  |  | 
 |  | case IDM_S98LOGGING: | 
 |  | dialog_s98(); | 
 |  | break; | 
 |  |  | 
 | case IDM_DISPCLOCK: | case IDM_DISPCLOCK: | 
 | menu_setdispclk(np2oscfg.DISPCLK ^ 1); | menu_setdispclk(np2oscfg.DISPCLK ^ 1); | 
 | update |= SYS_UPDATECFG; | update |= SYS_UPDATECFG; | 
| Line 447  static void HandleMenuChoice(long wParam | Line 528  static void HandleMenuChoice(long wParam | 
 | update |= SYS_UPDATECFG; | update |= SYS_UPDATECFG; | 
 | break; | break; | 
 |  |  | 
 |  | case IDM_MSRAPID: | 
 |  | menu_setmsrapid(np2cfg.MOUSERAPID ^ 1); | 
 |  | update |= SYS_UPDATECFG; | 
 |  | break; | 
 |  | case IDM_RECORDING: | 
 |  | menu_setrecording(false); | 
 |  | break; | 
 |  |  | 
 |  |  | 
 | case IDM_I286SAVE: | case IDM_I286SAVE: | 
 | debugsub_status(); | debugsub_status(); | 
 | break; | break; | 
 |  |  | 
 |  | case IDM_NP2HELP: | 
 |  | { | 
 |  | ICInstance inst; | 
 |  | long start, fin; | 
 |  | const char      urlStr[] = "http://retropc.net/tk800/np2x/help.html"; | 
 |  |  | 
 |  | ICStart(&inst, 'SMil'); | 
 |  | start = 0; | 
 |  | fin = strlen(urlStr); | 
 |  | ICLaunchURL(inst, "\p", urlStr, strlen(urlStr), &start, &fin); | 
 |  | ICStop(inst); | 
 |  | } | 
 |  | break; | 
 |  |  | 
 | default: | default: | 
 | if (HiWord(wParam) == IDM_APPLE) { |  | 
 | GetMenuItemText(GetMenuHandle(IDM_APPLE), |  | 
 | LoWord(wParam), applname); |  | 
 | #if !TARGET_API_MAC_CARBON |  | 
 | (void)OpenDeskAcc(applname); |  | 
 | #endif |  | 
 | } |  | 
 | break; | break; | 
 | } | } | 
 | sysmng_update(update); | sysmng_update(update); | 
 | HiliteMenu(0); | HiliteMenu(0); | 
 | } | } | 
 |  |  | 
 | #if 0 |  | 
 | static void HandleUpdateEvent(EventRecord *pevent) { |  | 
 |  |  | 
 | WindowPtr       hWnd; |  | 
 |  |  | 
 | hWnd = (WindowPtr)pevent->message; |  | 
 | BeginUpdate(hWnd); |  | 
 | scrndraw_redraw(); |  | 
 | EndUpdate(hWnd); |  | 
 | } |  | 
 | #endif |  | 
 |  |  | 
 | static void HandleMouseDown(EventRecord *pevent) { | static void HandleMouseDown(EventRecord *pevent) { | 
 |  |  | 
 | WindowPtr       hWnd; | WindowPtr       hWnd; | 
| Rect            rDrag; | BYTE                ret; | 
|  |  | 
| soundmng_stop(); |  | 
| switch(FindWindow(pevent->where, &hWnd)) { |  | 
| case inMenuBar: |  | 
| HandleMenuChoice(MenuSelect(pevent->where)); |  | 
| break; |  | 
|  |  | 
| case inDrag: |  | 
| #if TARGET_API_MAC_CARBON |  | 
| { |  | 
| BitMap  gscreenBits; |  | 
| GetQDGlobalsScreenBits(&gscreenBits); |  | 
| rDrag = gscreenBits.bounds; |  | 
| InsetRect(&rDrag, DRAG_THRESHOLD, DRAG_THRESHOLD); |  | 
| DragWindow(hWnd, pevent->where, &rDrag); |  | 
| } |  | 
| #else |  | 
| rDrag = qd.screenBits.bounds; |  | 
| InsetRect(&rDrag, DRAG_THRESHOLD, DRAG_THRESHOLD); |  | 
| DragWindow(hWnd, pevent->where, &rDrag); |  | 
| #endif |  | 
| break; |  | 
 |  |  | 
| case inContent: | if (FindWindow(pevent->where, &hWnd) == inMenuBar) { | 
| #if defined(NP2GCC) | soundmng_stop(); | 
| if (controlKey & GetCurrentKeyModifiers() ) { | HandleMenuChoice(MenuSelect(pevent->where)); | 
| mouse_btn(MOUSE_RIGHTDOWN); | } | 
| } | else { | 
| else { | ret=mouse_btn(MOUSE_LEFTDOWN); | 
| mouse_btn(MOUSE_LEFTDOWN); | } | 
| } |  | 
| #endif |  | 
| break; |  | 
|  |  | 
| #ifndef NP2GCC |  | 
| case inGoAway: |  | 
| if (TrackGoAway(hWnd, pevent->where)) { } |  | 
| np2running = FALSE; |  | 
| break; |  | 
| #endif |  | 
| } |  | 
| soundmng_play(); |  | 
 | } | } | 
 |  |  | 
 | #if 0 |  | 
 | static void eventproc(EventRecord *event) { |  | 
 |  |  | 
 | switch(event->what) { |  | 
 | case mouseDown: |  | 
 | HandleMouseDown(event); |  | 
 | break; |  | 
 |  |  | 
 | case updateEvt: |  | 
 | HandleUpdateEvent(event); |  | 
 | break; |  | 
 |  |  | 
| case keyDown: | // ---- | 
| case autoKey: |  | 
| mackbd_f12down(((event->message) & keyCodeMask) >> 8); |  | 
| if (event->modifiers & cmdKey) { |  | 
| HandleMenuChoice(MenuKey(event->message & charCodeMask)); |  | 
| } |  | 
| break; |  | 
 |  |  | 
| case keyUp: | static void framereset(UINT waitcnt) { | 
| mackbd_f12up(((event->message) & keyCodeMask) >> 8); |  | 
| break; |  | 
 |  |  | 
| #if defined(NP2GCC) | framecnt = 0; | 
| case mouseUp: | toolwin_draw((BYTE)waitcnt); | 
| if (controlKey & GetCurrentKeyModifiers()) { | if (np2oscfg.DISPCLK & 3) { | 
| mouse_btn(MOUSE_RIGHTUP); | if (sysmng_workclockrenewal()) { | 
| } | sysmng_updatecaption(3); | 
| else { | } | 
| mouse_btn(MOUSE_LEFTUP); |  | 
| } |  | 
| break; |  | 
| #endif |  | 
 | } | } | 
 | } | } | 
 | #endif |  | 
 |  |  | 
 | // ---- |  | 
 |  |  | 
 | static void processwait(UINT waitcnt) { | static void processwait(UINT waitcnt) { | 
 |  |  | 
 | if (timing_getcount() >= waitcnt) { | if (timing_getcount() >= waitcnt) { | 
 | framecnt = 0; |  | 
 | timing_setcount(0); | timing_setcount(0); | 
| if (np2oscfg.DISPCLK & 3) { | framereset(waitcnt); | 
| if (sysmng_workclockrenewal()) { |  | 
| sysmng_updatecaption(3); |  | 
| } |  | 
| } |  | 
 | } | } | 
 | } | } | 
 |  |  | 
| Line 593  static void flagsave(const char *ext) { | Line 613  static void flagsave(const char *ext) { | 
 | statsave_save(path); | statsave_save(path); | 
 | } | } | 
 |  |  | 
 |  | static void flagdelete(const char *ext) { | 
 |  |  | 
 |  | char    path[MAX_PATH]; | 
 |  |  | 
 |  | getstatfilename(path, ext, sizeof(path)); | 
 |  | file_delete(path); | 
 |  | } | 
 |  |  | 
 | static void flagload(const char *ext) { | static void flagload(const char *ext) { | 
 |  |  | 
 | char    path[MAX_PATH]; | char    path[MAX_PATH]; | 
 | char    buf[1024]; | char    buf[1024]; | 
| int             ret; | int             ret, r; | 
 |  |  | 
 |  | ret = IDOK; | 
 | getstatfilename(path, ext, sizeof(path)); | getstatfilename(path, ext, sizeof(path)); | 
| ret = statsave_check(path, buf, sizeof(buf)); | r = statsave_check(path, buf, sizeof(buf)); | 
| if (ret == NP2FLAG_SUCCESS) { | if (r & (~NP2FLAG_DISKCHG)) { | 
|  | ResumeErrorDialogProc(); | 
|  | ret = IDCANCEL; | 
|  | } | 
|  | else if (r & NP2FLAG_DISKCHG) { | 
|  | ret = ResumeWarningDialogProc(buf); | 
|  | } | 
|  | if (ret == IDOK) { | 
 | statsave_load(path); | statsave_load(path); | 
 |  | toolwin_setfdd(0, fdd_diskname(0)); | 
 |  | toolwin_setfdd(1, fdd_diskname(1)); | 
 | } | } | 
 |  | return; | 
 | } | } | 
 |  |  | 
 | #ifdef          NP2OPENING |  | 
 | static void openingNP2(void) { |  | 
 | Rect                srt, bounds; |  | 
 | GrafPtr             port; |  | 
 | CFURLRef    openingURL; |  | 
 | CFStringRef path; |  | 
 | char                buffer[1024]; |  | 
 | FSRef               fsr; |  | 
 | FSSpec              fsc; |  | 
 | PicHandle   pict; |  | 
 | GraphicsImportComponent     gi; |  | 
 |  |  | 
 | GetPort(&port); |  | 
 | SetPortWindowPort(hWndMain); |  | 
 | const RGBColor col = {0, 0, 0}; |  | 
 | SetRect(&bounds, 0, 0, 640, 400); |  | 
 | RGBBackColor(&col); |  | 
 | EraseRect(&bounds); |  | 
 |  |  | 
 | openingURL=CFURLCopyAbsoluteURL(CFBundleCopyResourcesDirectoryURL(CFBundleGetMainBundle())); |  | 
 | if (openingURL) { |  | 
 | path = CFURLCopyFileSystemPath(openingURL, kCFURLPOSIXPathStyle); |  | 
 | if (path) { |  | 
 | if (CFStringGetCString(path, buffer, 1024, CFStringGetSystemEncoding())) { |  | 
 | strcat(buffer, "/nekop2.bmp"); |  | 
 | FSPathMakeRef((const UInt8*)buffer, &fsr, NULL); |  | 
 | FSGetCatalogInfo(&fsr, kFSCatInfoNone, NULL, NULL, &fsc, NULL); |  | 
 | if (!GetGraphicsImporterForFile(&fsc, &gi)) { |  | 
 | if (!GraphicsImportGetNaturalBounds(gi, &srt)) { |  | 
 | OffsetRect( &srt, -srt.left, -srt.top); |  | 
 | GraphicsImportSetBoundsRect(gi, &srt); |  | 
 | GraphicsImportGetAsPicture(gi, &pict); |  | 
 | OffsetRect(&srt, (640-srt.right)/2, (400-srt.bottom)/2); |  | 
 | DrawPicture(pict,&srt); |  | 
 | QDFlushPortBuffer(GetWindowPort(hWndMain), NULL); |  | 
 | KillPicture(pict); |  | 
 | } |  | 
 | CloseComponent(gi); |  | 
 | } |  | 
 | } |  | 
 | if (path) CFRelease(path); |  | 
 | } |  | 
 | if (openingURL) CFRelease(openingURL); |  | 
 | } |  | 
 | SetPort(port); |  | 
 | } |  | 
 | #endif |  | 
 |  |  | 
 |  |  | 
 | int main(int argc, char *argv[]) { | int main(int argc, char *argv[]) { | 
 |  |  | 
 | Rect            wRect; |  | 
 | #if 0 |  | 
 | EventRecord     event; |  | 
 | #endif |  | 
 | EventRef            theEvent; | EventRef            theEvent; | 
 | EventTargetRef      theTarget; | EventTargetRef      theTarget; | 
 | #ifdef OPENING_WAIT | #ifdef OPENING_WAIT | 
 | UINT32          tick; | UINT32          tick; | 
 | #endif | #endif | 
|  |  | 
 | dosio_init(); | dosio_init(); | 
 | file_setcd(target); | file_setcd(target); | 
 |  |  | 
| Line 677  int main(int argc, char *argv[]) { | Line 663  int main(int argc, char *argv[]) { | 
 | initload(); | initload(); | 
 |  |  | 
 | TRACEINIT(); | TRACEINIT(); | 
 |  |  | 
 |  | toolwin_readini(); | 
 |  | if (!(setupMainWindow())) { | 
 |  | return(0); | 
 |  | } | 
 |  |  | 
 | SetRect(&wRect, 100, 100, 100, 100); |  | 
 | hWndMain = NewWindow(0, &wRect, "\pNeko Project II", FALSE, |  | 
 | noGrowDocProc, (WindowPtr)-1, TRUE, 0); |  | 
 | if (!hWndMain) { |  | 
 | TRACETERM(); |  | 
 | macossub_term(); |  | 
 | dosio_term(); |  | 
 | return(0); |  | 
 | } |  | 
 | scrnmng_initialize(); |  | 
 | SizeWindow(hWndMain, 640, 400, TRUE); |  | 
 | setUpCarbonEvent(); |  | 
 | ShowWindow(hWndMain); |  | 
 | #ifdef    NP2OPENING | #ifdef    NP2OPENING | 
 | openingNP2(); | openingNP2(); | 
 | #endif | #endif | 
| Line 712  int main(int argc, char *argv[]) { | Line 690  int main(int argc, char *argv[]) { | 
 | menu_setdispclk(np2oscfg.DISPCLK); | menu_setdispclk(np2oscfg.DISPCLK); | 
 | menu_setbtnrapid(np2cfg.BTN_RAPID); | menu_setbtnrapid(np2cfg.BTN_RAPID); | 
 | menu_setbtnmode(np2cfg.BTN_MODE); | menu_setbtnmode(np2cfg.BTN_MODE); | 
 |  | if (np2oscfg.I286SAVE) { | 
 |  | AppendMenuItemTextWithCFString(GetMenuRef(IDM_OTHER), CFCopyLocalizedString(CFSTR("i286 save"),"i286"), kMenuItemAttrIconDisabled, NULL,NULL); | 
 |  | } | 
 |  |  | 
 | scrnmode = 0; | scrnmode = 0; | 
 | if (scrnmng_create(scrnmode) != SUCCESS) { | if (scrnmng_create(scrnmode) != SUCCESS) { | 
| Line 728  int main(int argc, char *argv[]) { | Line 709  int main(int argc, char *argv[]) { | 
 | pccore_init(); | pccore_init(); | 
 | S98_init(); | S98_init(); | 
 |  |  | 
 |  | hid_init(); | 
 |  | if (soundmng_initialize() == SUCCESS) { | 
 |  | soundmng_pcmvolume(SOUND_PCMSEEK, np2cfg.MOTORVOL); | 
 |  | soundmng_pcmvolume(SOUND_PCMSEEK1, np2cfg.MOTORVOL); | 
 |  | } | 
 |  |  | 
 | #if defined(NP2GCC) | #if defined(NP2GCC) | 
 | if (np2oscfg.MOUSE_SW) {                                                                                // ver0.30 | if (np2oscfg.MOUSE_SW) {                                                                                // ver0.30 | 
 | mouse_running(MOUSE_ON); | mouse_running(MOUSE_ON); | 
| Line 736  int main(int argc, char *argv[]) { | Line 723  int main(int argc, char *argv[]) { | 
 | #ifdef OPENING_WAIT | #ifdef OPENING_WAIT | 
 | while((GETTICK() - tick) < OPENING_WAIT); | while((GETTICK() - tick) < OPENING_WAIT); | 
 | #endif | #endif | 
 | scrndraw_redraw(); |  | 
 | pccore_reset(); | pccore_reset(); | 
 |  |  | 
 | #if defined(USE_RESUME) | #if defined(USE_RESUME) | 
| Line 744  int main(int argc, char *argv[]) { | Line 730  int main(int argc, char *argv[]) { | 
 | flagload(np2resume); | flagload(np2resume); | 
 | } | } | 
 | #endif | #endif | 
 |  | if (np2oscfg.toolwin) { | 
 |  | toolwin_open(); | 
 |  | } | 
 |  |  | 
 | #if 0 |  | 
 | SetEventMask(everyEvent); |  | 
 | #endif |  | 
 | theTarget = GetEventDispatcherTarget(); | theTarget = GetEventDispatcherTarget(); | 
 |  |  | 
 | np2running = TRUE; | np2running = TRUE; | 
| Line 757  int main(int argc, char *argv[]) { | Line 743  int main(int argc, char *argv[]) { | 
 | SendEventToEventTarget (theEvent, theTarget); | SendEventToEventTarget (theEvent, theTarget); | 
 | ReleaseEvent(theEvent); | ReleaseEvent(theEvent); | 
 | } | } | 
 | #if 0 |  | 
 | if (WaitNextEvent(everyEvent, &event, 0, 0)) { |  | 
 | eventproc(&event); |  | 
 | } |  | 
 | #endif |  | 
 | else { | else { | 
 |  | soundmng_play(); | 
 | if (np2oscfg.NOWAIT) { | if (np2oscfg.NOWAIT) { | 
 | #if 0 |  | 
 | mackbd_callback(); |  | 
 | #endif |  | 
 | pccore_exec(framecnt == 0); | pccore_exec(framecnt == 0); | 
 | if (np2oscfg.DRAW_SKIP) {                       // nowait frame skip | if (np2oscfg.DRAW_SKIP) {                       // nowait frame skip | 
 | framecnt++; | framecnt++; | 
| Line 783  int main(int argc, char *argv[]) { | Line 762  int main(int argc, char *argv[]) { | 
 | } | } | 
 | else if (np2oscfg.DRAW_SKIP) {                  // frame skip | else if (np2oscfg.DRAW_SKIP) {                  // frame skip | 
 | if (framecnt < np2oscfg.DRAW_SKIP) { | if (framecnt < np2oscfg.DRAW_SKIP) { | 
 | #if 0 |  | 
 | mackbd_callback(); |  | 
 | #endif |  | 
 | pccore_exec(framecnt == 0); | pccore_exec(framecnt == 0); | 
 | framecnt++; | framecnt++; | 
 | } | } | 
| Line 796  int main(int argc, char *argv[]) { | Line 772  int main(int argc, char *argv[]) { | 
 | else {                                                          // auto skip | else {                                                          // auto skip | 
 | if (!waitcnt) { | if (!waitcnt) { | 
 | UINT cnt; | UINT cnt; | 
 | #if 0 |  | 
 | mackbd_callback(); |  | 
 | #endif |  | 
 | pccore_exec(framecnt == 0); | pccore_exec(framecnt == 0); | 
 | framecnt++; | framecnt++; | 
 | cnt = timing_getcount(); | cnt = timing_getcount(); | 
| Line 818  int main(int argc, char *argv[]) { | Line 791  int main(int argc, char *argv[]) { | 
 | else { | else { | 
 | timing_setcount(cnt - framecnt); | timing_setcount(cnt - framecnt); | 
 | } | } | 
| processwait(0); | framereset(0); | 
 | } | } | 
 | } | } | 
 | else { | else { | 
| Line 829  int main(int argc, char *argv[]) { | Line 802  int main(int argc, char *argv[]) { | 
 | } | } | 
 | } | } | 
 | np2running = FALSE; | np2running = FALSE; | 
 |  | menu_setrecording(true); | 
 |  |  | 
 |  | if (scrnmode & SCRNMODE_FULLSCREEN) { | 
 |  | toggleFullscreen(); | 
 |  | } | 
 |  |  | 
 | pccore_cfgupdate(); | pccore_cfgupdate(); | 
 |  |  | 
 | #if defined(USE_RESUME) | #if defined(USE_RESUME) | 
 | if (np2oscfg.resume) { | if (np2oscfg.resume) { | 
 | flagsave(np2resume); | flagsave(np2resume); | 
 | } | } | 
 |  | else { | 
 |  | flagdelete(np2resume); | 
 |  | } | 
 | #endif | #endif | 
 |  |  | 
 | pccore_term(); | pccore_term(); | 
 | S98_trash(); | S98_trash(); | 
 |  |  | 
 |  | hid_clear(); | 
 | #if defined(NP2GCC) | #if defined(NP2GCC) | 
 | mouse_running(MOUSE_OFF); | mouse_running(MOUSE_OFF); | 
 | #endif | #endif | 
 |  |  | 
 |  | soundmng_deinitialize(); | 
 | scrnmng_destroy(); | scrnmng_destroy(); | 
 |  |  | 
 | if (sys_updates & (SYS_UPDATECFG | SYS_UPDATEOSCFG)) { | if (sys_updates & (SYS_UPDATECFG | SYS_UPDATEOSCFG)) { | 
| initsave(); | initsave();                                             // np2.cfg create | 
|  | toolwin_writeini();                         // np2.cfg append | 
 | } | } | 
 | TRACETERM(); | TRACETERM(); | 
 | macossub_term(); | macossub_term(); | 
 | dosio_term(); | dosio_term(); | 
 |  |  | 
 | DisposeWindow(hWndMain); | DisposeWindow(hWndMain); | 
 |  | toolwin_close(); | 
 |  |  | 
 | (void)argc; | (void)argc; | 
 | (void)argv; | (void)argv; | 
| Line 864  int main(int argc, char *argv[]) { | Line 849  int main(int argc, char *argv[]) { | 
 | //以下、ごっそりIIxからマージ | //以下、ごっそりIIxからマージ | 
 | static pascal OSStatus np2appevent (EventHandlerCallRef myHandlerChain, EventRef event, void* userData) | static pascal OSStatus np2appevent (EventHandlerCallRef myHandlerChain, EventRef event, void* userData) | 
 | { | { | 
| UInt32          whatHappened; | OSStatus    result = eventNotHandledErr; | 
| OSStatus        result = eventNotHandledErr; |  | 
 |  |  | 
 | long                eventClass; | long                eventClass; | 
|  | UInt32              whatHappened; | 
 | eventClass = GetEventClass(event); | eventClass = GetEventClass(event); | 
 | whatHappened = GetEventKind(event); | whatHappened = GetEventKind(event); | 
 |  |  | 
| EventRecord         eve; | EventRecord eve; | 
 | ConvertEventRefToEventRecord( event,&eve ); | ConvertEventRefToEventRecord( event,&eve ); | 
 |  |  | 
 | if (IsDialogEvent(&eve)) return result; | if (IsDialogEvent(&eve)) return result; | 
 |  |  | 
| UInt32 modif; | UInt32              modif; | 
 | GetEventParameter (event, kEventParamKeyModifiers, typeUInt32, NULL, sizeof(UInt32), NULL, &modif); | GetEventParameter (event, kEventParamKeyModifiers, typeUInt32, NULL, sizeof(UInt32), NULL, &modif); | 
 |  |  | 
 | #if defined(NP2GCC) | #if defined(NP2GCC) | 
| HIPoint delta; | HIPoint             delta; | 
 | EventMouseButton buttonKind; | EventMouseButton buttonKind; | 
 | GetEventParameter (event, kEventParamMouseButton, typeMouseButton, NULL, sizeof(EventMouseButton), NULL, &buttonKind); | GetEventParameter (event, kEventParamMouseButton, typeMouseButton, NULL, sizeof(EventMouseButton), NULL, &buttonKind); | 
 |  |  | 
| Line 889  static pascal OSStatus np2appevent (Even | Line 872  static pascal OSStatus np2appevent (Even | 
 | #endif | #endif | 
 |  |  | 
 | switch (eventClass) | switch (eventClass) | 
| { | { | 
| case kEventClassAppleEvent: | case kEventClassCommand: | 
| if (whatHappened == kEventAppleEvent) { | if (GetEventKind(event)==kEventCommandProcess) { | 
| AEProcessAppleEvent(&eve); | HICommand       cmd; | 
| } | GetEventParameter(event, kEventParamDirectObject, typeHICommand, NULL, sizeof(HICommand), NULL, &cmd); | 
| break; | if (cmd.commandID == kHICommandAppHelp) { | 
|  | ICInstance inst; | 
|  | long start, fin; | 
|  | const char  urlStr[] = "http://retropc.net/tk800/np2x/help.html"; | 
|  |  | 
|  | ICStart(&inst, '????'); | 
|  | start = 0; | 
|  | fin = strlen(urlStr); | 
|  | ICLaunchURL(inst, "\p", urlStr, strlen(urlStr), &start, &fin); | 
|  | ICStop(inst); | 
|  | } | 
|  | } | 
|  | break; | 
|  |  | 
|  | case kEventClassAppleEvent: | 
|  | if (whatHappened == kEventAppleEvent) { | 
|  | AEProcessAppleEvent(&eve); | 
|  | } | 
|  | break; | 
 |  |  | 
| case kEventClassMouse: | case kEventClassMouse: | 
 | #if defined(NP2GCC) | #if defined(NP2GCC) | 
| switch (whatHappened) | switch (whatHappened) | 
| { | { | 
| case kEventMouseMoved: | case kEventMouseMoved: | 
| GetEventParameter (event, kEventParamMouseDelta, typeHIPoint, NULL, sizeof(HIPoint), NULL, &delta); | GetEventParameter (event, kEventParamMouseDelta, typeHIPoint, NULL, sizeof(HIPoint), NULL, &delta); | 
| mouse_callback(delta); | mouse_callback(delta); | 
| result = noErr; | result = noErr; | 
| break; | break; | 
| case kEventMouseDown: | case kEventMouseDown: | 
| if (buttonKind == kEventMouseButtonSecondary | modif & controlKey) { | if (buttonKind == kEventMouseButtonSecondary | modif & controlKey) { | 
| ret=mouse_btn(MOUSE_RIGHTDOWN); | ret=mouse_btn(MOUSE_RIGHTDOWN); | 
| } | } | 
| else { | else { | 
| HandleMouseDown(&eve); | HandleMouseDown(&eve); | 
| } | } | 
| result=noErr; | result=noErr; | 
| break; | break; | 
| case kEventMouseUp: | case kEventMouseUp: | 
| if (buttonKind == kEventMouseButtonSecondary | modif & controlKey) { | if (buttonKind == kEventMouseButtonSecondary | modif & controlKey) { | 
| ret=mouse_btn(MOUSE_RIGHTUP); | ret=mouse_btn(MOUSE_RIGHTUP); | 
| } | } | 
| else if (buttonKind == kEventMouseButtonTertiary) { | else if (buttonKind == kEventMouseButtonTertiary) { | 
| mouse_running(MOUSE_XOR); | mouse_running(MOUSE_XOR); | 
| menu_setmouse(np2oscfg.MOUSE_SW ^ 1); | menu_setmouse(np2oscfg.MOUSE_SW ^ 1); | 
| sysmng_update(SYS_UPDATECFG); | sysmng_update(SYS_UPDATECFG); | 
| } | } | 
| else { | else { | 
| ret=mouse_btn(MOUSE_LEFTUP); | ret=mouse_btn(MOUSE_LEFTUP); | 
| } | } | 
| result=noErr; | result=noErr; | 
| break; | break; | 
| } | } | 
 | #else | #else | 
| if (whatHappened == kEventMouseDown) { | if (whatHappened == kEventMouseDown) { | 
| HandleMouseDown(&eve); | HandleMouseDown(&eve); | 
| } | } | 
 | #endif | #endif | 
| break; | break; | 
| default: | default: | 
| break; | break; | 
| } | } | 
 |  |  | 
 | (void)myHandlerChain; | (void)myHandlerChain; | 
 | (void)userData; | (void)userData; | 
| Line 950  static pascal OSStatus np2windowevent(Ev | Line 951  static pascal OSStatus np2windowevent(Ev | 
 | UInt32              whatHappened; | UInt32              whatHappened; | 
 | OSStatus    result = eventNotHandledErr; | OSStatus    result = eventNotHandledErr; | 
 | long                eventClass; | long                eventClass; | 
 | static UInt32 backup = 0; |  | 
 |  |  | 
 | GetEventParameter(event, kEventParamDirectObject, typeWindowRef, NULL, | GetEventParameter(event, kEventParamDirectObject, typeWindowRef, NULL, | 
 | sizeof(window), NULL, &window); | sizeof(window), NULL, &window); | 
 | eventClass = GetEventClass(event); | eventClass = GetEventClass(event); | 
 | whatHappened = GetEventKind(event); | whatHappened = GetEventKind(event); | 
 |  |  | 
 |  | static UInt32 backup = 0; | 
 | switch (eventClass) | switch (eventClass) | 
| { | { | 
| case kEventClassWindow: | case kEventClassKeyboard: | 
| if (whatHappened == kEventWindowClose) { | UInt32 key; | 
| np2running = FALSE; | GetEventParameter (event, kEventParamKeyCode, typeUInt32, NULL, sizeof(UInt32), NULL, &key); | 
|  | UInt32 modif; | 
|  | GetEventParameter (event, kEventParamKeyModifiers, typeUInt32, NULL, sizeof(UInt32), NULL, &modif); | 
|  | switch (whatHappened) | 
|  | { | 
|  | case kEventRawKeyUp: | 
|  | mackbd_keyup(key); | 
 | result = noErr; | result = noErr; | 
| } | break; | 
| break; | case kEventRawKeyRepeat: | 
| case kEventClassKeyboard: | mackbd_keydown(key); | 
| UInt32 key; | result = noErr; | 
| GetEventParameter (event, kEventParamKeyCode, typeUInt32, NULL, sizeof(UInt32), NULL, &key); | break; | 
| UInt32 modif; | case kEventRawKeyDown: | 
| GetEventParameter (event, kEventParamKeyModifiers, typeUInt32, NULL, sizeof(UInt32), NULL, &modif); | if (modif & cmdKey) { | 
| switch (whatHappened) | EventRecord     eve; | 
| { | ConvertEventRefToEventRecord( event,&eve ); | 
| case kEventRawKeyUp: | HandleMenuChoice(MenuEvent(&eve)); | 
| mackbd_f12up(key); | } | 
| result = noErr; | else { | 
| break; | mackbd_keydown(key); | 
| case kEventRawKeyRepeat: | } | 
| mackbd_f12down(key); | result = noErr; | 
| result = noErr; | break; | 
| break; | case kEventRawKeyModifiersChanged: | 
| case kEventRawKeyDown: | if (modif & shiftKey) keystat_senddata(0x70); | 
| if (modif & cmdKey) { | else keystat_senddata(0x70 | 0x80); | 
| EventRecord eve; | if (modif & optionKey) keystat_senddata(0x73); | 
| ConvertEventRefToEventRecord( event,&eve ); | else keystat_senddata(0x73 | 0x80); | 
| HandleMenuChoice(MenuEvent(&eve)); | if (modif & controlKey) keystat_senddata(0x74); | 
| } | else keystat_senddata(0x74 | 0x80); | 
| else { | if ((modif & alphaLock) != (backup & alphaLock)) { | 
| mackbd_f12down(key); | keystat_senddata(0x71); | 
| } | backup = modif; | 
| result = noErr; | } | 
| break; | result = noErr; | 
| case kEventRawKeyModifiersChanged: | break; | 
| if (modif & shiftKey) keystat_senddata(0x70); | default: | 
| else keystat_senddata(0x70 | 0x80); | break; | 
| if (modif & optionKey) keystat_senddata(0x73); | } | 
| else keystat_senddata(0x73 | 0x80); | break; | 
| if (modif & controlKey) keystat_senddata(0x74); |  | 
| else keystat_senddata(0x74 | 0x80); | case kEventClassWindow: | 
| if ((modif & alphaLock) != (backup & alphaLock)) { | switch (whatHappened) | 
| keystat_senddata(0x71); | { | 
| backup = modif; | case kEventWindowClose: | 
| } | taskmng_exit(); | 
| result = noErr; | result = noErr; | 
| break; | break; | 
| default: | case kEventWindowActivated: | 
| break; | DisableAllMenuItems(GetMenuHandle(IDM_EDIT)); | 
| } | break; | 
| default: | case kEventWindowToolbarSwitchMode: | 
| break; | toolwin_open(); | 
| } | break; | 
|  | case kEventWindowDragStarted: | 
|  | soundmng_stop(); | 
|  | break; | 
|  | case kEventWindowDragCompleted: | 
|  | soundmng_play(); | 
|  | break; | 
|  | case kEventWindowShown: | 
|  | scrndraw_redraw(); | 
|  | break; | 
|  | } | 
|  | break; | 
|  | default: | 
|  | break; | 
|  | } | 
 |  |  | 
 | (void)myHandler; | (void)myHandler; | 
 | (void)userData; | (void)userData; | 
| Line 1017  static pascal OSStatus np2windowevent(Ev | Line 1038  static pascal OSStatus np2windowevent(Ev | 
 | } | } | 
 |  |  | 
 | static const EventTypeSpec appEventList[] = { | static const EventTypeSpec appEventList[] = { | 
 |  | {kEventClassCommand,    kEventCommandProcess }, | 
 | {kEventClassAppleEvent, kEventAppleEvent}, | {kEventClassAppleEvent, kEventAppleEvent}, | 
 | {kEventClassMouse,              kEventMouseDown}, | {kEventClassMouse,              kEventMouseDown}, | 
 | #if defined(NP2GCC) | #if defined(NP2GCC) | 
| Line 1027  static const EventTypeSpec appEventList[ | Line 1049  static const EventTypeSpec appEventList[ | 
 |  |  | 
 | static const EventTypeSpec windEventList[] = { | static const EventTypeSpec windEventList[] = { | 
 | {kEventClassWindow,             kEventWindowClose}, | {kEventClassWindow,             kEventWindowClose}, | 
 |  | {kEventClassWindow,             kEventWindowActivated}, | 
 |  | {kEventClassWindow,             kEventWindowToolbarSwitchMode}, | 
 |  | {kEventClassWindow,             kEventWindowDragStarted}, | 
 |  | {kEventClassWindow,             kEventWindowDragCompleted}, | 
 |  | {kEventClassWindow,             kEventWindowShown}, | 
 | {kEventClassKeyboard,   kEventRawKeyDown}, | {kEventClassKeyboard,   kEventRawKeyDown}, | 
 | {kEventClassKeyboard,   kEventRawKeyUp}, | {kEventClassKeyboard,   kEventRawKeyUp}, | 
 | {kEventClassKeyboard,   kEventRawKeyRepeat}, | {kEventClassKeyboard,   kEventRawKeyRepeat}, | 
| Line 1045  static void setUpCarbonEvent(void) { | Line 1072  static void setUpCarbonEvent(void) { | 
 | windEventList, 0, NULL); | windEventList, 0, NULL); | 
 | } | } | 
 |  |  | 
 |  | static bool setupMainWindow(void) { | 
 |  | #if defined(NP2GCC) | 
 |  | OSStatus    err; | 
 |  | IBNibRef    nibRef; | 
 |  |  | 
 |  | err = CreateNibReference(CFSTR("np2"), &nibRef); | 
 |  | if (err ==noErr ) { | 
 |  | CreateWindowFromNib(nibRef, CFSTR("MainWindow"), &hWndMain); | 
 |  | DisposeNibReference ( nibRef); | 
 |  | } | 
 |  | else { | 
 |  | return(false); | 
 |  | } | 
 |  |  | 
 |  | #else | 
 |  | Rect wRect; | 
 |  |  | 
 |  | SetRect(&wRect, 100, 100, 100, 100); | 
 |  | hWndMain = NewWindow(0, &wRect, "\pNeko Project II", FALSE, | 
 |  | noGrowDocProc, (WindowPtr)-1, TRUE, 0); | 
 |  | if (!hWndMain) { | 
 |  | TRACETERM(); | 
 |  | macossub_term(); | 
 |  | dosio_term(); | 
 |  | return(false); | 
 |  | } | 
 |  | SizeWindow(hWndMain, 640, 400, TRUE); | 
 |  | #endif | 
 |  | scrnmng_initialize(); | 
 |  | setUpCarbonEvent(); | 
 |  | ShowWindow(hWndMain); | 
 |  | return(true); | 
 |  | } | 
 |  |  | 
 |  | static void toggleFullscreen(void) { | 
 |  | static Ptr  bkfullscreen; | 
 |  | static BYTE mouse = 0; | 
 |  |  | 
 |  | soundmng_stop(); | 
 |  | if (!scrnmode & SCRNMODE_FULLSCREEN) { | 
 |  | RGBColor col = {0, 0, 0}; | 
 |  | short   w=640, h=480; | 
 |  | DisposeWindow(hWndMain); | 
 |  | BeginFullScreen(&bkfullscreen,0,&w,&h,&hWndMain,&col,(fullScreenAllowEvents | fullScreenDontChangeMenuBar)); | 
 |  | HideMenuBar(); | 
 |  | setUpCarbonEvent(); | 
 |  | if (!np2oscfg.MOUSE_SW) { | 
 |  | mouse = np2oscfg.MOUSE_SW; | 
 |  | mouse_running(MOUSE_ON); | 
 |  | menu_setmouse(1); | 
 |  | } | 
 |  | changescreen(scrnmode | SCRNMODE_FULLSCREEN); | 
 |  | } | 
 |  | else { | 
 |  | scrnmng_destroy(); | 
 |  | EndFullScreen(bkfullscreen, 0); | 
 |  | setupMainWindow(); | 
 |  | changescreen(scrnmode & (~SCRNMODE_FULLSCREEN)); | 
 |  | if (!mouse) { | 
 |  | mouse_running(MOUSE_OFF); | 
 |  | menu_setmouse(0); | 
 |  | } | 
 |  | ShowMenuBar(); | 
 |  | } | 
 |  | CheckMenuItem(GetMenuHandle(IDM_SCREEN), LoWord(IDM_FULLSCREEN), scrnmode & SCRNMODE_FULLSCREEN); | 
 |  | soundmng_play(); | 
 |  | } | 
 |  |  | 
 |  | void recieveCommand(long param) { | 
 |  | HandleMenuChoice(param); | 
 |  | } |