[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.19 and 1.28

version 1.19, 2000/09/12 06:05:30 version 1.28, 2001/10/05 01:38:21
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.18 2000/09/07 23:59:55 noro Exp $   * $OpenXM: OpenXM_contrib2/asir2000/io/ox_asir.c,v 1.27 2001/09/20 23:11:42 noro Exp $
 */  */
 #include "ca.h"  #include "ca.h"
 #include "parse.h"  #include "parse.h"
Line 72  int lib_ox_need_conv;
Line 72  int lib_ox_need_conv;
   
 void create_error(ERR *,unsigned int ,char *);  void create_error(ERR *,unsigned int ,char *);
   
 static int asir_OperandStackSize;  int asir_OperandStackSize;
 static Obj *asir_OperandStack;  Obj *asir_OperandStack;
 static int asir_OperandStackPtr = -1;  int asir_OperandStackPtr = -1;
   
 static void ox_io_init();  void ox_io_init();
 static void ox_asir_init(int,char **);  void ox_asir_init(int,char **);
 static Obj asir_pop_one();  Obj asir_pop_one();
 static Obj asir_peek_one();  Obj asir_peek_one();
 static void asir_push_one(Obj);  void asir_push_one(Obj);
 static void asir_end_flush();  void asir_end_flush();
 static void asir_executeFunction(int);  int asir_executeString();
 static int asir_executeString();  void asir_evalName(unsigned int);
 static void asir_evalName(unsigned int);  void asir_setName(unsigned int);
 static void asir_setName(unsigned int);  void asir_pops();
 static void asir_pops();  void asir_popString();
 static void asir_popString();  void asir_popCMO(unsigned int);
 static void asir_popCMO(unsigned int);  void asir_popSerializedLocalObject();
 static void asir_popSerializedLocalObject();  void asir_pushCMOtag(unsigned int);
 static void asir_pushCMOtag(unsigned int);  LIST asir_GetErrorList();
 static LIST asir_GetErrorList();  char *name_of_cmd(int);
 static char *name_of_cmd(int);  char *name_of_id(int);
 static 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);
   
 #if MPI  #if MPI
 /* XXX : currently MPI version supports only a homogeneous cluster. */  /* XXX : currently MPI version supports only a homogeneous cluster. */
Line 173  void ox_main(int argc,char **argv) {
Line 174  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 265  static void asir_do_cmd(int cmd,unsigned int serial)
Line 266  static void asir_do_cmd(int cmd,unsigned int serial)
         }          }
 }  }
   
 static char *name_of_id(int id)  char *name_of_id(int id)
 {  {
         switch ( id ) {          switch ( id ) {
                 case OX_COMMAND:                  case OX_COMMAND:
Line 286  static char *name_of_id(int id)
Line 287  static char *name_of_id(int id)
         }          }
 }  }
   
 static char *name_of_cmd(int cmd)  char *name_of_cmd(int cmd)
 {  {
         switch ( cmd ) {          switch ( cmd ) {
                 case SM_popSerializedLocalObject:                  case SM_popSerializedLocalObject:
Line 344  static char *name_of_cmd(int cmd)
Line 345  static char *name_of_cmd(int cmd)
         }          }
 }  }
   
 static LIST asir_GetErrorList()  LIST asir_GetErrorList()
 {  {
         int i;          int i;
         NODE n,n0;          NODE n,n0;
Line 361  static LIST asir_GetErrorList()
Line 362  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 377  static void asir_popSerializedLocalObject()
Line 378  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 392  static void asir_popCMO(unsigned int serial)
Line 393  static void asir_popCMO(unsigned int serial)
         }          }
 }  }
   
 static void asir_pushCMOtag(unsigned int serial)  void asir_pushCMOtag(unsigned int serial)
 {  {
         Obj obj;          Obj obj;
         ERR err;          ERR err;
Line 409  static void asir_pushCMOtag(unsigned int serial)
Line 410  static void asir_pushCMOtag(unsigned int serial)
         }          }
 }  }
   
 static void asir_popString()  void asir_popString()
 {  {
         Obj val;          Obj val;
         char *buf,*obuf;          char *buf,*obuf;
Line 418  static void asir_popString()
Line 419  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 432  static void asir_popString()
Line 433  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 440  static void asir_pops()
Line 441  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 462  static void asir_setName(unsigned int serial)
Line 463  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 483  static void asir_evalName(unsigned int serial)
Line 484  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;
Line 588  error:
Line 589  error:
         asir_push_one(result);          asir_push_one(result);
 }  }
   
 static void asir_end_flush()  void asir_end_flush()
 {  {
         ox_flushing = 0;          ox_flushing = 0;
 }  }
