[BACK]Return to main.c CVS log [TXT][DIR] Up to [local] / OpenXM_contrib2 / asir2000 / parse

Diff for /OpenXM_contrib2/asir2000/parse/main.c between version 1.14 and 1.35

version 1.14, 2001/12/27 07:51:17 version 1.35, 2014/05/09 19:35:52
Line 45 
Line 45 
  * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE,   * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE,
  * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE.   * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE.
  *   *
  * $OpenXM: OpenXM_contrib2/asir2000/parse/main.c,v 1.13 2001/12/25 02:39:06 noro Exp $   * $OpenXM: OpenXM_contrib2/asir2000/parse/main.c,v 1.34 2013/12/19 05:48:24 saito Exp $
 */  */
 #include "ca.h"  #include "ca.h"
 #include "parse.h"  #include "parse.h"
   
 #if PARI  #include <stdlib.h>
   #if defined(VISUAL)
   #include <io.h>
   #define R_OK 4
   #else
   #include <unistd.h>
   #include <fcntl.h>
   #endif
   
   #if defined(PARI)
 #include "genpari.h"  #include "genpari.h"
   
 /* XXX : environment is defined in libpari.a */  /* XXX : environment is defined in libpari.a */
   #  if !(PARI_VERSION_CODE > 131588)
 extern jmp_buf environnement;  extern jmp_buf environnement;
   #  endif
 #endif  #endif
   
 extern JMP_BUF main_env;  extern JMP_BUF main_env;
   
 #if defined(INTERVAL)  
 #ifndef ASIRRCNAME  #ifndef ASIRRCNAME
 #define ASIRRCNAME      "int_asirrc"  
 #endif  
 #else  
 #ifndef ASIRRCNAME  
 #define ASIRRCNAME      "asirrc"  #define ASIRRCNAME      "asirrc"
 #endif  #endif
 #endif  
   
   
 double get_current_time();  double get_current_time();
 void init_socket();  void init_socket();
 void recover();  void recover();
   void set_stacksize();
   
 extern int mpi_nprocs,mpi_myid;  extern int mpi_nprocs,mpi_myid;
   
   char *find_asirrc()
   {
           static char name[BUFSIZ];
           char dir[BUFSIZ];
           char *env,*env2;
   
   /* if ASIR_CONFIG is set, execute it; else execute .asirrc */
           env = getenv("ASIR_CONFIG");
           if( env && !access(env, R_OK) ) {
                   strcpy(name,env);
                   return name;
           }
           env = getenv("HOME");
           if ( env ) {
                   sprintf(name, "%s/.asirrc", env);
                   if (!access(name, R_OK)) {
                           return name;
                   }
           }
   #if defined(VISUAL)
           env  = getenv("HOMEDRIVE");
           env2 = getenv("HOMEPATH");
           if ( env && env2 ) {
                   sprintf(name, "%s%s/.asirrc", env, env2);
                   if (!access(name, R_OK)) {
                           return name;
                   }
           }
           env  = getenv("APPDATA");
           if ( env ) {
                   sprintf(name, "%s/OpenXM/.asirrc", env);
                   if (!access(name, R_OK)) {
                           return name;
                   }
           }
           get_rootdir(dir, BUFSIZ);
           sprintf(name, "%s/.asirrc", dir);
           if (!access(name, R_OK)) {
                   return name;
           }
   #endif
           return NULL;
   }
   
 #if defined(VISUAL_LIB)  #if defined(VISUAL_LIB)
 void Main(int argc,char *argv[])  void Main(int argc,char *argv[])
 #else  #else
