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

Diff for /OpenXM_contrib2/asir2000/io/ox_asir.c between version 1.43 and 1.77

version 1.43, 2003/03/07 06:39:57 version 1.77, 2016/08/24 05:33:58
Line 44 
Line 44 
  * OF THE SOFTWARE HAS BEEN DEVELOPED BY A THIRD PARTY, THE THIRD PARTY   * OF THE SOFTWARE HAS BEEN DEVELOPED BY A THIRD PARTY, THE THIRD PARTY
  * 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/io/ox_asir.c,v 1.42 2003/03/07 03:12:28 noro Exp $   * $OpenXM: OpenXM_contrib2/asir2000/io/ox_asir.c,v 1.76 2015/08/14 13:51:55 fujimoto Exp $
 */  */
 #include "ca.h"  #include "ca.h"
 #include "parse.h"  #include "parse.h"
 #include "signal.h"  #include "signal.h"
 #include "ox.h"  #include "ox.h"
 #include "version.h"  #include "version.h"
 #if defined(PARI)  
 #include "genpari.h"  
 #endif  
   
   char *find_asirrc();
 void ox_usr1_handler();  void ox_usr1_handler();
 int asir_ox_init();  int asir_ox_init();
   
 /* environement is defined in libpari.a */  /* environement is defined in libpari.a */
   #if 0
   # if !( PARI_VERSION_CODE > 131588)
 extern jmp_buf environnement;  extern jmp_buf environnement;
   # endif
   #endif
   extern int myrank_102,nserver_102;
   
 extern int do_message;  extern int do_message;
 extern int ox_flushing;  extern int ox_flushing;
Line 67  extern JMP_BUF ox_env;
Line 70  extern JMP_BUF ox_env;
 extern MATHCAP my_mathcap;  extern MATHCAP my_mathcap;
   
 extern int little_endian,ox_sock_id;  extern int little_endian,ox_sock_id;
   extern char LastError[];
   extern LIST LastStackTrace;
   
 int ox_sock_id;  int ox_sock_id;
 int lib_ox_need_conv;  int lib_ox_need_conv;
   
 void create_error(ERR *,unsigned int ,char *);  void create_error(ERR *,unsigned int ,char *,LIST trace);
   
 int asir_OperandStackSize;  int asir_OperandStackSize;
 Obj *asir_OperandStack;  Obj *asir_OperandStack;
Line 91  void asir_popString();
Line 96  void asir_popString();
 void asir_popCMO(unsigned int);  void asir_popCMO(unsigned int);
 void asir_popSerializedLocalObject();  void asir_popSerializedLocalObject();
 void asir_pushCMOtag(unsigned int);  void asir_pushCMOtag(unsigned int);
   void asir_set_rank_102(unsigned int);
   void asir_tcp_accept_102(unsigned int);
   void asir_tcp_connect_102(unsigned int);
   void asir_reset_102(unsigned int serial);
   void asir_bcast_102(unsigned int serial);
   void asir_reduce_102(unsigned int serial);
 LIST asir_GetErrorList();  LIST asir_GetErrorList();
 char *name_of_cmd(int);  char *name_of_cmd(int);
 char *name_of_id(int);  char *name_of_id(int);
   
 static void asir_do_cmd(int,unsigned int);  static void asir_do_cmd(int,unsigned int);
 static void asir_executeFunction(int);  static void asir_executeFunction(int);
   static void asir_executeFunctionSync(int);
   
 #if defined(MPI)  #if defined(MPI)
 /* XXX : currently MPI version supports only a homogeneous cluster. */  /* XXX : currently MPI version supports only a homogeneous cluster. */
Line 110  void ox_mpi_master_init() {
Line 122  void ox_mpi_master_init() {
                 /* ordering information is not exchanged */                  /* ordering information is not exchanged */
                 /* idx should be equal to i */                  /* idx should be equal to i */
                 idx = get_iofp(i,0,0);                  idx = get_iofp(i,0,0);
                 register_server(0,idx,idx);                  register_server(0,idx,idx,-1);
         }          }
 }  }
   