Line 600  static void asir_end_flush()
Line 601  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 614  static void asir_push_one(Obj obj)
Line 615  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 626  static Obj asir_pop_one() {
Line 627  static Obj asir_pop_one() {
         }          }
 }  }
   
 static Obj asir_peek_one() {  Obj asir_peek_one() {
         if ( asir_OperandStackPtr < 0 ) {          if ( asir_OperandStackPtr < 0 ) {
                 if ( do_message )                  if ( do_message )
                         fprintf(stderr,"OperandStack underflow");                          fprintf(stderr,"OperandStack underflow");
Line 638  static Obj asir_peek_one() {
Line 639  static Obj asir_peek_one() {
         }          }
 }  }
   
 static void ox_asir_init(int argc,char **argv)  void ox_asir_init(int argc,char **argv)
 {  {
         int tmp;          int tmp;
         char ifname[BUFSIZ];          char ifname[BUFSIZ];
Line 661  static void ox_asir_init(int argc,char **argv)
Line 662  static void ox_asir_init(int argc,char **argv)
 #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();
         process_args(--argc,++argv);          process_args(--argc,++argv);
         output_init();          output_init();
Line 693  static void ox_asir_init(int argc,char **argv)
Line 687  static void ox_asir_init(int argc,char **argv)
         if ( ptr = getenv("ASIR_CONFIG") )          if ( ptr = getenv("ASIR_CONFIG") )
                 strcpy(ifname,ptr);                  strcpy(ifname,ptr);
         else {          else {
 #if defined(THINK_C)  
                 sprintf(ifname,"asirrc");  
 #else  
                 homedir = getenv("HOME");                  homedir = getenv("HOME");
                 if ( !homedir ) {                  if ( !homedir ) {
                         char rootname[BUFSIZ];                          char rootname[BUFSIZ];
Line 704  static void ox_asir_init(int argc,char **argv)
Line 695  static void ox_asir_init(int argc,char **argv)
                         homedir = rootname;                          homedir = rootname;
                 }                  }
                 sprintf(ifname,"%s/.asirrc",homedir);                  sprintf(ifname,"%s/.asirrc",homedir);
 #endif  
         }          }
         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 722  static void ox_asir_init(int argc,char **argv)
Line 712  static void ox_asir_init(int argc,char **argv)
         create_my_mathcap("ox_asir");          create_my_mathcap("ox_asir");
 }  }
   
 static void ox_io_init() {  void ox_io_init() {
         unsigned char c,rc;          unsigned char c,rc;
           extern int I_am_server;
           int i;
   
           /* XXX : ssh forwards stdin to a remote host */
   #if defined(linux) || defined(__NeXT__) || defined(ultrix)
   #include <sys/param.h>
                           close(0);
                           for ( i = 5; i < NOFILE; i++ )
                                   close(i);
   #else
   #include <sys/resource.h>
                           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 775  void asir_ox_push_cmo(void *cmo)
Line 784  void asir_ox_push_cmo(void *cmo)
   
 /*  /*
  * Pop an object from the stack and converts it   * Pop an object from the stack and converts it
  * int a binary encoded CMO.   * into a binary encoded CMO.
  */   */
   
 int asir_ox_pop_cmo(void *cmo, int limit)  int asir_ox_pop_cmo(void *cmo, int limit)
Line 799  int asir_ox_pop_cmo(void *cmo, int limit)
Line 808  int asir_ox_pop_cmo(void *cmo, int limit)
                 return -1;                  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.   * Executes an SM command.
  */   */
Line 809  void asir_ox_push_cmd(int cmd)
Line 842  void asir_ox_push_cmd(int cmd)
         ERR err;          ERR err;
         extern char LastError[];          extern char LastError[];
   
         if ( ret = setjmp(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); /* XXX */
Line 836  void asir_ox_execute_string(char *s)
Line 869  void asir_ox_execute_string(char *s)
   
         MKSTR(str,s);          MKSTR(str,s);
         asir_push_one((Obj)str);          asir_push_one((Obj)str);
         if ( ret = setjmp(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); /* XXX */
Line 897  int asir_ox_init(int byteorder)
Line 930  int asir_ox_init(int byteorder)
 #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();
 /*      process_args(argc,argv); */  /*      process_args(argc,argv); */
         output_init();          output_init();
Line 925  int asir_ox_init(int byteorder)
Line 951  int asir_ox_init(int byteorder)
 #if defined(UINIT)  #if defined(UINIT)
         reg_sysf();          reg_sysf();
 #endif  #endif
 #if defined(THINK_C)  
         sprintf(ifname,"asirrc");  
 #else  
         sprintf(ifname,"%s/.asirrc",getenv("HOME"));          sprintf(ifname,"%s/.asirrc",getenv("HOME"));
 #endif  
         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;

Legend:
Removed from v.1.19  
changed lines
  Added in v.1.28

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