=================================================================== RCS file: /home/cvs/OpenXM_contrib2/asir2000/engine/init.c,v retrieving revision 1.3 retrieving revision 1.6 diff -u -p -r1.3 -r1.6 --- OpenXM_contrib2/asir2000/engine/init.c 2000/08/22 05:04:05 1.3 +++ OpenXM_contrib2/asir2000/engine/init.c 2000/12/11 02:00:41 1.6 @@ -45,7 +45,7 @@ * DEVELOPER SHALL HAVE NO LIABILITY IN CONNECTION WITH THE USE, * PERFORMANCE OR NON-PERFORMANCE OF THE SOFTWARE. * - * $OpenXM: OpenXM_contrib2/asir2000/engine/init.c,v 1.2 2000/08/21 08:31:27 noro Exp $ + * $OpenXM: OpenXM_contrib2/asir2000/engine/init.c,v 1.5 2000/12/05 01:24:52 noro Exp $ */ #include "ca.h" #include "version.h" @@ -84,11 +84,7 @@ int nez = 1; int current_mod = 0; #if PARI -#if defined(THINK_C) int paristack = 1<<16; -#else -int paristack = 1<<20; -#endif void (*addnumt[])() = { addq, addreal, addalg, addbf, addcplx, addmi, addlm, addgf2n, addgfpn }; void (*subnumt[])() = { subq, subreal, subalg, subbf, subcplx, submi, sublm, subgf2n, subgfpn }; @@ -223,13 +219,33 @@ void resume_timer() { } extern int lm_lazy, up_lazy; -extern GC_dont_gc; +extern int GC_dont_gc; +extern int do_weyl; void reset_engine() { lm_lazy = 0; up_lazy = 0; + do_weyl = 0; GC_dont_gc = 0; } unsigned int get_asir_version() { return ASIR_VERSION; +} + +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); }