=================================================================== RCS file: /home/cvs/OpenXM_contrib2/asir2000/io/pexpr_body.c,v retrieving revision 1.7 retrieving revision 1.19 diff -u -p -r1.7 -r1.19 --- OpenXM_contrib2/asir2000/io/pexpr_body.c 2004/12/18 16:50:10 1.7 +++ OpenXM_contrib2/asir2000/io/pexpr_body.c 2016/06/29 08:16:11 1.19 @@ -1,4 +1,4 @@ -/* $OpenXM: OpenXM_contrib2/asir2000/io/pexpr_body.c,v 1.6 2004/12/17 03:09:08 noro Exp $ */ +/* $OpenXM: OpenXM_contrib2/asir2000/io/pexpr_body.c,v 1.18 2015/08/14 13:51:55 fujimoto Exp $ */ #define PRINTHAT (fortran_output?PUTS("**"):PUTS("^")) @@ -21,6 +21,7 @@ void PRINTGFMMAT(); void PRINTBYTEARRAY(); void PRINTQUOTE(); void PRINTQUOTEARG(); +void PRINTNBP(); void PRINTERR(); void PRINTCPLX(); void PRINTLM(); @@ -89,6 +90,8 @@ Obj p; PRINTQUOTE(vl,(QUOTE)p); break; case O_QUOTEARG: PRINTQUOTEARG(vl,(QUOTEARG)p); break; + case O_NBP: + PRINTNBP(vl,(NBP)p); break; case O_SYMBOL: PRINTSYMBOL((SYMBOL)p); break; case O_RANGE: @@ -323,7 +326,7 @@ IMAT xmat; for(j = 0; j < row; j++) { PUTS("( "); for(i = 0; i < col; i++) { - cr = j * row + i; + cr = j * col + i; if( ent.cr == cr ) { PRINTEXPR(vl, (pointer)ent.body); PUTS(" "); GetNextIent(&Im, &ent, &c); @@ -554,6 +557,14 @@ void PRINTFNODE(FNODE f,int paren) PUTS(((ARF)FA0(f))->name); PRINTFNODE((FNODE)FA2(f),1); break; + case I_NARYOP: + t = (NODE)FA1(f); + PRINTFNODE((FNODE)BDY(t),1); + for ( t = NEXT(t); t; t = NEXT(t) ) { + PUTS(((ARF)FA0(f))->name); + PRINTFNODE((FNODE)BDY(t),1); + } + break; case I_COP: switch( (cid)FA0(f) ) { case C_EQ: opname = ("=="); break; @@ -605,7 +616,7 @@ void PRINTFNODE(FNODE f,int paren) /* lists */ case I_LIST: PUTS("["); PRINTFNODENODE((NODE)FA0(f)); PUTS("]"); break; /* function */ - case I_FUNC: + case I_FUNC: case I_FUNC_QARG: if ( !strcmp(((FUNC)FA0(f))->name,"@pi") ) PUTS("@pi"); else if ( !strcmp(((FUNC)FA0(f))->name,"@e") ) PUTS("@e"); else { @@ -678,7 +689,7 @@ Num q; int i,expo; m = (unsigned int *)&BDY((Real)q); -#if defined(__i386__) || defined(MIPSEL) || defined(VISUAL) || defined(__alpha) || defined(__FreeBSD__) || defined(__NetBSD__) || defined(__x86_64) +#if defined(__i386__) || defined(MIPSEL) || defined(VISUAL) || defined(__MINGW32__) || defined(__alpha) || defined(__FreeBSD__) || defined(__NetBSD__) || defined(__x86_64) || defined(__ARM_ARCH) || defined(ANDROID) u = m[1]; l = m[0]; #else u = m[0]; l = m[1]; @@ -754,10 +765,8 @@ Num q; case N_A: PUTS("("); PRINTR(ALG,(R)BDY((Alg)q)); PUTS(")"); break; -#if defined(PARI) case N_B: PRINTBF((BF)q); break; -#endif #if defined(INTERVAL) case N_IP: case N_IntervalBigFloat: @@ -879,6 +888,12 @@ Num q; PRINTN(NM(dn)); } break; + case N_GZ: + mpz_out_str(OUT,10,BDY((GZ)q)); + break; + case N_GQ: + mpq_out_str(OUT,10,BDY((GQ)q)); + break; } } @@ -1064,6 +1079,32 @@ VL vl; QUOTEARG quote; { PUTS("<...quoted...>"); +} + +void PRINTNBP(VL vl,NBP p) +{ + NODE t; + NBM m; + int d,i; + unsigned int *b; + if ( !p ) PUTS("0"); + else { + for ( t = BDY(p); t; t = NEXT(t) ) { + m = (NBM)BDY(t); + PUTS("("); + PRINTEXPR(vl,(Obj)m->c); + PUTS(")*"); + d = m->d; + b = m->b; + if ( d ) + for ( i = 0; i < d; i++ ) { + if ( NBM_GET(b,i) ) PUTS("x"); + else PUTS("y"); + } + else PUTS("1"); + if ( NEXT(t) ) PUTS("+"); + } + } } void PRINTTB(VL vl,TB p)