Diff for /np2/x11/main.c between versions 1.17 and 1.28

version 1.17, 2004/06/16 12:50:49 version 1.28, 2008/03/13 16:27:39
Line 10 Line 10
  * 2. Redistributions in binary form must reproduce the above copyright   * 2. Redistributions in binary form must reproduce the above copyright
  *    notice, this list of conditions and the following disclaimer in the   *    notice, this list of conditions and the following disclaimer in the
  *    documentation and/or other materials provided with the distribution.   *    documentation and/or other materials provided with the distribution.
  * 3. The name of the author may not be used to endorse or promote products  
  *    derived from this software without specific prior written permission.  
  *   *
  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR   * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES   * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
Line 44 Line 42
 #include "toolkit.h"  #include "toolkit.h"
   
 #include "kdispwin.h"  #include "kdispwin.h"
 #include "sysmenu.h"  
 #include "toolwin.h"  #include "toolwin.h"
 #include "viewer.h"  #include "viewer.h"
 #include "debugwin.h"  #include "debugwin.h"
Line 52 Line 49
   
 #include "commng.h"  #include "commng.h"
 #include "fontmng.h"  #include "fontmng.h"
 #include "inputmng.h"  
 #include "joymng.h"  #include "joymng.h"
 #include "kbdmng.h"  #include "kbdmng.h"
 #include "mousemng.h"  #include "mousemng.h"
Line 63 Line 59
   
   
 /*  /*
  * resume  
  */  
 static const char np2resumeext[] = "sav";  
   
   
 /*  
  * failure signale handler   * failure signale handler
  */   */
 typedef void sigfunc(int);  typedef void sigfunc(int);
Line 102  sighandler(int signo) Line 92  sighandler(int signo)
 static struct option longopts[] = {  static struct option longopts[] = {
         { "config",             required_argument,      0,      'c' },          { "config",             required_argument,      0,      'c' },
         { "timidity-config",    required_argument,      0,      'C' },          { "timidity-config",    required_argument,      0,      'C' },
         { "shared-pixmap",      no_argument,            0,      'p' },  
 #if defined(USE_SDL) || defined(USE_SYSMENU)  
         { "ttfont",             required_argument,      0,      't' },  
 #endif  
         { "help",               no_argument,            0,      'h' },          { "help",               no_argument,            0,      'h' },
         { 0,                    0,                      0,      0   },          { 0,                    0,                      0,      0   },
 };  };
Line 121  usage(void) Line 107  usage(void)
         printf("\t--help            [-h]        : print this message\n");          printf("\t--help            [-h]        : print this message\n");
         printf("\t--config          [-c] <file> : specify config file\n");          printf("\t--config          [-c] <file> : specify config file\n");
         printf("\t--timidity-config [-C] <file> : specify timidity config file\n");          printf("\t--timidity-config [-C] <file> : specify timidity config file\n");
         printf("\t--shared-pixmap   [-p]        : use MIT-SHM pixmap extention\n");  
 #if defined(USE_SDL) || defined(USE_SYSMENU)  
         printf("\t--ttfont          [-t] <file> : specify TrueType font\n");  
 #endif  
         exit(1);          exit(1);
 }  }
   
