--- np2/statsave.c 2004/03/29 14:19:24 1.40 +++ np2/statsave.c 2011/01/15 18:04:42 1.52 @@ -31,6 +31,7 @@ #include "keydisp.h" #include "hostdrv.h" #include "calendar.h" +#include "keystat.h" #if defined(MACOS) #define CRCONST str_cr @@ -60,18 +61,19 @@ enum { STATFLAG_CGW, #endif STATFLAG_COM, - STATFLAG_DISK, STATFLAG_DMA, STATFLAG_EGC, STATFLAG_EPSON, STATFLAG_EVT, STATFLAG_EXT, + STATFLAG_FDD, STATFLAG_FM, STATFLAG_GIJ, #if defined(SUPPORT_HOSTDRV) STATFLAG_HDRV, #endif - STATFLAG_MEM + STATFLAG_MEM, + STATFLAG_SXSI }; typedef struct { @@ -95,45 +97,13 @@ extern COMMNG cm_mpu98; extern COMMNG cm_rs232c; typedef struct { - char *buf; + OEMCHAR *buf; int remain; } ERR_BUF; // ---- -// 関数ポインタを intに変更。 -static BOOL proc2num(void *func, const PROCTBL *tbl, int size) { - - int i; - - for (i=0; iproc) { - *(long *)func = (long)tbl->id; - return(SUCCESS); - } - tbl++; - } - return(FAILURE); -} - -static BOOL num2proc(void *func, const PROCTBL *tbl, int size) { - - int i; - - for (i=0; iid) { - *(long *)func = (long)tbl->proc; - return(SUCCESS); - } - tbl++; - } - return(FAILURE); -} - - -// ---- - enum { SFFILEH_WRITE = 0x0001, SFFILEH_BLOCK = 0x0002, @@ -148,7 +118,7 @@ typedef struct { NP2FHDR f; } _SFFILEH, *SFFILEH; -static SFFILEH statflag_open(const char *filename, char *err, int errlen) { +static SFFILEH statflag_open(const OEMCHAR *filename, OEMCHAR *err, int errlen) { FILEH fh; SFFILEH ret; @@ -185,7 +155,7 @@ sfo_err1: static int statflag_closesection(SFFILEH sffh) { UINT leng; - BYTE zero[16]; + UINT8 zero[16]; if (sffh == NULL) { goto sfcs_err1; @@ -260,7 +230,7 @@ sfr_err: return(STATFLAG_FAILURE); } -static SFFILEH statflag_create(const char *filename) { +static SFFILEH statflag_create(const OEMCHAR *filename) { SFFILEH ret; FILEH fh; @@ -354,7 +324,7 @@ static void statflag_close(SFFILEH sffh) } } -void statflag_seterr(STFLAGH sfh, const char *str) { +void statflag_seterr(STFLAGH sfh, const OEMCHAR *str) { if ((sfh) && (sfh->errlen)) { milstr_ncat(sfh->err, str, sfh->errlen); @@ -363,6 +333,103 @@ void statflag_seterr(STFLAGH sfh, const } +// ---- function + +// 関数ポインタを intに変更。 +static BRESULT proc2num(void *func, const PROCTBL *tbl, int size) { + + int i; + + for (i=0; iproc) { + *(long *)func = (long)tbl->id; + return(SUCCESS); + } + tbl++; + } + return(FAILURE); +} + +static BRESULT num2proc(void *func, const PROCTBL *tbl, int size) { + + int i; + + for (i=0; iid) { + *(long *)func = (long)tbl->proc; + return(SUCCESS); + } + tbl++; + } + return(FAILURE); +} + + +// ---- file + +typedef struct { + OEMCHAR path[MAX_PATH]; + UINT ftype; + int readonly; + DOSDATE date; + DOSTIME time; +} STATPATH; + +static const OEMCHAR str_updated[] = OEMTEXT("%s: updated"); +static const OEMCHAR str_notfound[] = OEMTEXT("%s: not found"); + +static int statflag_writepath(STFLAGH sfh, const OEMCHAR *path, + UINT ftype, int readonly) { + + STATPATH sp; + FILEH fh; + + ZeroMemory(&sp, sizeof(sp)); + if ((path) && (path[0])) { + file_cpyname(sp.path, path, NELEMENTS(sp.path)); + sp.ftype = ftype; + sp.readonly = readonly; + fh = file_open_rb(path); + if (fh != FILEH_INVALID) { + file_getdatetime(fh, &sp.date, &sp.time); + file_close(fh); + } + } + return(statflag_write(sfh, &sp, sizeof(sp))); +} + +static int statflag_checkpath(STFLAGH sfh, const OEMCHAR *dvname) { + + int ret; + STATPATH sp; + FILEH fh; + OEMCHAR buf[256]; + DOSDATE dosdate; + DOSTIME dostime; + + ret = statflag_read(sfh, &sp, sizeof(sp)); + if (sp.path[0]) { + fh = file_open_rb(sp.path); + if (fh != FILEH_INVALID) { + file_getdatetime(fh, &dosdate, &dostime); + file_close(fh); + if ((memcmp(&sp.date, &dosdate, sizeof(dosdate))) || + (memcmp(&sp.time, &dostime, sizeof(dostime)))) { + ret |= STATFLAG_DISKCHG; + OEMSPRINTF(buf, str_updated, dvname); + statflag_seterr(sfh, buf); + } + } + else { + ret |= STATFLAG_DISKCHG; + OEMSPRINTF(buf, str_notfound, dvname); + statflag_seterr(sfh, buf); + } + } + return(ret); +} + + // ---- common static int flagsave_common(STFLAGH sfh, const SFENTRY *tbl) { @@ -546,7 +613,7 @@ static int nevent_write(STFLAGH sfh, int UINT i; ZeroMemory(&nit, sizeof(nit)); - for (i=0; itype) { @@ -1202,10 +1288,6 @@ const SFENTRY *tblterm; ret |= flagsave_com(&sffh->sfh, tbl); break; - case STATFLAG_DISK: - ret |= flagsave_disk(&sffh->sfh, tbl); - break; - case STATFLAG_DMA: ret |= flagsave_dma(&sffh->sfh, tbl); break; @@ -1226,9 +1308,15 @@ const SFENTRY *tblterm; ret |= flagsave_ext(&sffh->sfh, tbl); break; + case STATFLAG_FDD: + ret |= flagsave_fdd(&sffh->sfh, tbl); + break; + +#if !defined(DISABLE_SOUND) case STATFLAG_FM: ret |= flagsave_fm(&sffh->sfh, tbl); break; +#endif case STATFLAG_GIJ: ret |= flagsave_gij(&sffh->sfh, tbl); @@ -1243,6 +1331,10 @@ const SFENTRY *tblterm; case STATFLAG_MEM: ret |= flagsave_mem(&sffh->sfh, tbl); break; + + case STATFLAG_SXSI: + ret |= flagsave_sxsi(&sffh->sfh, tbl); + break; } tbl++; } @@ -1250,7 +1342,7 @@ const SFENTRY *tblterm; return(ret); } -int statsave_check(const char *filename, char *buf, int size) { +int statsave_check(const OEMCHAR *filename, OEMCHAR *buf, int size) { SFFILEH sffh; int ret; @@ -1268,7 +1360,7 @@ const SFENTRY *tblterm; while((!done) && (ret != STATFLAG_FAILURE)) { ret |= statflag_readsection(sffh); tbl = np2tbl; - tblterm = tbl + (sizeof(np2tbl)/sizeof(SFENTRY)); + tblterm = tbl + NELEMENTS(np2tbl); while(tbl < tblterm) { if (!memcmp(sffh->sfh.hdr.index, tbl->index, 10)) { break; @@ -1296,15 +1388,21 @@ const SFENTRY *tblterm; case STATFLAG_EVT: case STATFLAG_EXT: case STATFLAG_GIJ: +#if !defined(DISABLE_SOUND) case STATFLAG_FM: +#endif #if defined(SUPPORT_HOSTDRV) case STATFLAG_HDRV: #endif ret |= flagcheck_veronly(&sffh->sfh, tbl); break; - case STATFLAG_DISK: - ret |= flagcheck_disk(&sffh->sfh, tbl); + case STATFLAG_FDD: + ret |= flagcheck_fdd(&sffh->sfh, tbl); + break; + + case STATFLAG_SXSI: + ret |= flagcheck_sxsi(&sffh->sfh, tbl); break; default: @@ -1320,7 +1418,7 @@ const SFENTRY *tblterm; return(ret); } -int statsave_load(const char *filename) { +int statsave_load(const OEMCHAR *filename) { SFFILEH sffh; int ret; @@ -1345,7 +1443,7 @@ const SFENTRY *tblterm; rs232c_midipanic(); mpu98ii_midipanic(); pc9861k_midipanic(); - sxsi_trash(); + sxsi_alltrash(); ret |= flagload_common(&sffh->sfh, np2tbl); @@ -1358,15 +1456,15 @@ const SFENTRY *tblterm; sound_reset(); fddmtrsnd_bind(); - iocore_reset(); // サウンドでpicを呼ぶので… - cbuscore_reset(); - fmboard_reset(pccore.sound); + iocore_reset(&np2cfg); // サウンドでpicを呼ぶので… + cbuscore_reset(&np2cfg); + fmboard_reset(&np2cfg, pccore.sound); done = FALSE; while((!done) && (ret != STATFLAG_FAILURE)) { ret |= statflag_readsection(sffh); tbl = np2tbl + 1; - tblterm = np2tbl + (sizeof(np2tbl)/sizeof(SFENTRY)); + tblterm = np2tbl + NELEMENTS(np2tbl); while(tbl < tblterm) { if (!memcmp(sffh->sfh.hdr.index, tbl->index, 10)) { break; @@ -1393,10 +1491,6 @@ const SFENTRY *tblterm; ret |= flagload_com(&sffh->sfh, tbl); break; - case STATFLAG_DISK: - ret |= flagload_disk(&sffh->sfh, tbl); - break; - case STATFLAG_DMA: ret |= flagload_dma(&sffh->sfh, tbl); break; @@ -1417,9 +1511,15 @@ const SFENTRY *tblterm; ret |= flagload_ext(&sffh->sfh, tbl); break; + case STATFLAG_FDD: + ret |= flagload_fdd(&sffh->sfh, tbl); + break; + +#if !defined(DISABLE_SOUND) case STATFLAG_FM: ret |= flagload_fm(&sffh->sfh, tbl); break; +#endif case STATFLAG_GIJ: ret |= flagload_gij(&sffh->sfh, tbl); @@ -1435,6 +1535,10 @@ const SFENTRY *tblterm; ret |= flagload_mem(&sffh->sfh, tbl); break; + case STATFLAG_SXSI: + ret |= flagload_sxsi(&sffh->sfh, tbl); + break; + default: ret |= STATFLAG_WARNING; break; @@ -1447,7 +1551,7 @@ const SFENTRY *tblterm; statflag_close(sffh); // I/O作り直し - i286_memorymap((pccore.model & PCMODEL_EPSON)?1:0); + MEMM_ARCH((pccore.model & PCMODEL_EPSON)?1:0); iocore_build(); iocore_bind(); cbuscore_bind(); @@ -1464,7 +1568,8 @@ const SFENTRY *tblterm; FONTPTR_LOW = fontrom + cgwindow.low; FONTPTR_HIGH = fontrom + cgwindow.high; #endif - i286_vram_dispatch(vramop.operate); + MEMM_VRAM(vramop.operate); + fddmtr_reset(); soundmng_play(); return(ret);