Line 123  void ox_mpi_slave_init() {
Line 135  void ox_mpi_slave_init() {
                 /* ordering information is not exchanged */                  /* ordering information is not exchanged */
                 /* idx should be equal to i */                  /* idx should be equal to i */
                 idx = get_iofp(i,0,0);                  idx = get_iofp(i,0,0);
                 register_server(0,idx,idx);                  register_server(0,idx,idx,-1);
         }          }
         asir_OperandStackSize = BUFSIZ;          asir_OperandStackSize = BUFSIZ;
         asir_OperandStack = (Obj *)CALLOC(asir_OperandStackSize,sizeof(Obj));          asir_OperandStack = (Obj *)CALLOC(asir_OperandStackSize,sizeof(Obj));
Line 138  void ox_main(int argc,char **argv) {
Line 150  void ox_main(int argc,char **argv) {
         ERR err;          ERR err;
         unsigned int serial;          unsigned int serial;
         int ret;          int ret;
         extern char LastError[];  
   
         ox_asir_init(argc,argv,"ox_asir");          ox_asir_init(argc,argv,"ox_asir");
         if ( do_message )          if ( do_message )
Line 146  void ox_main(int argc,char **argv) {
Line 157  void ox_main(int argc,char **argv) {
         if ( SETJMP(ox_env) ) {          if ( SETJMP(ox_env) ) {
                 while ( NEXT(asir_infile) )                  while ( NEXT(asir_infile) )
                         closecurrentinput();                          closecurrentinput();
                   resetpvs();
                   reset_engine();
                   reset_io();
                 ox_send_sync(0);                  ox_send_sync(0);
         }          }
         while ( 1 ) {          while ( 1 ) {
                 extern int recv_intr;                  extern int recv_intr;
   
                 serial = ox_recv(0,&id,&obj);                  serial = ox_recv(0,&id,&obj);
 #if defined(VISUAL)  #if defined(VISUAL) || defined(__MINGW32__)
                 if ( recv_intr ) {                  if ( recv_intr ) {
                         if ( recv_intr == 1 ) {                          if ( recv_intr == 1 ) {
                                 recv_intr = 0;                                  recv_intr = 0;
Line 174  void ox_main(int argc,char **argv) {
Line 188  void ox_main(int argc,char **argv) {
                                         fprintf(stderr," %s\n",name_of_cmd(cmd));                                          fprintf(stderr," %s\n",name_of_cmd(cmd));
                                 if ( ret = SETJMP(main_env) ) {                                  if ( ret = SETJMP(main_env) ) {
                                         if ( ret == 1 ) {                                          if ( ret == 1 ) {
                                                 create_error(&err,serial,LastError);                                                  create_error(&err,serial,LastError,LastStackTrace);
                                                 asir_push_one((Obj)err);                                                  asir_push_one((Obj)err);
                                                   while ( NEXT(asir_infile) )
                                                           closecurrentinput();
                                                   resetpvs();
                                         }                                          }
                                         break;                                          break;
                                 }                                  }
Line 242  static void asir_do_cmd(int cmd,unsigned int serial)
Line 259  static void asir_do_cmd(int cmd,unsigned int serial)
                 case SM_executeFunction:                  case SM_executeFunction:
                         asir_executeFunction(serial);                          asir_executeFunction(serial);
                         break;                          break;
                   case SM_executeFunctionSync:
                           asir_executeFunctionSync(serial);
                           break;
                 case SM_shutdown:                  case SM_shutdown:
                         asir_terminate(2);                          asir_terminate(2);
                         break;                          break;
Line 258  static void asir_do_cmd(int cmd,unsigned int serial)
Line 278  static void asir_do_cmd(int cmd,unsigned int serial)
                 case SM_pushCMOtag:                  case SM_pushCMOtag:
                         asir_pushCMOtag(serial);                          asir_pushCMOtag(serial);
                         break;                          break;
                   case SM_set_rank_102:
                           asir_set_rank_102(serial);
                           break;
                   case SM_tcp_accept_102:
                           asir_tcp_accept_102(serial);
                           break;
                   case SM_tcp_connect_102:
                           asir_tcp_connect_102(serial);
                           break;
                   case SM_reset_102:
                           asir_reset_102(serial);
                           break;
                   case SM_bcast_102:
                           asir_bcast_102(serial);
                           break;
                   case SM_reduce_102:
                           asir_reduce_102(serial);
                           break;
                 case SM_nop:                  case SM_nop:
                 default:                  default:
                         break;                          break;
Line 337  char *name_of_cmd(int cmd)
Line 375  char *name_of_cmd(int cmd)
                         return "SM_nop";                          return "SM_nop";
                 case SM_pushCMOtag:                  case SM_pushCMOtag:
                         return "SM_pushCMOtag";                          return "SM_pushCMOtag";
                   case SM_set_rank_102:
                           return "SM_set_rank_102";
                           break;
                   case SM_tcp_accept_102:
                           return "SM_tcp_accept_102";
                           break;
                   case SM_tcp_connect_102:
                           return "SM_tcp_connect_102";
                   case SM_reset_102:
                           return "SM_reset_102";
                           break;
                   case SM_bcast_102:
                           return "SM_bcast_102";
                           break;
                   case SM_reduce_102:
                           return "SM_reduce_102";
                           break;
                   case SM_executeFunctionSync:
                           return "SM_executeFunctionSync";
                           break;
                 default:                  default:
                         return "Unknown cmd";                          return "Unknown cmd";
                         break;                          break;
Line 385  void asir_popCMO(unsigned int serial)
Line 443  void asir_popCMO(unsigned int serial)
         if ( valid_as_cmo(obj) )          if ( valid_as_cmo(obj) )
                 ox_send_data(0,obj);                  ox_send_data(0,obj);
         else {          else {
                 create_error(&err,serial,"cannot convert to CMO object");                  create_error(&err,serial,"cannot convert to CMO object",0);
                 ox_send_data(0,err);                  ox_send_data(0,err);
                 asir_push_one(obj);                  asir_push_one(obj);
         }          }
 }  }
   
   void asir_reduce_102(unsigned int serial)
   {
           Q r;
           int root;
           Obj data,obj;
           ERR err;
           STRING op;
           char *opname;
           void (*func)();
   
           func = 0;
           op = (STRING)asir_pop_one();
           opname = BDY(op);
           r = (Q)asir_pop_one();
           root = QTOS(r);
           if ( !strcmp(opname,"+") )
                   func = arf_add;
           else if ( !strcmp(opname,"*") )
                   func = arf_mul;
           if ( !func ) {
                   create_error(&err,serial,"Invalid opration in ox_reduce_102",0);
                   asir_push_one(obj);
           } else
                   ox_reduce_102(root,func);
   }
   
   void asir_bcast_102(unsigned int serial)
   {
           Q r;
           int root;
           Obj data;
   
           r = (Q)asir_pop_one();
           root = QTOS(r);
           ox_bcast_102(root);
   }
   
   void asir_reset_102(unsigned int serial)
   {
           int i,j,id;
           Obj obj;
   
           for ( i = 0; i < myrank_102; i++ )
                   do {
                           ox_recv_102(i,&id,&obj);
                   } while ( id != OX_SYNC_BALL );
           for ( i = myrank_102+1; i < nserver_102; i++ )
                   ox_send_sync_102(i);
   }
   
   void asir_set_rank_102(unsigned int serial)
   {
           Obj obj;
           Q rank,nserver;
           int n,r,stat;
           NODE arg;
           ERR err;
   
           rank = (Q)asir_pop_one();
           nserver = (Q)asir_pop_one();
           stat = 0;
           if ( !nserver || !INT(nserver) || !INT(rank) ) {
                   stat = -1;
           } else {
                   n = QTOS(nserver); r = QTOS(rank);
                   if ( n <= 0 || r < 0 || r >= n ) {
                           stat = -1;
                   }
                   myrank_102 = r;
                   nserver_102 = n;
           }
           if ( !stat ) return;
           else {
                   create_error(&err,serial,"Invalid argument(s) in ox_set_rank_102",0);
                   asir_push_one(obj);
           }
   }
   
   void asir_tcp_accept_102(unsigned int serial)
   {
           Obj obj;
           Q r,p;
           ERR err;
           char port_str[BUFSIZ];
           int port,s,use_unix,rank;
   
           r = (Q)asir_pop_one();
           p = (Q)asir_pop_one();
           if ( IS_CYGWIN || !p || NUM(p) ) {
                   port = QTOS(p);
                   sprintf(port_str,"%d",port);
                   use_unix = 0;
           } else {
                   strcpy(port_str,BDY((STRING)p));
                   use_unix = 1;
           }
           s = try_bind_listen(use_unix,port_str);
           s = try_accept(use_unix,s);
           rank = QTOS((Q)r);
           if ( register_102(s,rank,1) < 0 ) {
                   create_error(&err,serial,
                           "failed to bind or accept in ox_tcp_accept_102",0);
                   asir_push_one((Obj)err);
           }
   }
   
   void asir_tcp_connect_102(unsigned int serial)
   {
           Obj obj;
           Q r,p;
           STRING h;
           ERR err;
           char *host;
           char port_str[BUFSIZ];
           int port,s,use_unix,rank;
   
           r = (Q)asir_pop_one();
           p = (Q)asir_pop_one();
           h = (STRING)asir_pop_one();
           if ( IS_CYGWIN || !p || NUM(p) ) {
                   port = QTOS(p);
                   sprintf(port_str,"%d",port);
                   use_unix = 0;
                   host = BDY((STRING)h);
           } else {
                   strcpy(port_str,BDY((STRING)p));
                   use_unix = 1;
                   host = 0;
           }
           s = try_connect(use_unix,host,port_str);
           rank = QTOS((Q)r);
           if ( register_102(s,rank,1) < 0 ) {
                   create_error(&err,serial,
                           "failed to connect in ox_tcp_connect_102",0);
                   asir_push_one((Obj)err);
           }
   }
   
 void asir_pushCMOtag(unsigned int serial)  void asir_pushCMOtag(unsigned int serial)
 {  {
         Obj obj;          Obj obj;
Line 403  void asir_pushCMOtag(unsigned int serial)
Line 599  void asir_pushCMOtag(unsigned int serial)
                 MKUSINT(ui,tag);                  MKUSINT(ui,tag);
                 asir_push_one((Obj)ui);                  asir_push_one((Obj)ui);
         } else {          } else {
                 create_error(&err,serial,"cannot convert to CMO object");                  create_error(&err,serial,"cannot convert to CMO object",0);
                 asir_push_one((Obj)err);                  asir_push_one((Obj)err);
         }          }
 }  }
   
   void print_to_wfep(Obj obj)
   {
           asir_push_one(obj);
           asir_popString();
   }
   
   extern int wfep_mode;
   
 void asir_popString()  void asir_popString()
 {  {
         Obj val;          Obj val;
         char *buf,*obuf;          char *buf;
         int l;          int l;
         STRING str;          STRING str;
   
         val = asir_pop_one();          val = asir_pop_one();
         if ( !val )          if ( !val )
                 obuf = "0";                  buf = "0";
         else {          else if ( wfep_mode && OID(val) == O_ERR ) {
                   /* XXX : for wfep */
                   ox_send_data(0,val); return;
           } else {
                 l = estimate_length(CO,val);                  l = estimate_length(CO,val);
                 buf = (char *)ALLOCA(l+1);                  buf = (char *)ALLOCA(l+1);
                 soutput_init(buf);                  soutput_init(buf);
                 sprintexpr(CO,val);                  sprintexpr(CO,val);
                 l = strlen(buf);  
                 obuf = (char *)MALLOC(l+1);  
                 strcpy(obuf,buf);  
         }          }
         MKSTR(str,obuf);          MKSTR(str,buf);
         ox_send_data(0,str);          ox_send_data(0,str);
 }  }
   
Line 442  void asir_pops()
Line 646  void asir_pops()
 void asir_setName(unsigned int serial)  void asir_setName(unsigned int serial)
 {  {
         char *name;          char *name;
         int l,n;          size_t l,n;
         char *dummy = "=0;";          char *dummy = "=0;";
         SNODE snode;          SNODE snode;
         ERR err;          ERR err;
Line 453  void asir_setName(unsigned int serial)
Line 657  void asir_setName(unsigned int serial)
         parse_strp = (char *)ALLOCA(n);          parse_strp = (char *)ALLOCA(n);
         sprintf(parse_strp,"%s%s",name,dummy);          sprintf(parse_strp,"%s%s",name,dummy);
         if ( mainparse(&snode) ) {          if ( mainparse(&snode) ) {
                 create_error(&err,serial,"cannot set to variable");                  create_error(&err,serial,"cannot set to variable",0);
                 asir_push_one((Obj)err);                  asir_push_one((Obj)err);
         } else {          } else {
                 FA1((FNODE)FA0(snode)) = (pointer)mkfnode(1,I_FORMULA,asir_pop_one());                  FA1((FNODE)FA0(snode)) = (pointer)mkfnode(1,I_FORMULA,asir_pop_one());
Line 464  void asir_setName(unsigned int serial)
Line 668  void asir_setName(unsigned int serial)
 void asir_evalName(unsigned int serial)  void asir_evalName(unsigned int serial)
 {  {
         char *name;          char *name;
         int l,n;          size_t l,n;
         SNODE snode;          SNODE snode;
         ERR err;          ERR err;
         pointer val;          pointer val;
Line 475  void asir_evalName(unsigned int serial)
Line 679  void asir_evalName(unsigned int serial)
         parse_strp = (char *)ALLOCA(n);          parse_strp = (char *)ALLOCA(n);
         sprintf(parse_strp,"%s;",name);          sprintf(parse_strp,"%s;",name);
         if ( mainparse(&snode) ) {          if ( mainparse(&snode) ) {
                 create_error(&err,serial,"no such variable");                  create_error(&err,serial,"no such variable",0);
                 val = (pointer)err;                  val = (pointer)err;
         } else          } else
                 val = evalstat(snode);                  val = evalstat(snode);
         asir_push_one(val);          asir_push_one(val);
 }  }
   
   char *augment_backslash(char *s)
   {
           char *p,*r;
           int i;
   
           for ( i = 0, p = s; *p; p++, i++ ) if ( *p == '\\' ) i++;
           r = (char *)MALLOC_ATOMIC((i+1)*sizeof(char));
           for ( i = 0, p = s; *p; p++, i++ ) {
                   if ( *p == '\\' ) r[i++] = '\\';
                   r[i] = *p;
           }
           return r;
   }
   
 int asir_executeString()  int asir_executeString()
 {  {
         SNODE snode;          SNODE snode;
         pointer val;          pointer val;
         char *cmd;          char *cmd;
   #if 0
 #if defined(PARI)  #if defined(PARI)
         recover(0);          recover(0);
         /* environement is defined in libpari.a */          /* 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
   #endif
         cmd = ((STRING)asir_pop_one())->body;          cmd = ((STRING)asir_pop_one())->body;
   /* XXX : probably this is useless */
   #if 0
           parse_strp = augment_backslash(cmd);
   #else
         parse_strp = cmd;          parse_strp = cmd;
   #endif
           asir_infile->ln = 1;
         if ( mainparse(&snode) ) {          if ( mainparse(&snode) ) {
                 return -1;                  return -1;
         }          }
Line 549  static void asir_executeFunction(int serial)
Line 777  static void asir_executeFunction(int serial)
         if ( n )          if ( n )
                 NEXT(n1) = 0;                  NEXT(n1) = 0;
   
   #if 0
         if ( !strcmp(func,"load") ) {          if ( !strcmp(func,"load") ) {
                 fname = (STRING)BDY(n);                  fname = (STRING)BDY(n);
                 if ( OID(fname) == O_STR ) {                  if ( OID(fname) == O_STR ) {
Line 563  static void asir_executeFunction(int serial)
Line 792  static void asir_executeFunction(int serial)
                 }                  }
                 result = 0;                  result = 0;
         } else {          } else {
   #endif
                 searchf(noargsysf,func,&f);                  searchf(noargsysf,func,&f);
                 if ( !f )                  if ( !f )
                         searchf(sysf,func,&f);                          gen_searchf_searchonly(func,&f);
                 if ( !f )  
                         searchf(ubinf,func,&f);  
                 if ( !f )  
                         searchf(usrf,func,&f);  
                 if ( !f ) {                  if ( !f ) {
                         sprintf(buf,"executeFunction : the function %s not found",func);                          sprintf(buf,"executeFunction : the function %s not found",func);
                         goto error;                          goto error;
                 } else {                  } else {
                         result = (Obj)bevalf(f,n);                          result = (Obj)bevalf(f,n);
                 }                  }
   #if 0
         }          }
   #endif
           printf("executeFunction done\n");
         asir_push_one(result);          asir_push_one(result);
         return;          return;
   
 error:  error:
         create_error(&err,serial,buf);          create_error(&err,serial,buf,0);
         result = (Obj)err;          result = (Obj)err;
         asir_push_one(result);          asir_push_one(result);
 }  }
   
   static void asir_executeFunctionSync(int serial)
   {
           char *func;
           int argc,i;
           FUNC f;
           Obj result=0;
           NODE n,n1;
           STRING fname;
           char *path;
           ERR err;
           Obj arg;
           static char buf[BUFSIZ];
   
           arg = asir_pop_one();
           if ( !arg || OID(arg) != O_STR ) {
                   sprintf(buf,"executeFunction : invalid function name");
                   goto error;
           } else
                   func = ((STRING)arg)->body;
   
           arg = asir_pop_one();
           if ( !arg || OID(arg) != O_USINT ) {
                   sprintf(buf,"executeFunction : invalid argc");
                   goto error;
           } else
                   argc = (int)(((USINT)arg)->body);
   
           for ( n = 0; argc; argc-- ) {
                   NEXTNODE(n,n1);
                   BDY(n1) = (pointer)asir_pop_one();
           }
           if ( n )
                   NEXT(n1) = 0;
   
           ox_send_data(0,ONE);
   
   #if 0
           if ( !strcmp(func,"load") ) {
                   fname = (STRING)BDY(n);
                   if ( OID(fname) == O_STR ) {
                           searchasirpath(BDY(fname),&path);
                           if ( path ) {
                                   if ( do_message )
                                           fprintf(stderr,"loading %s\n",path);
                                   execasirfile(path);
                           } else
                                   if ( do_message )
                                           fprintf(stderr,"load : %s not found in the search path\n",BDY(fname));
                   }
                   result = 0;
           } else {
   #endif
                   searchf(noargsysf,func,&f);
                   if ( !f )
                           gen_searchf_searchonly(func,&f);
                   if ( !f ) {
                           sprintf(buf,"executeFunction : the function %s not found",func);
                           goto error;
                   } else {
                           result = (Obj)bevalf(f,n);
                   }
   #if 0
           }
   #endif
           printf("executeFunctionSync done\n");
           ox_send_data(0,result);
           return;
   
   error:
           create_error(&err,serial,buf,0);
           result = (Obj)err;
           ox_send_data(0,result);
   }
   
 void asir_end_flush()  void asir_end_flush()
 {  {
         ox_flushing = 0;          ox_flushing = 0;
Line 638  Obj asir_peek_one() {
Line 941  Obj asir_peek_one() {
   
 void ox_asir_init(int argc,char **argv,char *servername)  void ox_asir_init(int argc,char **argv,char *servername)
 {  {
         char ifname[BUFSIZ];          char *ifname;
         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_server_in_X11;          extern int do_server_in_X11;
         extern char displayname[];          extern char displayname[];
         char *getenv();  
         static ox_asir_initialized = 0;          static ox_asir_initialized = 0;
         FILE *ifp;          int do_server_sav;
         char *homedir;  #if !defined(VISUAL) && !defined(__MINGW32__)
         char *ptr;  
 #if !defined(VISUAL)  
         int tmp;          int tmp;
 #endif  #endif
   
 #if !defined(VISUAL) && !defined(MPI)          GC_init();
   #if !defined(VISUAL) && !defined(__MINGW32__) && !defined(MPI)
         do_server_in_X11 = 1; /* XXX */          do_server_in_X11 = 1; /* XXX */
 #endif  #endif
         asir_save_handler();          asir_save_handler();
   #if 0
 #if defined(PARI)  #if defined(PARI)
         risa_pari_init();          risa_pari_init();
 #endif  #endif
   #endif
         srandom((int)get_current_time());          srandom((int)get_current_time());
   
         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 defined(__CYGWIN__)  #if defined(__CYGWIN__)
         if ( !displayname[0] )          if ( !displayname[0] )
Line 681  void ox_asir_init(int argc,char **argv,char *servernam
Line 983  void ox_asir_init(int argc,char **argv,char *servernam
         pf_init();          pf_init();
         sysf_init();          sysf_init();
         parif_init();          parif_init();
 #if defined(VISUAL)          order_init();
   #if defined(VISUAL) || defined(__MINGW32__)
         init_socket();          init_socket();
 #endif  #endif
 #if defined(UINIT)  #if defined(UINIT)
         reg_sysf();          reg_sysf();
 #endif  #endif
 /* if ASIR_CONFIG is set, execute it; else execute .asirrc */          /* the bottom of the input stack */
         if ( ptr = getenv("ASIR_CONFIG") )          input_init(0,"string");
                 strcpy(ifname,ptr);  
         else {  
                 homedir = getenv("HOME");  
                 if ( !homedir ) {  
                         char rootname[BUFSIZ];  
   
                         get_rootdir(rootname,sizeof(rootname));          if ( do_asirrc && (ifname = find_asirrc()) ) {
                         homedir = rootname;                  do_server_sav = do_server_in_X11;
                 }                  do_server_in_X11 = 0;
                 sprintf(ifname,"%s/.asirrc",homedir);                  if ( !SETJMP(main_env) )
                           execasirfile(ifname);
                   do_server_in_X11 = do_server_sav;
         }          }
         if ( do_asirrc && (ifp = fopen(ifname,"r")) ) {  
                 input_init(ifp,ifname);  
                 if ( !SETJMP(main_env) ) {  
                         read_exec_file = 1;  
                         read_eval_loop();  
                         read_exec_file = 0;  
                 }  
                 fclose(ifp);  
         }  
         input_init(0,"string");  
 /* XXX Windows compatibility */  /* XXX Windows compatibility */
         ox_io_init();          ox_io_init();
         create_my_mathcap(servername);          create_my_mathcap(servername);
Line 740  void ox_io_init() {
Line 1031  void ox_io_init() {
   
         I_am_server = 1;          I_am_server = 1;
         endian_init();          endian_init();
 #if defined(VISUAL)  #if defined(VISUAL) || defined(__MINGW32__)
         if ( !ox_sock_id )          if ( !ox_sock_id )
                 exit(0);                  exit(0);
         iofp[0].in = WSIO_open(ox_sock_id,"r");          iofp[0].in = WSIO_open(ox_sock_id,"r");
Line 753  void ox_io_init() {
Line 1044  void ox_io_init() {
         setbuffer(iofp[0].in,(char *)malloc(LBUFSIZ),LBUFSIZ);          setbuffer(iofp[0].in,(char *)malloc(LBUFSIZ),LBUFSIZ);
         setbuffer(iofp[0].out,(char *)malloc(LBUFSIZ),LBUFSIZ);          setbuffer(iofp[0].out,(char *)malloc(LBUFSIZ),LBUFSIZ);
 #endif  #endif
         signal(SIGUSR1,ox_usr1_handler);          set_signal(SIGUSR1,ox_usr1_handler);
 #endif  #endif
         asir_OperandStackSize = BUFSIZ;          asir_OperandStackSize = BUFSIZ;
         asir_OperandStack = (Obj *)CALLOC(asir_OperandStackSize,sizeof(Obj));          asir_OperandStack = (Obj *)CALLOC(asir_OperandStackSize,sizeof(Obj));
Line 767  void ox_io_init() {
Line 1058  void ox_io_init() {
         read_char(iofp[0].in,&rc);          read_char(iofp[0].in,&rc);
         iofp[0].conv = c == rc ? 0 : 1;          iofp[0].conv = c == rc ? 0 : 1;
         /* XXX; for raw I/O */          /* XXX; for raw I/O */
         register_server(0,0,0);          register_server(0,0,0,-1);
 }  }
   
 #if !defined(VISUAL)  #if !defined(VISUAL) && !defined(__MINGW32__)
 /*  /*
  * Library mode functions   * Library mode functions
  */   */
Line 803  int asir_ox_pop_cmo(void *cmo, int limit)
Line 1094  int asir_ox_pop_cmo(void *cmo, int limit)
         obj = asir_pop_one();          obj = asir_pop_one();
         if ( !valid_as_cmo(obj) ) {          if ( !valid_as_cmo(obj) ) {
                 asir_push_one(obj);                  asir_push_one(obj);
                 create_error(&err,0,"The object at the stack top is invalid as a CMO.");                  create_error(&err,0,"The object at the stack top is invalid as a CMO.",0);
                 obj = (Obj)err;                  obj = (Obj)err;
         }          }
         len = count_as_cmo(obj);          len = count_as_cmo(obj);
Line 852  void asir_ox_push_cmd(int cmd)
Line 1143  void asir_ox_push_cmd(int cmd)
         if ( ret = SETJMP(main_env) ) {          if ( ret = SETJMP(main_env) ) {
                 asir_reset_handler();                  asir_reset_handler();
                 if ( ret == 1 ) {                  if ( ret == 1 ) {
                         create_error(&err,0,LastError); /* XXX */                          create_error(&err,0,LastError,LastStackTrace); /* XXX */
                         asir_push_one((Obj)err);                          asir_push_one((Obj)err);
                 }                  }
         } else {          } else {
Line 879  void asir_ox_execute_string(char *s)
Line 1170  void asir_ox_execute_string(char *s)
         if ( ret = SETJMP(main_env) ) {          if ( ret = SETJMP(main_env) ) {
                 asir_reset_handler();                  asir_reset_handler();
                 if ( ret == 1 ) {                  if ( ret == 1 ) {
                         create_error(&err,0,LastError); /* XXX */                          create_error(&err,0,LastError,LastStackTrace); /* XXX */
                         asir_push_one((Obj)err);                          asir_push_one((Obj)err);
                 }                  }
         } else {          } else {
Line 932  int asir_ox_peek_cmo_string_length()
Line 1223  int asir_ox_peek_cmo_string_length()
 int asir_ox_init(int byteorder)  int asir_ox_init(int byteorder)
 {  {
         int tmp;          int tmp;
         char ifname[BUFSIZ];          char *ifname;
         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_server_in_X11;          extern int do_server_in_X11;
         char *getenv();  
         static ox_asir_initialized = 0;          static ox_asir_initialized = 0;
         FILE *ifp;  
   
 #if !defined(VISUAL) && !defined(MPI)          GC_init();
   #if !defined(VISUAL) && !defined(__MINGW32__) && !defined(MPI)
         do_server_in_X11 = 0; /* XXX */          do_server_in_X11 = 0; /* XXX */
 #endif  #endif
         asir_save_handler();          asir_save_handler();
   #if 0
 #if defined(PARI)  #if defined(PARI)
         risa_pari_init();          risa_pari_init();
 #endif  #endif
   #endif
         srandom((int)get_current_time());          srandom((int)get_current_time());
   
         rtime_init();          rtime_init();
         env_init();          env_init();
         endian_init();          endian_init();
         GC_init();  
 /*      process_args(argc,argv); */  /*      process_args(argc,argv); */
         output_init();          output_init();
         arf_init();          arf_init();
Line 965  int asir_ox_init(int byteorder)
Line 1255  int asir_ox_init(int byteorder)
         pf_init();          pf_init();
         sysf_init();          sysf_init();
         parif_init();          parif_init();
 #if defined(VISUAL)  #if defined(VISUAL) || defined(__MINGW32__)
         init_socket();          init_socket();
 #endif  #endif
 #if defined(UINIT)  #if defined(UINIT)
         reg_sysf();          reg_sysf();
 #endif  #endif
         sprintf(ifname,"%s/.asirrc",getenv("HOME"));  
         if ( do_asirrc && (ifp = fopen(ifname,"r")) ) {  
                 input_init(ifp,ifname);  
                 if ( !SETJMP(main_env) ) {  
                         read_exec_file = 1;  
                         read_eval_loop();  
                         read_exec_file = 0;  
                 }  
                 fclose(ifp);  
         }  
         input_init(0,"string");          input_init(0,"string");
           if ( do_asirrc && (ifname = find_asirrc()) ) {
                   if ( !SETJMP(main_env) )
                           execasirfile(ifname);
           }
   
         asir_OperandStackSize = BUFSIZ;          asir_OperandStackSize = BUFSIZ;
         asir_OperandStack = (Obj *)CALLOC(asir_OperandStackSize,sizeof(Obj));          asir_OperandStack = (Obj *)CALLOC(asir_OperandStackSize,sizeof(Obj));

Legend:
Removed from v.1.43  
changed lines
  Added in v.1.77

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