Line 86  main(int argc,char *argv[])
Line 136  main(int argc,char *argv[])
 #endif  #endif
 {  {
         int tmp;          int tmp;
         FILE *ifp;          char *ifname;
         char ifname[BUFSIZ];  
         extern int GC_dont_gc;          extern int GC_dont_gc;
         extern int read_exec_file;  
         extern int do_asirrc;          extern int do_asirrc;
         extern int do_file;          extern int do_file;
           extern char *do_filename;
           extern int asir_setenv;
         extern FILE *in_fp;          extern FILE *in_fp;
         extern int *StackBottom;          extern int *StackBottom;
         char *getenv();  
         char *homedir;  
         char *ptr;  
 #if !defined(VISUAL)  #if !defined(VISUAL)
         char *slash,*binname;          char *slash,*bslash,*binname,*p;
 #endif  #endif
   
           set_stacksize();
         StackBottom = &tmp;          StackBottom = &tmp;
 #if MPI          GC_init();
   #if defined(MPI)
         mpi_init();          mpi_init();
         if ( mpi_myid ) {          if ( mpi_myid ) {
                 int slave_argc;                  int slave_argc;
Line 117  main(int argc,char *argv[])
Line 166  main(int argc,char *argv[])
                 ox_mpi_master_init();                  ox_mpi_master_init();
 #elif !defined(VISUAL)  #elif !defined(VISUAL)
         slash = (char *)rindex(argv[0],'/');          slash = (char *)rindex(argv[0],'/');
           bslash = (char *)rindex(argv[0],'\\');
         if ( slash )          if ( slash )
                 binname = slash+1;                  binname = slash+1;
           else if ( bslash )
                   binname = bslash+1;
         else          else
                 binname = argv[0];                  binname = argv[0];
         if ( !strcmp(binname,"ox_asir") ) {          for ( p = binname; *p; p++ )
                   *p = tolower(*p);
           if ( !strncmp(binname,"ox_asir",strlen("ox_asir")) ) {
                 /* never return */                  /* never return */
                 ox_main(argc,argv);                  ox_main(argc,argv);
                 exit(0);                  exit(0);
 #if DO_PLOT  #if defined(DO_PLOT)
         } else if ( !strcmp(binname,"ox_plot") ) {          } else if ( !strncmp(binname,"ox_plot",strlen("ox_plot")) ) {
                 /* never return */                  /* never return */
                 ox_plot_main(argc,argv);                  ox_plot_main(argc,argv);
                 exit(0);                  exit(0);
 #endif  #endif
         } else if ( !strcmp(binname,"ox_launch") ) {          } else if ( !strncmp(binname,"ox_launch",strlen("ox_launch")) ) {
                 /* never return */                  /* never return */
                 launch_main(argc,argv);                  launch_main(argc,argv);
                 exit(0);                  exit(0);
Line 144  main(int argc,char *argv[])
Line 198  main(int argc,char *argv[])
         rtime_init();          rtime_init();
         env_init();          env_init();
         endian_init();          endian_init();
         GC_init();          cppname_init();
         process_args(--argc,++argv);          process_args(--argc,++argv);
 #if PARI  #if defined(PARI)
     risa_pari_init();      risa_pari_init();
 #endif  #endif
         copyright();          if (!do_quiet) {
                   copyright();
           }
         output_init();          output_init();
         arf_init();          arf_init();
         nglob_init();          nglob_init();
Line 160  main(int argc,char *argv[])
Line 216  main(int argc,char *argv[])
         pf_init();          pf_init();
         sysf_init();          sysf_init();
         parif_init();          parif_init();
           order_init();
           /* XXX set the default ordering */
 #if defined(VISUAL)  #if defined(VISUAL)
         init_socket();          init_socket();
 #endif  #endif
Line 167  main(int argc,char *argv[])
Line 225  main(int argc,char *argv[])
         reg_sysf();          reg_sysf();
 #endif  #endif
   
 /* if ASIR_CONFIG is set, execute it; else execute .asirrc */          if ( do_file ) {
         if ( ptr = getenv("ASIR_CONFIG") )                  asir_infile=NULL;
                 strcpy(ifname,ptr);                  loadasirfile(do_filename);
         else {          } else {
                 homedir = getenv("HOME");                  /* the bottom of the input stack */
                 if ( !homedir ) {                  input_init(stdin,"stdin");
                         char rootname[BUFSIZ];  
   
                         get_rootdir(rootname,sizeof(rootname));  
                         homedir = rootname;  
                 }  
                 sprintf(ifname,"%s/." ASIRRCNAME,homedir);  
         }          }
   
         if ( do_asirrc && (ifp = fopen(ifname,"r")) ) {          if ( do_asirrc && (ifname = find_asirrc()) ) {
                 input_init(ifp,ifname);                  if ( !SETJMP(main_env) )
                 if ( !SETJMP(main_env) ) {                          execasirfile(ifname);
                         read_exec_file = 1;  
                         read_eval_loop();  
                         read_exec_file = 0;  
                 }  
                 fclose(ifp);  
         }          }
   
         if ( do_file )  
                 input_init(in_fp,"stdin");  
         else  
                 input_init(stdin,"stdin");  
         prompt();          prompt();
         while ( 1 ) {          while ( 1 ) {
 #if PARI  #if defined(PARI)
                 recover(0);                  recover(0);
                 /* XXX environement is defined in libpari.a */                  /* XXX environement is defined in libpari.a */
   #  if !(PARI_VERSION_CODE > 131588)
                 if ( setjmp(environnement) ) {                  if ( setjmp(environnement) ) {
                         avma = top; recover(1);                          avma = top; recover(1);
                         resetenv("");                          resetenv("");
                 }                  }
   #  endif
 #endif  #endif
                 if ( SETJMP(main_env) )                  if ( SETJMP(main_env) )
                         prompt();                          prompt();
                   if ( !do_file ) {
                           if ( SETJMP(asir_infile->jmpbuf) )
                                   prompt();
                           else
                                   asir_infile->ready_for_longjmp = 1;
                   }
                   restore_handler();
                 read_eval_loop();                  read_eval_loop();
         }          }
 }  }
Line 217  main(int argc,char *argv[])
Line 269  main(int argc,char *argv[])
 void set_error(int code,char *reason,char *action)  void set_error(int code,char *reason,char *action)
 {}  {}
 #endif  #endif
   
   void set_stacksize()
   {
   #if !defined(VISUAL)
           struct rlimit rlim;
           int c,m;
   
           getrlimit(RLIMIT_STACK,&rlim);
           if ( rlim.rlim_cur < (1<<26) ) {
                   rlim.rlim_cur = MIN(1<<26,rlim.rlim_max);
                   setrlimit(RLIMIT_STACK,&rlim);
           }
   #endif
   }

Legend:
Removed from v.1.14  
changed lines
  Added in v.1.35

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>