Diff for /np2/x11/ini.c between versions 1.8 and 1.18

version 1.8, 2004/01/14 15:15:13 version 1.18, 2007/01/23 15:48:20
Line 7 Line 7
 #include "profile.h"  #include "profile.h"
 #include "strres.h"  #include "strres.h"
   
   #include "commng.h"
   #include "joymng.h"
 #include "kbdmng.h"  #include "kbdmng.h"
 #include "soundmng.h"  #include "soundmng.h"
   
Line 19  typedef struct { Line 21  typedef struct {
 } _INIARG, *INIARG;  } _INIARG, *INIARG;
   
   
   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  static void
 inirdargs16(const char *src, const INITBL *ini)  inirdargs16(const char *src, const INITBL *ini)
 {  {
Line 158  inirdsnddrv(const char *src, const INITB Line 181  inirdsnddrv(const char *src, const INITB
         *(UINT8 *)ini->value = snddrv_drv2num(src);          *(UINT8 *)ini->value = snddrv_drv2num(src);
 }  }
   
   static void
   inirdinterp(const char *src, const INITBL *ini)
   {
   
           if (!milstr_cmp(src, "NEAREST")) {
                   *(UINT8 *)ini->value = INTERP_NEAREST;
           } else if (!milstr_cmp(src, "TILES")) {
                   *(UINT8 *)ini->value = INTERP_TILES;
           } else if (!milstr_cmp(src, "HYPER")) {
                   *(UINT8 *)ini->value = INTERP_HYPER;
           } else {
                   *(UINT8 *)ini->value = INTERP_BILINEAR;
           }
   }
   
 static void update_iniread_flag(const INITBL *p);  static void update_iniread_flag(const INITBL *p);
   
 static BOOL  static BOOL
Line 186  inireadcb(void *arg, const char *para, c Line 224  inireadcb(void *arg, const char *para, c
                                 *((BYTE *)p->value) = (!milstr_cmp(data, str_true))?1:0;                                  *((BYTE *)p->value) = (!milstr_cmp(data, str_true))?1:0;
                                 break;                                  break;
   
                           case INITYPE_BITMAP:
                                   inisetbmp((BYTE *)p->value, p->arg, milstr_cmp(data, str_true) == 0);
                                   break;
   
                         case INITYPE_ARGS16:                          case INITYPE_ARGS16:
                                 milstr_ncpy(work, data, 512);                                  milstr_ncpy(work, data, 512);
                                 inirdargs16(work, p);                                  inirdargs16(work, p);
Line 238  inireadcb(void *arg, const char *para, c Line 280  inireadcb(void *arg, const char *para, c
                                 inirdsnddrv(work, p);                                  inirdsnddrv(work, p);
                                 break;                                  break;
   
                           case INITYPE_INTERP:
                                   milstr_ncpy(work, data, 512);
                                   inirdinterp(work, p);
                                   break;
   
                         default:                          default:
                                 rv = FALSE;                                  rv = FALSE;
                                 break;                                  break;
Line 312  iwss_extend: Line 359  iwss_extend:
         }          }
 }  }
   
   static const char *
   iniwrinterp(UINT8 interp)
   {
   
           if (interp == INTERP_NEAREST)
                   return "NEAREST";
           else if (interp == INTERP_TILES)
                   return "TILES";
           else if (interp == INTERP_HYPER)
                   return "HYPER";
           else
                   return "BILINEAR";
   }
   
 static BOOL read_iniread_flag(const INITBL *p);  static BOOL read_iniread_flag(const INITBL *p);
   
 void  void
Line 355  ini_write(const char *path, const char * Line 416  ini_write(const char *path, const char *
                                 milstr_ncpy(work, (*((BYTE *)p->value)) ? str_true : str_false, sizeof(work));                                  milstr_ncpy(work, (*((BYTE *)p->value)) ? str_true : str_false, sizeof(work));
                                 break;                                  break;
   
                           case INITYPE_BITMAP:
                                   milstr_ncpy(work, inigetbmp((BYTE *)p->value, p->arg) ? str_true : str_false, sizeof(work));
                                   break;
   
                         case INITYPE_ARGH8:                          case INITYPE_ARGH8:
                                 iniwrsetargh8(work, sizeof(work), p);                                  iniwrsetargh8(work, sizeof(work), p);
                                 break;                                  break;
Line 406  ini_write(const char *path, const char * Line 471  ini_write(const char *path, const char *
                                 SPRINTF(work, "%s", snddrv_num2drv(*(UINT8 *)p->value));                                  SPRINTF(work, "%s", snddrv_num2drv(*(UINT8 *)p->value));
                                 break;                                  break;
   
                           case INITYPE_INTERP:
                                   SPRINTF(work, "%s", iniwrinterp(*(UINT8 *)p->value));
                                   break;
   
                         default:                          default:
                                 set = FAILURE;                                  set = FAILURE;
                                 break;                                  break;
Line 429  static const char ini_title[] = "NekoPro Line 498  static const char ini_title[] = "NekoPro
 enum {  enum {
         INIRO_STR       = INIFLAG_RO | INITYPE_STR,          INIRO_STR       = INIFLAG_RO | INITYPE_STR,
         INIRO_BOOL      = INIFLAG_RO | INITYPE_BOOL,          INIRO_BOOL      = INIFLAG_RO | INITYPE_BOOL,
           INIRO_BITMAP    = INIFLAG_RO | INITYPE_BITMAP,
         INIRO_UINT8     = INIFLAG_RO | INITYPE_UINT8,          INIRO_UINT8     = INIFLAG_RO | INITYPE_UINT8,
         INIMAX_UINT8    = INIFLAG_MAX | INITYPE_UINT8,          INIMAX_UINT8    = INIFLAG_MAX | INITYPE_UINT8,
         INIAND_UINT8    = INIFLAG_AND | INITYPE_UINT8,          INIAND_UINT8    = INIFLAG_AND | INITYPE_UINT8,
Line 452  static const INITBL iniitem[] = { Line 522  static const INITBL iniitem[] = {
         {"hdrvroot", INIRO_STR,         np2cfg.hdrvroot,        MAX_PATH},          {"hdrvroot", INIRO_STR,         np2cfg.hdrvroot,        MAX_PATH},
         {"hdrv_acc", INIRO_UINT8,       &np2cfg.hdrvacc,        0},          {"hdrv_acc", INIRO_UINT8,       &np2cfg.hdrvacc,        0},
   
         {"pc_model", INITYPE_STR,       &np2cfg.model,          sizeof(np2cfg.model)},          {"pc_model", INITYPE_STR,       np2cfg.model,           sizeof(np2cfg.model)},
   
         {"clk_base", INITYPE_UINT32,    &np2cfg.baseclock,      0},          {"clk_base", INITYPE_UINT32,    &np2cfg.baseclock,      0},
         {"clk_mult", INITYPE_UINT32,    &np2cfg.multiple,       0},          {"clk_mult", INITYPE_UINT32,    &np2cfg.multiple,       0},
Line 462  static const INITBL iniitem[] = { Line 532  static const INITBL iniitem[] = {
         {"ExMemory", INIMAX_UINT8,      &np2cfg.EXTMEM,         13},          {"ExMemory", INIMAX_UINT8,      &np2cfg.EXTMEM,         13},
         {"ITF_WORK", INIRO_BOOL,        &np2cfg.ITF_WORK,       0},          {"ITF_WORK", INIRO_BOOL,        &np2cfg.ITF_WORK,       0},
   
         {"HDD1FILE", INITYPE_STR,       np2cfg.hddfile[0],      MAX_PATH},          {"HDD1FILE", INITYPE_STR,       np2cfg.sasihdd[0],      MAX_PATH},
         {"HDD2FILE", INITYPE_STR,       np2cfg.hddfile[1],      MAX_PATH},          {"HDD2FILE", INITYPE_STR,       np2cfg.sasihdd[1],      MAX_PATH},
   
         {"SampleHz", INITYPE_UINT16,    &np2cfg.samplingrate,   0},          {"SampleHz", INITYPE_UINT16,    &np2cfg.samplingrate,   0},
         {"Latencys", INITYPE_UINT16,    &np2cfg.delayms,        0},          {"Latencys", INITYPE_UINT16,    &np2cfg.delayms,        0},
Line 517  static const INITBL iniitem[] = { Line 587  static const INITBL iniitem[] = {
   
         {"calendar", INITYPE_BOOL,      &np2cfg.calendar,       0},          {"calendar", INITYPE_BOOL,      &np2cfg.calendar,       0},
         {"USE144FD", INITYPE_BOOL,      &np2cfg.usefd144,       0},          {"USE144FD", INITYPE_BOOL,      &np2cfg.usefd144,       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},
   
         {"keyboard", INIRO_KB,          &np2oscfg.KEYBOARD,     0},          {"keyboard", INIRO_KB,          &np2oscfg.KEYBOARD,     0},
         {"F12_COPY", INITYPE_UINT8,     &np2oscfg.F12KEY,       0},          {"F12_COPY", INITYPE_UINT8,     &np2oscfg.F12KEY,       0},
         {"Joystick", INITYPE_BOOL,      &np2oscfg.JOYPAD1,      0},          {"Joystick", INITYPE_BOOL,      &np2oscfg.JOYPAD1,      0},
         {"Joy1_btn", INITYPE_ARGH8,     np2oscfg.JOY1BTN,       4},          {"Joy1_btn", INITYPE_ARGH8,     np2oscfg.JOY1BTN,       JOY_NBUTTON},
           {"Joy1_dev", INITYPE_STR,       &np2oscfg.JOYDEV[0],    MAX_PATH},
           {"Joy1amap", INITYPE_ARGH8,     np2oscfg.JOYAXISMAP[0], JOY_NAXIS},
           {"Joy1bmap", INITYPE_ARGH8,     np2oscfg.JOYBTNMAP[0],  JOY_NBUTTON},
   
         {"confirm_", INITYPE_BOOL,      &np2oscfg.confirm,      0},          {"confirm_", INITYPE_BOOL,      &np2oscfg.confirm,      0},
   
Line 530  static const INITBL iniitem[] = { Line 607  static const INITBL iniitem[] = {
         {"mpu98mdl", INITYPE_STR,       np2oscfg.mpu.mdl,       64},          {"mpu98mdl", INITYPE_STR,       np2oscfg.mpu.mdl,       64},
         {"mpu98def", INITYPE_STR,       np2oscfg.mpu.def,       MAX_PATH},          {"mpu98def", INITYPE_STR,       np2oscfg.mpu.def,       MAX_PATH},
   
           {"com1port", INIMAX_UINT8,      &np2oscfg.com[0].port,  COMPORT_MIDI},
           {"com1para", INITYPE_UINT8,     &np2oscfg.com[0].param, 0},
           {"com1_bps", INITYPE_UINT32,    &np2oscfg.com[0].speed, 0},
           {"com1mmap", INITYPE_STR,       np2oscfg.com[0].mout,   MAX_PATH},
           {"com1mmdl", INITYPE_STR,       np2oscfg.com[0].mdl,    64},
           {"com1mdef", INITYPE_STR,       np2oscfg.com[0].def,    MAX_PATH},
   
           {"com2port", INIMAX_UINT8,      &np2oscfg.com[1].port,  COMPORT_MIDI},
           {"com2para", INITYPE_UINT8,     &np2oscfg.com[1].param, 0},
           {"com2_bps", INITYPE_UINT32,    &np2oscfg.com[1].speed, 0},
           {"com2mmap", INITYPE_STR,       np2oscfg.com[1].mout,   MAX_PATH},
           {"com2mmdl", INITYPE_STR,       np2oscfg.com[1].mdl,    64},
           {"com2mdef", INITYPE_STR,       np2oscfg.com[1].def,    MAX_PATH},
   
           {"com3port", INIMAX_UINT8,      &np2oscfg.com[2].port,  COMPORT_MIDI},
           {"com3para", INITYPE_UINT8,     &np2oscfg.com[2].param, 0},
           {"com3_bps", INITYPE_UINT32,    &np2oscfg.com[2].speed, 0},
           {"com3mmap", INITYPE_STR,       np2oscfg.com[2].mout,   MAX_PATH},
           {"com3mmdl", INITYPE_STR,       np2oscfg.com[2].mdl,    64},
           {"com3mdef", INITYPE_STR,       np2oscfg.com[2].def,    MAX_PATH},
   
         {"e_resume", INITYPE_BOOL,      &np2oscfg.resume,       0},          {"e_resume", INITYPE_BOOL,      &np2oscfg.resume,       0},
         {"STATSAVE", INIRO_BOOL,        &np2oscfg.statsave,     0},          {"STATSAVE", INIRO_BOOL,        &np2oscfg.statsave,     0},
 #if defined(__GNUC__) && (defined(i386) || defined(__i386__))  #if defined(GCC_CPU_ARCH_IA32)
         {"nousemmx", INITYPE_BOOL,      &np2oscfg.disablemmx,   0},          {"nousemmx", INITYPE_BOOL,      &np2oscfg.disablemmx,   0},
 #endif  #endif
         {"toolwind", INITYPE_BOOL,      &np2oscfg.toolwin,      0},          {"toolwind", INITYPE_BOOL,      &np2oscfg.toolwin,      0},
         {"keydispl", INITYPE_BOOL,      &np2oscfg.keydisp,      0},          {"keydispl", INITYPE_BOOL,      &np2oscfg.keydisp,      0},
           {"soft_kbd", INITYPE_BOOL,      &np2oscfg.softkbd,      0},
         {"jast_snd", INITYPE_BOOL,      &np2oscfg.jastsnd,      0},          {"jast_snd", INITYPE_BOOL,      &np2oscfg.jastsnd,      0},
   
         {"sounddrv", INITYPE_SNDDRV,    &np2oscfg.snddrv,       0},          {"sounddrv", INITYPE_SNDDRV,    &np2oscfg.snddrv,       0},
         {"audiodev", INITYPE_STR,       &np2oscfg.audiodev,     MAX_PATH},  
         {"MIDIOUTd", INITYPE_STR,       &np2oscfg.MIDIDEV[0],   MAX_PATH},          {"MIDIOUTd", INITYPE_STR,       &np2oscfg.MIDIDEV[0],   MAX_PATH},
         {"MIDIIN_d", INITYPE_STR,       &np2oscfg.MIDIDEV[1],   MAX_PATH},          {"MIDIIN_d", INITYPE_STR,       &np2oscfg.MIDIDEV[1],   MAX_PATH},
         {"MIDIWAIT", INITYPE_UINT32,    &np2oscfg.MIDIWAIT,     0},          {"MIDIWAIT", INITYPE_UINT32,    &np2oscfg.MIDIWAIT,     0},
   
         {"sharepix", INIRO_BOOL,        &np2oscfg.shared_pixmap,0},          {"dinterp_", INITYPE_INTERP,    &np2oscfg.drawinterp,   0},
           {"F11_KEY_", INITYPE_UINT8,     &np2oscfg.F11KEY,       0},
         {"toolkit_", INIRO_STR,         &np2oscfg.toolkit,      sizeof(np2oscfg.toolkit)},  
   
         {"I286SAVE", INIRO_BOOL,        &np2oscfg.I286SAVE,     0}          {"I286SAVE", INIRO_BOOL,        &np2oscfg.I286SAVE,     0},
 };  };
 #define INIITEMS        (sizeof(iniitem) / sizeof(iniitem[0]))  #define INIITEMS        (sizeof(iniitem) / sizeof(iniitem[0]))
   
Line 597  read_iniread_flag(const INITBL *p) Line 694  read_iniread_flag(const INITBL *p)
         return FALSE;          return FALSE;
 }  }
   
   NP2CFG np2cfg_default;
   NP2OSCFG np2oscfg_default;
   
 void  void
 initload(void)  initload(void)
 {  {
         char path[MAX_PATH];          char path[MAX_PATH];
   
           np2cfg_default = np2cfg;
           np2oscfg_default = np2oscfg;
   
         milstr_ncpy(path, modulefile, sizeof(path));          milstr_ncpy(path, modulefile, sizeof(path));
         ini_read(path, ini_title, iniitem, INIITEMS);          ini_read(path, ini_title, iniitem, INIITEMS);
 }  }

Removed from v.1.8  
changed lines
  Added in v.1.18


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