version 1.2, 2004/03/26 08:25:36 |
version 1.17, 2015/08/08 14:19:42 |
|
|
/* $OpenXM: OpenXM_contrib2/asir2000/io/pexpr_body.c,v 1.1 2004/03/17 03:22:47 noro Exp $ */ |
/* $OpenXM: OpenXM_contrib2/asir2000/io/pexpr_body.c,v 1.16 2015/08/06 10:01:52 fujimoto Exp $ */ |
|
|
#define PRINTHAT (fortran_output?PUTS("**"):PUTS("^")) |
#define PRINTHAT (fortran_output?PUTS("**"):PUTS("^")) |
|
|
|
|
void PRINTLIST(); |
void PRINTLIST(); |
void PRINTVECT(); |
void PRINTVECT(); |
void PRINTMAT(); |
void PRINTMAT(); |
|
void PRINTIMAT(); /* IMAT */ |
void PRINTSTR(); |
void PRINTSTR(); |
void PRINTCOMP(); |
void PRINTCOMP(); |
void PRINTDP(); |
void PRINTDP(); |
Line 19 void PRINTGF2MAT(); |
|
Line 20 void PRINTGF2MAT(); |
|
void PRINTGFMMAT(); |
void PRINTGFMMAT(); |
void PRINTBYTEARRAY(); |
void PRINTBYTEARRAY(); |
void PRINTQUOTE(); |
void PRINTQUOTE(); |
|
void PRINTQUOTEARG(); |
|
void PRINTNBP(); |
void PRINTERR(); |
void PRINTERR(); |
void PRINTCPLX(); |
void PRINTCPLX(); |
void PRINTLM(); |
void PRINTLM(); |
|
|
void PRINTSYMBOL(); |
void PRINTSYMBOL(); |
void PRINTRANGE(); |
void PRINTRANGE(); |
void PRINTTB(); |
void PRINTTB(); |
|
void PRINTDPV(); |
void PRINTFNODE(); |
void PRINTFNODE(); |
void PRINTBF(); |
void PRINTBF(); |
|
void PRINTDAlg(); |
|
|
void PRINTEXPR(vl,p) |
void PRINTEXPR(vl,p) |
VL vl; |
VL vl; |
Obj p; |
Obj p; |
{ |
{ |
#if defined(FPRINT) |
|
if ( asir_texmacs && !user_print_function ) printf("\2verbatim:"); |
|
#endif |
|
if ( !p ) { |
if ( !p ) { |
PRINTR(vl,(R)p); |
PRINTR(vl,(R)p); |
} else |
} else |
|
|
PRINTVECT(vl,(VECT)p); break; |
PRINTVECT(vl,(VECT)p); break; |
case O_MAT: |
case O_MAT: |
PRINTMAT(vl,(MAT)p); break; |
PRINTMAT(vl,(MAT)p); break; |
|
/* IMAT */ |
|
case O_IMAT: |
|
PRINTIMAT(vl,(IMAT)p); break; |
|
/* IMAT */ |
case O_STR: |
case O_STR: |
PRINTSTR((STRING)p); break; |
PRINTSTR((STRING)p); break; |
case O_COMP: |
case O_COMP: |
|
|
PRINTBYTEARRAY(vl,(BYTEARRAY)p); break; |
PRINTBYTEARRAY(vl,(BYTEARRAY)p); break; |
case O_QUOTE: |
case O_QUOTE: |
PRINTQUOTE(vl,(QUOTE)p); break; |
PRINTQUOTE(vl,(QUOTE)p); break; |
|
case O_QUOTEARG: |
|
PRINTQUOTEARG(vl,(QUOTEARG)p); break; |
|
case O_NBP: |
|
PRINTNBP(vl,(NBP)p); break; |
case O_SYMBOL: |
case O_SYMBOL: |
PRINTSYMBOL((SYMBOL)p); break; |
PRINTSYMBOL((SYMBOL)p); break; |
case O_RANGE: |
case O_RANGE: |
PRINTRANGE(vl,(RANGE)p); break; |
PRINTRANGE(vl,(RANGE)p); break; |
case O_TB: |
case O_TB: |
PRINTTB(vl,(TB)p); break; |
PRINTTB(vl,(TB)p); break; |
|
case O_DPV: |
|
PRINTDPV(vl,(DPV)p); break; |
default: |
default: |
break; |
break; |
} |
} |
#if defined(FPRINT) |
|
if ( asir_texmacs && !user_print_function ) |
|
{ putchar('\5'); fflush(stdout); } |
|
#endif |
|
} |
} |
|
|
#if defined(FPRINT) |
#if defined(FPRINT) |
Line 117 void printbin(double z) |
|
Line 125 void printbin(double z) |
|
} |
} |
} |
} |
fprintf(stderr,"\n"); |
fprintf(stderr,"\n"); |
|
#if defined(__MINGW32__) || defined(__MINGW64__) |
|
fflush(stderr); |
|
#endif |
} |
} |
#endif |
#endif |
#endif |
#endif |
|
|
} |
} |
} |
} |
|
|
|
void PRINTDPV(vl,d) |
|
VL vl; |
|
DPV d; |
|
{ |
|
int i; |
|
DP *ptr; |
|
|
|
PUTS("modvect("); |
|
for ( i = 0, ptr = BDY(d); i < d->len; i++ ) { |
|
if ( i != 0 ) PUTS(","); |
|
PRINTEXPR(vl,(Obj)ptr[i]); |
|
} |
|
PUTS(")"); |
|
} |
|
|
void PRINTMAT(vl,mat) |
void PRINTMAT(vl,mat) |
VL vl; |
VL vl; |
MAT mat; |
MAT mat; |
|
|
} |
} |
} |
} |
|
|
|
/* IMAT */ |
|
#if !defined(CPRINT) |
|
void PRINTIMAT(vl,xmat) |
|
VL vl; |
|
IMAT xmat; |
|
{ |
|
int i,j,c; |
|
int row, col, cr; |
|
IMATC Im; |
|
IENT ent; |
|
|
|
row = xmat->row; |
|
col = xmat->col; |
|
Im = (pointer)xmat->root; |
|
if ( xmat->clen == 0 ) { |
|
for(j = 0; j< row; j++) { |
|
PUTS("( "); |
|
for(i = 0; i < col; i++) PUTS("0 "); |
|
PUTS(")"); |
|
if ( j < row - 1 ) PUTS("\n"); |
|
} |
|
return; |
|
} |
|
c = -1; |
|
GetNextIent(&Im, &ent, &c); |
|
for(j = 0; j < row; j++) { |
|
PUTS("( "); |
|
for(i = 0; i < col; i++) { |
|
cr = j * col + i; |
|
if( ent.cr == cr ) { |
|
PRINTEXPR(vl, (pointer)ent.body); PUTS(" "); |
|
GetNextIent(&Im, &ent, &c); |
|
} else { |
|
PUTS("0 "); |
|
} |
|
} |
|
PUTS(")"); |
|
if ( j < row - 1 ) PUTS("\n"); |
|
} |
|
} |
|
#endif |
|
/* IMAT */ |
|
|
void PRINTLIST(vl,list) |
void PRINTLIST(vl,list) |
VL vl; |
VL vl; |
LIST list; |
LIST list; |
Line 491 void PRINTFNODE(FNODE f,int paren) |
|
Line 560 void PRINTFNODE(FNODE f,int paren) |
|
PUTS(((ARF)FA0(f))->name); |
PUTS(((ARF)FA0(f))->name); |
PRINTFNODE((FNODE)FA2(f),1); |
PRINTFNODE((FNODE)FA2(f),1); |
break; |
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: |
case I_COP: |
switch( (cid)FA0(f) ) { |
switch( (cid)FA0(f) ) { |
case C_EQ: opname = ("=="); break; |
case C_EQ: opname = ("=="); break; |
Line 542 void PRINTFNODE(FNODE f,int paren) |
|
Line 619 void PRINTFNODE(FNODE f,int paren) |
|
/* lists */ |
/* lists */ |
case I_LIST: PUTS("["); PRINTFNODENODE((NODE)FA0(f)); PUTS("]"); break; |
case I_LIST: PUTS("["); PRINTFNODENODE((NODE)FA0(f)); PUTS("]"); break; |
/* function */ |
/* function */ |
case I_FUNC: |
case I_FUNC: case I_FUNC_QARG: |
if ( !strcmp(((FUNC)FA0(f))->name,"@pi") ) PUTS("@pi"); |
if ( !strcmp(((FUNC)FA0(f))->name,"@pi") ) PUTS("@pi"); |
else if ( !strcmp(((FUNC)FA0(f))->name,"@e") ) PUTS("@e"); |
else if ( !strcmp(((FUNC)FA0(f))->name,"@e") ) PUTS("@e"); |
else { |
else { |
Line 579 void PRINTNUM(q) |
|
Line 656 void PRINTNUM(q) |
|
Num q; |
Num q; |
{ |
{ |
char real_format[20]; |
char real_format[20]; |
|
DAlg d; |
|
DP nm; |
|
Q dn; |
|
|
if ( !q ) { |
if ( !q ) { |
PUTS("0"); |
PUTS("0"); |
|
|
int i,expo; |
int i,expo; |
|
|
m = (unsigned int *)&BDY((Real)q); |
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(__MINGW64__) || defined(__alpha) || defined(__FreeBSD__) || defined(__NetBSD__) || defined(__x86_64) |
u = m[1]; l = m[0]; |
u = m[1]; l = m[0]; |
#else |
#else |
u = m[0]; l = m[1]; |
u = m[0]; l = m[1]; |
|
|
case N_A: |
case N_A: |
PUTS("("); PRINTR(ALG,(R)BDY((Alg)q)); PUTS(")"); |
PUTS("("); PRINTR(ALG,(R)BDY((Alg)q)); PUTS(")"); |
break; |
break; |
#if defined(PARI) |
|
case N_B: |
case N_B: |
PRINTBF((BF)q); break; |
PRINTBF((BF)q); break; |
#endif |
|
#if defined(INTERVAL) |
#if defined(INTERVAL) |
case N_IP: |
case N_IP: |
case N_IntervalBigFloat: |
case N_IntervalBigFloat: |
|
|
case N_GFSN: |
case N_GFSN: |
PRINTUM(BDY((GFSN)q)); |
PRINTUM(BDY((GFSN)q)); |
break; |
break; |
|
case N_DA: |
|
d = (DAlg)q; |
|
nm = d->nm; |
|
dn = d->dn; |
|
if ( SGN((Q)dn) == -1 ) PUTS("-"); |
|
PUTS("("); |
|
PRINTDP(CO,((DAlg)q)->nm); |
|
PUTS(")"); |
|
if ( !UNIN(NM(dn)) ) { |
|
PUTS("/"); |
|
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; |
} |
} |
} |
} |
|
|
|
|
PRINTFNODE(BDY(quote),0); |
PRINTFNODE(BDY(quote),0); |
} else { |
} else { |
PUTS("<...quoted...>"); |
PUTS("<...quoted...>"); |
|
} |
|
} |
|
|
|
void PRINTQUOTEARG(vl,quote) |
|
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("+"); |
|
} |
} |
} |
} |
} |
|
|