[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.1 and 1.49

version 1.1, 1999/12/03 07:39:11 version 1.49, 2003/12/12 09:01:11
Line 1 
Line 1 
 /* $OpenXM: OpenXM/src/asir99/io/ox_asir.c,v 1.5 1999/11/18 02:24:02 noro Exp $ */  /*
    * Copyright (c) 1994-2000 FUJITSU LABORATORIES LIMITED
    * All rights reserved.
    *
    * FUJITSU LABORATORIES LIMITED ("FLL") hereby grants you a limited,
    * non-exclusive and royalty-free license to use, copy, modify and
    * redistribute, solely for non-commercial and non-profit purposes, the
    * computer program, "Risa/Asir" ("SOFTWARE"), subject to the terms and
    * conditions of this Agreement. For the avoidance of doubt, you acquire
    * only a limited right to use the SOFTWARE hereunder, and FLL or any
    * third party developer retains all rights, including but not limited to
    * copyrights, in and to the SOFTWARE.
    *
    * (1) FLL does not grant you a license in any way for commercial
    * purposes. You may use the SOFTWARE only for non-commercial and
    * non-profit purposes only, such as academic, research and internal
    * business use.
    * (2) The SOFTWARE is protected by the Copyright Law of Japan and
    * international copyright treaties. If you make copies of the SOFTWARE,
    * with or without modification, as permitted hereunder, you shall affix
    * to all such copies of the SOFTWARE the above copyright notice.
    * (3) An explicit reference to this SOFTWARE and its copyright owner
    * shall be made on your publication or presentation in any form of the
    * results obtained by use of the SOFTWARE.
    * (4) In the event that you modify the SOFTWARE, you shall notify FLL by
    * e-mail at risa-admin@sec.flab.fujitsu.co.jp of the detailed specification
    * for such modification or the source code of the modified part of the
    * SOFTWARE.
    *
    * THE SOFTWARE IS PROVIDED AS IS WITHOUT ANY WARRANTY OF ANY KIND. FLL
    * MAKES ABSOLUTELY NO WARRANTIES, EXPRESSED, IMPLIED OR STATUTORY, AND
    * EXPRESSLY DISCLAIMS ANY IMPLIED WARRANTY OF MERCHANTABILITY, FITNESS
    * FOR A PARTICULAR PURPOSE OR NONINFRINGEMENT OF THIRD PARTIES'
    * RIGHTS. NO FLL DEALER, AGENT, EMPLOYEES IS AUTHORIZED TO MAKE ANY
    * MODIFICATIONS, EXTENSIONS, OR ADDITIONS TO THIS WARRANTY.
    * UNDER NO CIRCUMSTANCES AND UNDER NO LEGAL THEORY, TORT, CONTRACT,
    * OR OTHERWISE, SHALL FLL BE LIABLE TO YOU OR ANY OTHER PERSON FOR ANY
    * DIRECT, INDIRECT, SPECIAL, INCIDENTAL, PUNITIVE OR CONSEQUENTIAL
    * DAMAGES OF ANY CHARACTER, INCLUDING, WITHOUT LIMITATION, DAMAGES
    * ARISING OUT OF OR RELATING TO THE SOFTWARE OR THIS AGREEMENT, DAMAGES
    * FOR LOSS OF GOODWILL, WORK STOPPAGE, OR LOSS OF DATA, OR FOR ANY
    * DAMAGES, EVEN IF FLL SHALL HAVE BEEN INFORMED OF THE POSSIBILITY OF
    * SUCH DAMAGES, OR FOR ANY CLAIM BY ANY OTHER PARTY. EVEN IF A PART
    * OF THE SOFTWARE HAS BEEN DEVELOPED BY A THIRD PARTY, THE THIRD PARTY
    * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE,
    * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE.
    * $OpenXM: OpenXM_contrib2/asir2000/io/ox_asir.c,v 1.48 2003/12/12 04:59:59 noro Exp $
   */
 #include "ca.h"  #include "ca.h"
 #include "parse.h"  #include "parse.h"
   #include "signal.h"
 #include "ox.h"  #include "ox.h"
 #include "version.h"  #include "version.h"
   #if defined(PARI)
   #include "genpari.h"
   #endif
   
 void ox_usr1_handler();  void ox_usr1_handler();
   int asir_ox_init();
   
   /* environement is defined in libpari.a */
 extern jmp_buf environnement;  extern jmp_buf environnement;
   extern int myrank_102,nserver_102;
   
 extern int do_message;  extern int do_message;
 extern int ox_flushing;  extern int ox_flushing;
 extern jmp_buf ox_env;  extern JMP_BUF ox_env;
 extern MATHCAP my_mathcap;  extern MATHCAP my_mathcap;
   
   extern int little_endian,ox_sock_id;
   
 int ox_sock_id;  int ox_sock_id;
   int lib_ox_need_conv;
   
 static int asir_OperandStackSize;  void create_error(ERR *,unsigned int ,char *);
 static Obj *asir_OperandStack;  
 static int asir_OperandStackPtr = -1;  
   
 static void create_error(ERR *,unsigned int ,char *);  int asir_OperandStackSize;
 static void ox_io_init();  Obj *asir_OperandStack;
 static void ox_asir_init(int,char **);  int asir_OperandStackPtr = -1;
 static Obj asir_pop_one();  
 static void asir_push_one(Obj);  void ox_io_init();
 static void asir_end_flush();  void ox_asir_init(int,char **,char *);
   Obj asir_pop_one();
   Obj asir_peek_one();
   void asir_push_one(Obj);
   void asir_end_flush();
   int asir_executeString();
   void asir_evalName(unsigned int);
   void asir_setName(unsigned int);
   void asir_pops();
   void asir_popString();
   void asir_popCMO(unsigned int);
   void asir_popSerializedLocalObject();
   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();
   char *name_of_cmd(int);
   char *name_of_id(int);
   
   static void asir_do_cmd(int,unsigned int);
 static void asir_executeFunction(int);  static void asir_executeFunction(int);
 static int asir_executeString();  
 static void asir_evalName(unsigned int);  
 static void asir_setName(unsigned int);  
 static void asir_pops();  
 static void asir_popString();  
 static void asir_popCMO(unsigned int);  
 static void asir_popSerializedLocalObject();  
 static LIST asir_GetErrorList();  
 static char *name_of_cmd(unsigned int);  
 static char *name_of_id(int);  
 static void asir_do_cmd(unsigned int,unsigned int);  
   
 #if MPI  #if defined(MPI)
   /* XXX : currently MPI version supports only a homogeneous cluster. */
   
 extern int mpi_nprocs,mpi_myid;  extern int mpi_nprocs,mpi_myid;
   
 void ox_mpi_master_init() {  void ox_mpi_master_init() {
         int i,idx,ret;          int i,idx;
   
         for ( i = 1; i < mpi_nprocs; i++ ) {          for ( i = 0; i < mpi_nprocs; i++ ) {
                 /* client mode */                  /* ordering information is not exchanged */
                   /* idx should be equal to i */
                 idx = get_iofp(i,0,0);                  idx = get_iofp(i,0,0);
                 ret = register_server(idx,idx);                  register_server(0,idx,idx);
         }          }
 }  }
   
 void ox_mpi_slave_init() {  void ox_mpi_slave_init() {
           int i,idx;
   
         endian_init();          endian_init();
         /* server mode */  
         get_iofp(0,0,1);  
         fclose(stdin);          fclose(stdin);
           for ( i = 0; i < mpi_nprocs; i++ ) {
                   /* ordering information is not exchanged */
                   /* idx should be equal to i */
                   idx = get_iofp(i,0,0);
                   register_server(0,idx,idx);
           }
         asir_OperandStackSize = BUFSIZ;          asir_OperandStackSize = BUFSIZ;
         asir_OperandStack = (Obj *)CALLOC(asir_OperandStackSize,sizeof(Obj));          asir_OperandStack = (Obj *)CALLOC(asir_OperandStackSize,sizeof(Obj));
         asir_OperandStackPtr = -1;          asir_OperandStackPtr = -1;
 }  }
 #endif  #endif
   
 static void create_error(ERR *err,unsigned int serial,char *msg)  
 {  
         int len;  
         USINT ui;  
         NODE n,n1;  
         LIST list;  
         char *msg1;  
         STRING errmsg;  
   
         MKUSINT(ui,serial);  
         len = strlen(msg);  
         msg1 = (char *)MALLOC(len+1);  
         strcpy(msg1,msg);  
         MKSTR(errmsg,msg1);  
         MKNODE(n1,errmsg,0); MKNODE(n,ui,n1); MKLIST(list,n);  
         MKERR(*err,list);  
 }  
   
 void ox_main(int argc,char **argv) {  void ox_main(int argc,char **argv) {
         int id;          int id;
         unsigned int cmd;          int cmd;
         Obj obj;          Obj obj;
         USINT ui;  
         ERR err;          ERR err;
         LIST list;  
         NODE n,n1;  
         unsigned int serial;          unsigned int serial;
         int ret;          int ret;
         extern char LastError[];          extern char LastError[];
   
         ox_asir_init(argc,argv);          ox_asir_init(argc,argv,"ox_asir");
         if ( do_message )          if ( do_message )
                 fprintf(stderr,"I'm an ox_asir, Version %d.\n",ASIR_VERSION);                  fprintf(stderr,"I'm an ox_asir, Version %d.\n",ASIR_VERSION);
         if ( setjmp(ox_env) ) {          if ( SETJMP(ox_env) ) {
                 while ( NEXT(asir_infile) )                  while ( NEXT(asir_infile) )
                         closecurrentinput();                          closecurrentinput();
                 ox_send_sync(0);                  ox_send_sync(0);
Line 124  void ox_main(int argc,char **argv) {
Line 179  void ox_main(int argc,char **argv) {
                                         break;                                          break;
                                 if ( do_message )                                  if ( do_message )
                                         fprintf(stderr," %s\n",name_of_cmd(cmd));                                          fprintf(stderr," %s\n",name_of_cmd(cmd));
                                 if ( ret = setjmp(env) ) {                                  if ( ret = SETJMP(main_env) ) {
                                         if ( ret == 1 ) {                                          if ( ret == 1 ) {
                                                 create_error(&err,serial,LastError);                                                  create_error(&err,serial,LastError);
                                                 asir_push_one((Obj)err);                                                  asir_push_one((Obj)err);
Line 152  void ox_main(int argc,char **argv) {
Line 207  void ox_main(int argc,char **argv) {
         }          }
 }  }
   
 static void asir_do_cmd(unsigned int cmd,unsigned int serial)  static void asir_do_cmd(int cmd,unsigned int serial)
 {  {
         MATHCAP client_mathcap;          MATHCAP client_mathcap;
         Q q;          Q q;
Line 207  static void asir_do_cmd(unsigned int cmd,unsigned int 
Line 262  static void asir_do_cmd(unsigned int cmd,unsigned int 
                         client_mathcap = (MATHCAP)asir_pop_one();                          client_mathcap = (MATHCAP)asir_pop_one();
                         store_remote_mathcap(0,client_mathcap);                          store_remote_mathcap(0,client_mathcap);
                         break;                          break;
                   case SM_pushCMOtag:
                           asir_pushCMOtag(serial);
                           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;
         }          }
 }  }
   
 static char *name_of_id(int id)  char *name_of_id(int id)
 {  {
         switch ( id ) {          switch ( id ) {
                 case OX_COMMAND:                  case OX_COMMAND:
Line 234  static char *name_of_id(int id)
Line 310  static char *name_of_id(int id)
         }          }
 }  }
   
 static char *name_of_cmd(unsigned cmd)  char *name_of_cmd(int cmd)
 {  {
         switch ( cmd ) {          switch ( cmd ) {
                 case SM_popSerializedLocalObject:                  case SM_popSerializedLocalObject:
Line 284  static char *name_of_cmd(unsigned cmd)
Line 360  static char *name_of_cmd(unsigned cmd)
                         break;                          break;
                 case SM_nop:                  case SM_nop:
                         return "SM_nop";                          return "SM_nop";
                   case 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;
                 default:                  default:
                         return "Unknown cmd";                          return "Unknown cmd";
                         break;                          break;
         }          }
 }  }
   
 static LIST asir_GetErrorList()  LIST asir_GetErrorList()
 {  {
         int i;          int i;
         NODE n,n0;          NODE n,n0;
Line 307  static LIST asir_GetErrorList()
Line 402  static LIST asir_GetErrorList()
         return err;          return err;
 }  }
   
 static void asir_popSerializedLocalObject()  void asir_popSerializedLocalObject()
 {  {
         Obj obj;          Obj obj;
         VL t,vl;          VL t,vl;
Line 323  static void asir_popSerializedLocalObject()
Line 418  static void asir_popSerializedLocalObject()
         ox_send_cmd(0,SM_endBlock);          ox_send_cmd(0,SM_endBlock);
 }  }
   
 static void asir_popCMO(unsigned int serial)  void asir_popCMO(unsigned int serial)
 {  {
         Obj obj;          Obj obj;
         ERR err;          ERR err;
Line 338  static void asir_popCMO(unsigned int serial)
Line 433  static void asir_popCMO(unsigned int serial)
         }          }
 }  }
   
 static void asir_popString()  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");
                   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; 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");
                   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");
                   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");
                   asir_push_one((Obj)err);
           }
   }
   
   void asir_pushCMOtag(unsigned int serial)
   {
           Obj obj;
           ERR err;
           USINT ui;
           int tag;
   
           obj = asir_peek_one();
           if ( cmo_tag(obj,&tag) ) {
                   MKUSINT(ui,tag);
                   asir_push_one((Obj)ui);
           } else {
                   create_error(&err,serial,"cannot convert to CMO object");
                   asir_push_one((Obj)err);
           }
   }
   
   void asir_popString()
   {
         Obj val;          Obj val;
         char *buf,*obuf;          char *buf,*obuf;
         int l;          int l;
Line 347  static void asir_popString()
Line 597  static void asir_popString()
   
         val = asir_pop_one();          val = asir_pop_one();
         if ( !val )          if ( !val )
                 obuf = 0;                  obuf = "0";
         else {          else {
                 l = estimate_length(CO,val);                  l = estimate_length(CO,val);
                 buf = (char *)ALLOCA(l+1);                  buf = (char *)ALLOCA(l+1);
Line 361  static void asir_popString()
Line 611  static void asir_popString()
         ox_send_data(0,str);          ox_send_data(0,str);
 }  }
   
 static void asir_pops()  void asir_pops()
 {  {
         int n;          int n;
   
Line 369  static void asir_pops()
Line 619  static void asir_pops()
         asir_OperandStackPtr = MAX(asir_OperandStackPtr-n,-1);          asir_OperandStackPtr = MAX(asir_OperandStackPtr-n,-1);
 }  }
   
 static void asir_setName(unsigned int serial)  void asir_setName(unsigned int serial)
 {  {
         char *name;          char *name;
         int l,n;          int l,n;
Line 391  static void asir_setName(unsigned int serial)
Line 641  static void asir_setName(unsigned int serial)
         }          }
 }  }
   
 static void asir_evalName(unsigned int serial)  void asir_evalName(unsigned int serial)
 {  {
         char *name;          char *name;
         int l,n;          int l,n;
Line 412  static void asir_evalName(unsigned int serial)
Line 662  static void asir_evalName(unsigned int serial)
         asir_push_one(val);          asir_push_one(val);
 }  }
   
 static int asir_executeString()  int asir_executeString()
 {  {
         SNODE snode;          SNODE snode;
         pointer val;          pointer val;
         char *cmd;          char *cmd;
 #if PARI  #if defined(PARI)
         recover(0);          recover(0);
           /* environement is defined in libpari.a */
         if ( setjmp(environnement) ) {          if ( setjmp(environnement) ) {
                 avma = top; recover(1);                  avma = top; recover(1);
                 resetenv("");                  resetenv("");
Line 450  static void asir_executeFunction(int serial)
Line 701  static void asir_executeFunction(int serial)
         int argc;          int argc;
         FUNC f;          FUNC f;
         Obj result;          Obj result;
         VL vl;  
         NODE n,n1;          NODE n,n1;
         STRING fname;          STRING fname;
         char *path;          char *path;
         USINT ui;  
         ERR err;          ERR err;
           Obj arg;
         static char buf[BUFSIZ];          static char buf[BUFSIZ];
   
         func = ((STRING)asir_pop_one())->body;          arg = asir_pop_one();
         argc = (int)(((USINT)asir_pop_one())->body);          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-- ) {          for ( n = 0; argc; argc-- ) {
                 NEXTNODE(n,n1);                  NEXTNODE(n,n1);
                 BDY(n1) = (pointer)asir_pop_one();                  BDY(n1) = (pointer)asir_pop_one();
Line 491  static void asir_executeFunction(int serial)
Line 752  static void asir_executeFunction(int serial)
                         searchf(usrf,func,&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);
                         create_error(&err,serial,buf);                          goto error;
                         result = (Obj)err;  
                 } else {                  } else {
                         result = (Obj)bevalf(f,n);                          result = (Obj)bevalf(f,n);
                 }                  }
         }          }
         asir_push_one(result);          asir_push_one(result);
           return;
   
   error:
           create_error(&err,serial,buf);
           result = (Obj)err;
           asir_push_one(result);
 }  }
   
 static void asir_end_flush()  void asir_end_flush()
 {  {
         ox_flushing = 0;          ox_flushing = 0;
 }  }
Line 512  static void asir_end_flush()
Line 778  static void asir_end_flush()
 */  */
   
   
 static void asir_push_one(Obj obj)  void asir_push_one(Obj obj)
 {  {
         if ( !obj || OID(obj) != O_VOID ) {          if ( !obj || OID(obj) != O_VOID ) {
                 asir_OperandStackPtr++;                  asir_OperandStackPtr++;
Line 526  static void asir_push_one(Obj obj)
Line 792  static void asir_push_one(Obj obj)
         }          }
 }  }
   
 static Obj asir_pop_one() {  Obj asir_pop_one() {
         if ( asir_OperandStackPtr < 0 ) {          if ( asir_OperandStackPtr < 0 ) {
                 if ( do_message )                  if ( do_message )
                         fprintf(stderr,"OperandStack underflow");                          fprintf(stderr,"OperandStack underflow");
Line 538  static Obj asir_pop_one() {
Line 804  static Obj asir_pop_one() {
         }          }
 }  }
   
 static void ox_asir_init(int argc,char **argv)  Obj asir_peek_one() {
           if ( asir_OperandStackPtr < 0 ) {
                   if ( do_message )
                           fprintf(stderr,"OperandStack underflow");
                   return 0;
           } else {
                   if ( do_message )
                           fprintf(stderr,"peek at %d\n",asir_OperandStackPtr);
                   return asir_OperandStack[asir_OperandStackPtr];
           }
   }
   
   void ox_asir_init(int argc,char **argv,char *servername)
 {  {
         int tmp;  
         char ifname[BUFSIZ];          char ifname[BUFSIZ];
         extern int GC_dont_gc;          extern int GC_dont_gc;
         extern int read_exec_file;          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[];
         char *getenv();          char *getenv();
         static ox_asir_initialized = 0;          static ox_asir_initialized = 0;
         FILE *ifp;          FILE *ifp;
           char *homedir;
           char *ptr;
   #if !defined(VISUAL)
           int tmp;
   #endif
   
 #if !defined(VISUAL) && !MPI  #if !defined(VISUAL) && !defined(MPI)
         do_server_in_X11 = 1; /* XXX */          do_server_in_X11 = 1; /* XXX */
 #endif  #endif
         asir_save_handler();          asir_save_handler();
 #if PARI  #if defined(PARI)
         risa_pari_init();          risa_pari_init();
 #endif  #endif
         srandom((int)get_current_time());          srandom((int)get_current_time());
   
 #if defined(THINK_C)  
         param_init();  
 #endif  
         StackBottom = &tmp + 1; /* XXX */  
         rtime_init();          rtime_init();
         env_init();          env_init();
         endian_init();          endian_init();
 #if !defined(VISUAL) && !defined(THINK_C)  
 /*      check_key(); */  
 #endif  
         GC_init();          GC_init();
           cppname_init();
         process_args(--argc,++argv);          process_args(--argc,++argv);
   #if defined(__CYGWIN__)
           if ( !displayname[0] )
                   do_server_in_X11 = 0; /* XXX */
   #endif
         output_init();          output_init();
         arf_init();          arf_init();
         nglob_init();          nglob_init();
Line 587  static void ox_asir_init(int argc,char **argv)
Line 868  static void ox_asir_init(int argc,char **argv)
 #if defined(UINIT)  #if defined(UINIT)
         reg_sysf();          reg_sysf();
 #endif  #endif
 #if defined(THINK_C)  /* if ASIR_CONFIG is set, execute it; else execute .asirrc */
         sprintf(ifname,"asirrc");          if ( ptr = getenv("ASIR_CONFIG") )
 #else                  strcpy(ifname,ptr);
         sprintf(ifname,"%s/.asirrc",getenv("HOME"));          else {
 #endif                  homedir = getenv("HOME");
                   if ( !homedir ) {
                           char rootname[BUFSIZ];
   
                           get_rootdir(rootname,sizeof(rootname));
                           homedir = rootname;
                   }
                   sprintf(ifname,"%s/.asirrc",homedir);
           }
         if ( do_asirrc && (ifp = fopen(ifname,"r")) ) {          if ( do_asirrc && (ifp = fopen(ifname,"r")) ) {
                 input_init(ifp,ifname);                  input_init(ifp,ifname);
                 if ( !setjmp(env) ) {                  if ( !SETJMP(main_env) ) {
                         read_exec_file = 1;                          read_exec_file = 1;
                         read_eval_loop();                          read_eval_loop();
                         read_exec_file = 0;                          read_exec_file = 0;
Line 602  static void ox_asir_init(int argc,char **argv)
Line 891  static void ox_asir_init(int argc,char **argv)
                 fclose(ifp);                  fclose(ifp);
         }          }
         input_init(0,"string");          input_init(0,"string");
 #if !MPI  /* XXX Windows compatibility */
         ox_io_init();          ox_io_init();
 #endif          create_my_mathcap(servername);
         create_my_mathcap("ox_asir");  
 }  }
   
 static void ox_io_init() {  void ox_io_init() {
         unsigned char c,rc;          unsigned char c,rc;
         extern int little_endian,ox_sock_id;          extern int I_am_server;
   
           /* XXX : ssh forwards stdin to a remote host on PC Unix */
   #if defined(linux)
   #include <sys/param.h>
           int i;
   
           close(0);
           for ( i = 5; i < NOFILE; i++ )
                   close(i);
   #elif defined(__FreeBSD__)
   #include <sys/resource.h>
           int i;
           struct rlimit rl;
   
           getrlimit(RLIMIT_NOFILE,&rl);
           close(0);
           for ( i = 5; i < rl.rlim_cur; i++ )
                   close(i);
   #endif
   
           I_am_server = 1;
         endian_init();          endian_init();
 #if defined(VISUAL)  #if defined(VISUAL)
         if ( !ox_sock_id )          if ( !ox_sock_id )
Line 622  static void ox_io_init() {
Line 930  static void ox_io_init() {
         iofp[0].in = fdopen(3,"r");          iofp[0].in = fdopen(3,"r");
         iofp[0].out = fdopen(4,"w");          iofp[0].out = fdopen(4,"w");
   
   #if !defined(__CYGWIN__)
         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
         signal(SIGUSR1,ox_usr1_handler);          signal(SIGUSR1,ox_usr1_handler);
 #endif  #endif
         asir_OperandStackSize = BUFSIZ;          asir_OperandStackSize = BUFSIZ;
Line 637  static void ox_io_init() {
Line 947  static void ox_io_init() {
         write_char(iofp[0].out,&c); ox_flush_stream_force(0);          write_char(iofp[0].out,&c); ox_flush_stream_force(0);
         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 */
           register_server(0,0,0);
 }  }
   
   #if !defined(VISUAL)
   /*
    * Library mode functions
    */
   
   /*
    * Converts a binary encoded CMO into a risa object
    * and pushes it onto the stack.
    */
   
   void asir_ox_push_cmo(void *cmo)
   {
           Obj obj;
   
           ox_copy_init(cmo);
           ox_buf_to_obj_as_cmo(&obj);
           asir_push_one(obj);
   }
   
   /*
    * Pop an object from the stack and converts it
    * into a binary encoded CMO.
    */
   
   int asir_ox_pop_cmo(void *cmo, int limit)
   {
           Obj obj;
           int len;
           ERR err;
   
           obj = asir_pop_one();
           if ( !valid_as_cmo(obj) ) {
                   asir_push_one(obj);
                   create_error(&err,0,"The object at the stack top is invalid as a CMO.");
                   obj = (Obj)err;
           }
           len = count_as_cmo(obj);
           if ( len <= limit ) {
                   ox_copy_init(cmo);
                   ox_obj_to_buf_as_cmo(obj);
                   return len;
           } else
                   return -1;
   }
   
   int asir_ox_pop_string(void *string, int limit)
   {
           Obj val;
           int l;
   
           val = asir_pop_one();
           if ( !val ) {
                   if ( limit >= 2 ) {
                           sprintf(string,"0");
                           l = strlen(string);
                   } else
                           l = -1;
           } else {
                   l = estimate_length(CO,val);
                   if ( l+1 <= limit ) {
                           soutput_init(string);
                           sprintexpr(CO,val);
                           l = strlen(string);
                   } else
                           l = -1;
           }
           return l;
   }
   
   /*
    * Executes an SM command.
    */
   
   void asir_ox_push_cmd(int cmd)
   {
           int ret;
           ERR err;
           extern char LastError[];
   
           if ( ret = SETJMP(main_env) ) {
                   asir_reset_handler();
                   if ( ret == 1 ) {
                           create_error(&err,0,LastError); /* XXX */
                           asir_push_one((Obj)err);
                   }
           } else {
                   asir_save_handler();
                   asir_set_handler();
                   asir_do_cmd(cmd,0);
                   asir_reset_handler();
           }
   }
   
   /*
    * Executes a string written in Asir.
    */
   
   void asir_ox_execute_string(char *s)
   {
           STRING str;
           int ret;
           ERR err;
           extern char LastError[];
   
           MKSTR(str,s);
           asir_push_one((Obj)str);
           if ( ret = SETJMP(main_env) ) {
                   asir_reset_handler();
                   if ( ret == 1 ) {
                           create_error(&err,0,LastError); /* XXX */
                           asir_push_one((Obj)err);
                   }
           } else {
                   asir_save_handler();
                   asir_set_handler();
                   asir_executeString();
                   asir_reset_handler();
           }
   }
   
   /*
    * Returns the size as a CMO of the object
    * at the top of the stack.
    */
   
   int asir_ox_peek_cmo_size()
   {
           Obj obj;
           int len;
   
           obj = asir_peek_one();
           if ( !valid_as_cmo(obj) ) {
                   fprintf(stderr,"The object at the stack top is invalid as a CMO.\n");
                   return 0;
           }
           len = count_as_cmo(obj);
           return len;
   }
   
   int asir_ox_peek_cmo_string_length()
   {
           Obj obj;
           int len;
   
           obj = asir_peek_one();
           if ( !valid_as_cmo(obj) ) {
                   fprintf(stderr,"The object at the stack top is invalid as a CMO.\n");
                   return 0;
           }
           len = estimate_length(CO,obj);
           return len+1;
   }
   
   /*
    * Initialization.
    * byteorder=0 => native
    *          =1 => network byte order
    */
   
   int asir_ox_init(int byteorder)
   {
           int tmp;
           char ifname[BUFSIZ];
           extern int GC_dont_gc;
           extern int read_exec_file;
           extern int do_asirrc;
           extern int do_server_in_X11;
           char *getenv();
           static ox_asir_initialized = 0;
           FILE *ifp;
   
   #if !defined(VISUAL) && !defined(MPI)
           do_server_in_X11 = 0; /* XXX */
   #endif
           asir_save_handler();
   #if defined(PARI)
           risa_pari_init();
   #endif
           srandom((int)get_current_time());
   
           rtime_init();
           env_init();
           endian_init();
           GC_init();
   /*      process_args(argc,argv); */
           output_init();
           arf_init();
           nglob_init();
           glob_init();
           sig_init();
           tty_init();
           debug_init();
           pf_init();
           sysf_init();
           parif_init();
   #if defined(VISUAL)
           init_socket();
   #endif
   #if defined(UINIT)
           reg_sysf();
   #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");
   
           asir_OperandStackSize = BUFSIZ;
           asir_OperandStack = (Obj *)CALLOC(asir_OperandStackSize,sizeof(Obj));
           asir_OperandStackPtr = -1;
           if ( little_endian && byteorder )
                   lib_ox_need_conv = 1;
           else
                   lib_ox_need_conv = 0;
           do_message = 0;
           create_my_mathcap("ox_asir");
           asir_reset_handler();
           return 0;
   }
   #endif

Legend:
Removed from v.1.1  
changed lines
  Added in v.1.49

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