Line 140  main(int argc, char *argv[]) Line 122  main(int argc, char *argv[])
         int rv = 1;          int rv = 1;
         int ch;          int ch;
         int i, drvmax;          int i, drvmax;
         BOOL shared_pixmap_flag = FALSE;  
   
         progname = argv[0];          progname = argv[0];
   
         toolkit_initialize();          toolkit_initialize();
         toolkit_arginit(&argc, &argv);          toolkit_arginit(&argc, &argv);
   
         while ((ch = getopt_long(argc, argv, "c:C:t:ph", longopts, NULL)) != -1) {          while ((ch = getopt_long(argc, argv, "c:C:t:vh", longopts, NULL)) != -1) {
                 switch (ch) {                  switch (ch) {
                 case 'c':                  case 'c':
                         if (stat(optarg, &sb) < 0 || !S_ISREG(sb.st_mode)) {                          if (stat(optarg, &sb) < 0 || !S_ISREG(sb.st_mode)) {
Line 178  main(int argc, char *argv[]) Line 159  main(int argc, char *argv[])
                         milstr_ncpy(fontfilename, optarg, sizeof(fontfilename));                          milstr_ncpy(fontfilename, optarg, sizeof(fontfilename));
                         break;                          break;
   
                 case 'p':                  case 'v':
                         shared_pixmap_flag = TRUE;                          verbose = 1;
                         break;                          break;
   
                 case 'h':                  case 'h':
Line 253  main(int argc, char *argv[]) Line 234  main(int argc, char *argv[])
   
         rand_setseed((SINT32)time(NULL));          rand_setseed((SINT32)time(NULL));
   
 #if defined(GCC_CPU_ARCH_IA32)  
         mmxflag = havemmx() ? 0 : MMXFLAG_NOTSUPPORT;          mmxflag = havemmx() ? 0 : MMXFLAG_NOTSUPPORT;
         mmxflag += np2oscfg.disablemmx ? MMXFLAG_DISABLE : 0;          mmxflag += np2oscfg.disablemmx ? MMXFLAG_DISABLE : 0;
 #endif  
   
         use_shared_pixmap = np2oscfg.shared_pixmap && shared_pixmap_flag;  
   
         TRACEINIT();          TRACEINIT();
   
Line 272  main(int argc, char *argv[]) Line 249  main(int argc, char *argv[])
         toolkit_widget_create();          toolkit_widget_create();
         scrnmng_initialize();          scrnmng_initialize();
         kbdmng_init();          kbdmng_init();
         inputmng_init();  
         keystat_initialize();          keystat_initialize();
   
         scrnmode = 0;          scrnmode = 0;
         if (np2cfg.RASTER) {          if (np2cfg.RASTER) {
                 scrnmode |= SCRNMODE_HIGHCOLOR;                  scrnmode |= SCRNMODE_HIGHCOLOR;
         }          }
         if (sysmenu_create() != SUCCESS)  
                 goto sysmenu_failure;  
         if (scrnmng_create(scrnmode) != SUCCESS)          if (scrnmng_create(scrnmode) != SUCCESS)
                 goto scrnmng_failure;                  goto scrnmng_failure;
   
         if (soundmng_initialize() == SUCCESS) {          if (soundmng_initialize() == SUCCESS) {
                 result = soundmng_pcmload(SOUND_PCMSEEK, file_getcd("fddseek.wav"));                  result = soundmng_pcmload(SOUND_PCMSEEK, file_getcd("fddseek.wav"));
                 if (!result) {                  if (!result) {
                         result = soundmng_pcmload(SOUND_PCMSEEK, SYSRESPATH "/wav/fddseek.wav");                          result = soundmng_pcmload(SOUND_PCMSEEK, SYSRESPATH "/fddseek.wav");
                 }                  }
                 if (result) {                  if (result) {
                         soundmng_pcmvolume(SOUND_PCMSEEK, np2cfg.MOTORVOL);                          soundmng_pcmvolume(SOUND_PCMSEEK, np2cfg.MOTORVOL);
Line 295  main(int argc, char *argv[]) Line 269  main(int argc, char *argv[])
   
                 result = soundmng_pcmload(SOUND_PCMSEEK1, file_getcd("fddseek1.wav"));                  result = soundmng_pcmload(SOUND_PCMSEEK1, file_getcd("fddseek1.wav"));
                 if (!result) {                  if (!result) {
                         result = soundmng_pcmload(SOUND_PCMSEEK1, SYSRESPATH "/wav/fddseek1.wav");                          result = soundmng_pcmload(SOUND_PCMSEEK1, SYSRESPATH "/fddseek1.wav");
                 }                  }
                 if (result) {                  if (result) {
                         soundmng_pcmvolume(SOUND_PCMSEEK1, np2cfg.MOTORVOL);                          soundmng_pcmvolume(SOUND_PCMSEEK1, np2cfg.MOTORVOL);
                 }                  }
         }          }
   
           joymng_initialize();
         mousemng_initialize();          mousemng_initialize();
         if (np2oscfg.MOUSE_SW) {          if (np2oscfg.MOUSE_SW) {
                 mouse_running(MOUSE_ON);                  mouse_running(MOUSE_ON);
Line 311  main(int argc, char *argv[]) Line 286  main(int argc, char *argv[])
         sysmng_initialize();          sysmng_initialize();
         taskmng_initialize();          taskmng_initialize();
   
         joy_init();  
         pccore_init();          pccore_init();
         S98_init();          S98_init();
   
Line 332  main(int argc, char *argv[]) Line 306  main(int argc, char *argv[])
                 }                  }
         }          }
   
   #if defined(SUPPORT_RESUME)
         if (np2oscfg.resume) {          if (np2oscfg.resume) {
                 flagload(np2resumeext, "Resume", FALSE);                  flagload(np2resumeext, "Resume", FALSE);
         }          }
   #endif
         sysmng_workclockreset();          sysmng_workclockreset();
   
         drvmax = (argc < 4) ? argc : 4;          drvmax = (argc < 4) ? argc : 4;
         for (i = 0; i < drvmax; i++) {          for (i = 0; i < drvmax; i++) {
                 milstr_ncpy(diskdrv_fname[i],argv[i],sizeof(diskdrv_fname[0]));                  diskdrv_readyfdd(i, argv[i], 0);
                 diskdrv_delay[i] = 1;  
         }          }
   
         setup_signal(SIGINT, sighandler);          setup_signal(SIGINT, sighandler);
Line 356  main(int argc, char *argv[]) Line 331  main(int argc, char *argv[])
         pccore_cfgupdate();          pccore_cfgupdate();
   
         mouse_running(MOUSE_OFF);          mouse_running(MOUSE_OFF);
           joymng_deinitialize();
         S98_trash();          S98_trash();
   
   #if !defined(CPUCORE_IA32)
         if (np2oscfg.resume) {          if (np2oscfg.resume) {
                 flagsave(np2resumeext);                  flagsave(np2resumeext);
         } else {          } else {
                 flagdelete(np2resumeext);                  flagdelete(np2resumeext);
         }          }
   #endif
   
         pccore_term();          pccore_term();
         debugwin_destroy();          debugwin_destroy();
Line 371  main(int argc, char *argv[]) Line 349  main(int argc, char *argv[])
         scrnmng_destroy();          scrnmng_destroy();
   
 scrnmng_failure:  scrnmng_failure:
         sysmenu_destroy();  
   
 sysmenu_failure:  
         fontmng_terminate();          fontmng_terminate();
   
 fontmng_failure:  fontmng_failure:

Removed from v.1.17  
changed lines
  Added in v.1.28


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