[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.4 and 1.13

version 1.4, 2000/01/19 09:31:00 version 1.13, 2000/03/19 12:35:20
Line 1 
Line 1 
 /* $OpenXM: OpenXM_contrib2/asir2000/io/ox_asir.c,v 1.3 2000/01/18 05:55:07 noro Exp $ */  /* $OpenXM: OpenXM_contrib2/asir2000/io/ox_asir.c,v 1.12 2000/03/16 08:23:16 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 PARI
   #include "genpari.h"
   #endif
   
 void ox_usr1_handler();  void ox_usr1_handler();
   int asir_ox_init();
   
 extern jmp_buf environnement;  extern jmp_buf environnement;
   
Line 13  extern int ox_flushing;
Line 18  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;  static int asir_OperandStackSize;
 static Obj *asir_OperandStack;  static Obj *asir_OperandStack;
Line 34  static void asir_popString();
Line 42  static void asir_popString();
 static void asir_popCMO(unsigned int);  static void asir_popCMO(unsigned int);
 static void asir_popSerializedLocalObject();  static void asir_popSerializedLocalObject();
 static LIST asir_GetErrorList();  static LIST asir_GetErrorList();
 static char *name_of_cmd(unsigned int);  static char *name_of_cmd(int);
 static char *name_of_id(int);  static char *name_of_id(int);
 static void asir_do_cmd(unsigned int,unsigned int);  static void asir_do_cmd(int,unsigned int);
   
 #if MPI  #if MPI
 extern int mpi_nprocs,mpi_myid;  extern int mpi_nprocs,mpi_myid;
Line 82  static void create_error(ERR *err,unsigned int serial,
Line 90  static void create_error(ERR *err,unsigned int serial,
   
 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;          USINT ui;
         ERR err;          ERR err;
Line 152  void ox_main(int argc,char **argv) {
Line 160  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 234  static char *name_of_id(int id)
Line 242  static char *name_of_id(int id)
         }          }
 }  }
   
 static char *name_of_cmd(unsigned cmd)  static char *name_of_cmd(int cmd)
 {  {
         switch ( cmd ) {          switch ( cmd ) {
                 case SM_popSerializedLocalObject:                  case SM_popSerializedLocalObject:
Line 456  static void asir_executeFunction(int serial)
Line 464  static void asir_executeFunction(int serial)
         char *path;          char *path;
         USINT ui;          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 511  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()  static void asir_end_flush()
Line 624  static void ox_asir_init(int argc,char **argv)
Line 649  static void ox_asir_init(int argc,char **argv)
   
 static void ox_io_init() {  static void ox_io_init() {
         unsigned char c,rc;          unsigned char c,rc;
         extern int little_endian,ox_sock_id;  
   
         endian_init();          endian_init();
 #if defined(VISUAL)  #if defined(VISUAL)
Line 680  int asir_ox_pop_cmo(void *cmo, int limit)
Line 704  int asir_ox_pop_cmo(void *cmo, int limit)
 {  {
         Obj obj;          Obj obj;
         int len;          int len;
           ERR err;
   
         obj = asir_pop_one();          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);          len = count_as_cmo(obj);
         if ( len <= limit ) {          if ( len <= limit ) {
                 ox_copy_init(cmo);                  ox_copy_init(cmo);
Line 695  int asir_ox_pop_cmo(void *cmo, int limit)
Line 725  int asir_ox_pop_cmo(void *cmo, int limit)
  * Executes an SM command.   * Executes an SM command.
  */   */
   
 void asir_ox_push_cmd(unsigned int cmd)  void asir_ox_push_cmd(int cmd)
 {  {
         asir_do_cmd(cmd,0);          int ret;
           ERR err;
           extern char LastError[];
   
           if ( ret = setjmp(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();
           }
 }  }
   
 /*  /*
Line 707  void asir_ox_push_cmd(unsigned int cmd)
Line 752  void asir_ox_push_cmd(unsigned int cmd)
 void asir_ox_execute_string(char *s)  void asir_ox_execute_string(char *s)
 {  {
         STRING str;          STRING str;
           int ret;
           ERR err;
           extern char LastError[];
   
         MKSTR(str,s);          MKSTR(str,s);
         asir_push_one((Obj)str);          asir_push_one((Obj)str);
         asir_executeString();          if ( ret = setjmp(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();
           }
 }  }
   
 /*  /*
Line 724  int asir_ox_peek_cmo_size()
Line 783  int asir_ox_peek_cmo_size()
         int len;          int len;
   
         obj = asir_pop_one();          obj = asir_pop_one();
         len = count_as_cmo(obj);  
         asir_push_one(obj);          asir_push_one(obj);
           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;          return len;
 }  }
   
 /*  /*
  * Initialization.   * Initialization.
  * byteorder = 1 : little endian   * byteorder=0 => native
  *             0 : big endian   *          =1 => network byte order
  */   */
   
 void asir_ox_io_init();  int asir_ox_init(int byteorder)
   
 void asir_ox_init(int byteorder)  
 {  {
         int tmp;          int tmp;
         char ifname[BUFSIZ];          char ifname[BUFSIZ];
Line 750  void asir_ox_init(int byteorder)
Line 811  void asir_ox_init(int byteorder)
         FILE *ifp;          FILE *ifp;
   
 #if !defined(VISUAL) && !MPI  #if !defined(VISUAL) && !MPI
         do_server_in_X11 = 1; /* XXX */          do_server_in_X11 = 0; /* XXX */
 #endif  #endif
         asir_save_handler();          asir_save_handler();
 #if PARI  #if PARI
Line 801  void asir_ox_init(int byteorder)
Line 862  void asir_ox_init(int byteorder)
                 fclose(ifp);                  fclose(ifp);
         }          }
         input_init(0,"string");          input_init(0,"string");
         asir_ox_io_init(byteorder);  
         create_my_mathcap("ox_asir");  
 }  
   
 void asir_ox_io_init(byteorder)  
 int byteorder;  
 {  
         unsigned char c;  
         extern int little_endian;  
         extern int lib_ox_initialized;  
   
         endian_init();  
         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;
         if ( little_endian )          if ( little_endian && byteorder )
                 c = 1;                  lib_ox_need_conv = 1;
         else          else
                 c = 0;                  lib_ox_need_conv = 0;
         iofp[0].conv = c == byteorder ? 0 : 1;  
         lib_ox_initialized = 1;  
         do_message = 0;          do_message = 0;
           create_my_mathcap("ox_asir");
           asir_reset_handler();
           return 0;
 }  }

Legend:
Removed from v.1.4  
changed lines
  Added in v.1.13

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