=================================================================== RCS file: /home/cvs/OpenXM_contrib2/asir2000/io/ox_asir.c,v retrieving revision 1.53 retrieving revision 1.58 diff -u -p -r1.53 -r1.58 --- OpenXM_contrib2/asir2000/io/ox_asir.c 2004/03/01 02:03:27 1.53 +++ OpenXM_contrib2/asir2000/io/ox_asir.c 2005/07/26 00:58:50 1.58 @@ -44,7 +44,7 @@ * 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.52 2004/02/26 06:37:09 noro Exp $ + * $OpenXM: OpenXM_contrib2/asir2000/io/ox_asir.c,v 1.57 2004/06/15 00:56:52 noro Exp $ */ #include "ca.h" #include "parse.h" @@ -155,6 +155,9 @@ void ox_main(int argc,char **argv) { if ( SETJMP(ox_env) ) { while ( NEXT(asir_infile) ) closecurrentinput(); + resetpvs(); + reset_engine(); + reset_io(); ox_send_sync(0); } while ( 1 ) { @@ -185,6 +188,8 @@ void ox_main(int argc,char **argv) { if ( ret == 1 ) { create_error(&err,serial,LastError); asir_push_one((Obj)err); + while ( NEXT(asir_infile) ) + closecurrentinput(); } break; } @@ -661,6 +666,20 @@ void asir_evalName(unsigned int serial) 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() { SNODE snode; @@ -677,7 +696,12 @@ int asir_executeString() # endif #endif cmd = ((STRING)asir_pop_one())->body; +/* XXX : probably this is useless */ +#if 0 + parse_strp = augment_backslash(cmd); +#else parse_strp = cmd; +#endif if ( mainparse(&snode) ) { return -1; } @@ -834,6 +858,7 @@ void ox_asir_init(int argc,char **argv,char *servernam int tmp; #endif + GC_init(); #if !defined(VISUAL) && !defined(MPI) do_server_in_X11 = 1; /* XXX */ #endif @@ -846,7 +871,6 @@ void ox_asir_init(int argc,char **argv,char *servernam rtime_init(); env_init(); endian_init(); - GC_init(); cppname_init(); process_args(--argc,++argv); #if defined(__CYGWIN__) @@ -1123,6 +1147,7 @@ int asir_ox_init(int byteorder) static ox_asir_initialized = 0; FILE *ifp; + GC_init(); #if !defined(VISUAL) && !defined(MPI) do_server_in_X11 = 0; /* XXX */ #endif @@ -1135,7 +1160,6 @@ int asir_ox_init(int byteorder) rtime_init(); env_init(); endian_init(); - GC_init(); /* process_args(argc,argv); */ output_init(); arf_init();