--- np2/win9x/ini.cpp 2004/02/13 08:33:48 1.24 +++ np2/win9x/ini.cpp 2004/06/14 13:35:40 1.30 @@ -11,6 +11,26 @@ #include "pccore.h" + +static BOOL inigetbmp(const BYTE *ptr, UINT pos) { + + return((ptr[pos >> 3] >> (pos & 7)) & 1); +} + +static void inisetbmp(BYTE *ptr, UINT pos, BOOL set) { + + UINT8 bit; + + ptr += (pos >> 3); + bit = 1 << (pos & 7); + if (set) { + *ptr |= bit; + } + else { + *ptr &= ~bit; + } +} + static void inirdargs16(const char *src, const INITBL *ini) { SINT16 *dst; @@ -164,6 +184,14 @@ const INITBL *pterm; *((BYTE *)p->value) = (!milstr_cmp(work, str_true))?1:0; break; + case INITYPE_BITMAP: + GetPrivateProfileString(title, p->item, + (inigetbmp((BYTE *)p->value, p->arg))?str_true:str_false, + work, sizeof(work), path); + inisetbmp((BYTE *)p->value, p->arg, + (milstr_cmp(work, str_true) == 0)); + break; + case INITYPE_ARGS16: GetPrivateProfileString(title, p->item, str_null, work, sizeof(work), path); @@ -218,7 +246,7 @@ const INITBL *pterm; GetPrivateProfileString(title, p->item, work, work, sizeof(work), path); val = (UINT32)milstr_solveHEX(work); - *(UINT16 *)p->value = (UINT32)val; + *(UINT32 *)p->value = (UINT32)val; break; case INITYPE_BYTE3: @@ -227,13 +255,6 @@ const INITBL *pterm; inirdbyte3(work, p); break; - case INITYPE_USERKEY: - GetPrivateProfileString(title, p->item, str_null, - work, sizeof(work), path); - ((NKEYM)p->value)->keys = (UINT8)profile_setkeys(work, - ((NKEYM)p->value)->key, 15); - break; - case INITYPE_KB: GetPrivateProfileString(title, p->item, str_null, work, sizeof(work), path); @@ -307,11 +328,6 @@ const char *set; SPRINTF(work, str_x, *((UINT32 *)p->value)); break; - case INITYPE_USERKEY: - profile_getkeys(work, sizeof(work), - ((NKEYM)p->value)->key, ((NKEYM)p->value)->keys); - break; - default: set = NULL; break; @@ -327,11 +343,16 @@ const char *set; // ---- +#if !defined(SUPPORT_PC9821) static const char ini_title[] = "NekoProjectII"; +#else +static const char ini_title[] = "NekoProject21"; +#endif enum { INIRO_STR = INITYPE_STR + INIFLAG_RO, INIRO_BOOL = INITYPE_BOOL + INIFLAG_RO, + INIRO_BITMAP = INITYPE_BITMAP + INIFLAG_RO, INIRO_UINT8 = INITYPE_UINT8 + INIFLAG_RO, INIMAX_UINT8 = INITYPE_UINT8 + INIFLAG_MAX, INIAND_UINT8 = INITYPE_UINT8 + INIFLAG_AND, @@ -393,7 +414,7 @@ static const INITBL iniitem[] = { {"optSPBVR", INITYPE_HEX8, &np2cfg.spb_vrc, 0}, {"optSPBVL", INIMAX_UINT8, &np2cfg.spb_vrl, 24}, {"optSPB_X", INITYPE_BOOL, &np2cfg.spb_x, 0}, - {"optMPU98", INITYPE_HEX8 &np2cfg.mpuopt, 0}, + {"optMPU98", INITYPE_HEX8, &np2cfg.mpuopt, 0}, {"volume_F", INIMAX_UINT8, &np2cfg.vol_fm, 128}, {"volume_S", INIMAX_UINT8, &np2cfg.vol_ssg, 128}, @@ -432,8 +453,10 @@ static const INITBL iniitem[] = { {"calendar", INITYPE_BOOL, &np2cfg.calendar, 0}, {"USE144FD", INITYPE_BOOL, &np2cfg.usefd144, 0}, - {"userkey1", INITYPE_USERKEY, np2cfg.userkey+0, 0}, - {"userkey2", INITYPE_USERKEY, np2cfg.userkey+1, 0}, + {"FDDRIVE1", INIRO_BITMAP, &np2cfg.fddequip, 0}, + {"FDDRIVE2", INIRO_BITMAP, &np2cfg.fddequip, 1}, + {"FDDRIVE3", INIRO_BITMAP, &np2cfg.fddequip, 2}, + {"FDDRIVE4", INIRO_BITMAP, &np2cfg.fddequip, 3}, // OS°Í¸¡© @@ -487,6 +510,8 @@ static const INITBL iniitem[] = { {"keydispl", INITYPE_BOOL, &np2oscfg.keydisp, 0}, {"jast_snd", INITYPE_BOOL, &np2oscfg.jastsnd, 0}, // ver0.73 {"useromeo", INITYPE_BOOL, &np2oscfg.useromeo, 0}, // ver0.74 + {"thickfrm", INITYPE_BOOL, &np2oscfg.thickframe, 0}, // ver0.77 + {"xrollkey", INIRO_BOOL, &np2oscfg.xrollkey, 0}, // ver0.78 {"I286SAVE", INIRO_BOOL, &np2oscfg.I286SAVE, 0}};