=================================================================== RCS file: /home/cvs/OpenXM_contrib2/asir2000/io/bload.c,v retrieving revision 1.14 retrieving revision 1.18 diff -u -p -r1.14 -r1.18 --- OpenXM_contrib2/asir2000/io/bload.c 2004/12/10 07:36:35 1.14 +++ OpenXM_contrib2/asir2000/io/bload.c 2017/08/31 09:11:04 1.18 @@ -44,20 +44,20 @@ * 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/bload.c,v 1.13 2003/12/22 09:33:47 noro Exp $ + * $OpenXM: OpenXM_contrib2/asir2000/io/bload.c,v 1.17 2015/08/04 06:20:45 noro Exp $ */ #include "ca.h" #include "parse.h" #include "com.h" -#if defined(PARI) -#include "genpari.h" -int get_lg(GEN); -#endif extern VL file_vl; +void loadnbp(FILE *s,NBP *p); + void (*loadf[])() = { 0, loadnum, loadp, loadr, loadlist, loadvect, loadmat, - loadstring, 0, loaddp, loadui, loaderror,0,0,0,loadgfmmat, loadbytearray }; + loadstring, 0, loaddp, loadui, loaderror,0,0,0,loadgfmmat, + loadbytearray, 0, 0, 0, 0, 0, 0, 0, 0, loadnbp }; + #if defined(INTERVAL) void loaditv(); void loaditvd(); @@ -120,46 +120,35 @@ void loadreal(FILE *s,Real *p) void loadbf(FILE *s,BF *p) { -#if defined(PARI) - GEN z; - unsigned int uexpo,lexpo; - char dmy; - int sign; - unsigned int len; - unsigned long expo; - BF q; + BF r; + char dmy; + int sgn,prec; + UL exp; + int len; read_char(s,&dmy); - read_int(s,&sign); - read_int(s,&uexpo); - read_int(s,&lexpo); - -#if defined(LONG_IS_32BIT) - if ( uexpo ) - error("loadbf : exponent too large"); + NEWBF(r); + read_int(s,&sgn); + read_int(s,&prec); + read_int64(s,&exp); read_int(s,&len); - NEWBF(q,len+2); - z = (GEN)BDY(q); - settyp(z,t_REAL); - setlg(z,len+2); - setsigne(z,(long)sign); - setexpo(z,(long)lexpo); - read_intarray(s,(int *)(z+2),len); -#elif defined(LONG_IS_64BIT) - expo = (((UL)uexpo)<<32)|((UL)lexpo); - read_int(s,&len); - NEWBF(q,(len+5)/2); /* 2+(len+1)/2 */ - z = (GEN)BDY(q); - settyp(z,t_REAL); - setlg(z,(len+5)/2); - setsigne(z,(long)sign); - setexpo(z,(long)expo); - read_longarray(s,z+2,len); + mpfr_init2(r->body,prec); + MPFR_SIGN(r->body) = sgn; + MPFR_EXP(r->body) = (int)exp; +#if defined(VISUAL) +#if !defined(_WIN64) + read_intarray(s,(int *)r->body->_mpfr_d,len); +#else + read_longarray(s,(long long*)r->body->_mpfr_d,len); #endif - *p = q; #else - error("loadbf : PARI is not combined"); +#if SIZEOF_LONG == 4 + read_intarray(s,(int *)r->body->_mpfr_d,len); +#else /* SIZEOF_LONG == 8 */ + read_longarray(s,(long *)r->body->_mpfr_d,len); #endif +#endif + *p = r; } #if defined(INTERVAL) @@ -464,4 +453,22 @@ void loadgfmmat(FILE *s,GFMMAT *p) for ( i = 0; i < row; i++ ) read_intarray(s,a[i],col); *p = mat; +} + +void loadnbp(FILE *s,NBP *p) +{ + int n,i; + NBM m; + NODE r0,r; + + read_int(s,&n); + for ( i = 0, r0 = 0; i < n; i++ ) { + NEWNBM(m); + loadobj(s,(Obj *)&m->c); + read_int(s,&m->d); + NEWNBMBDY(m,m->d); read_intarray(s,m->b,(m->d+31)/32); + NEXTNODE(r0,r); BDY(r) = (pointer)m; + } + if ( r0 ) NEXT(r) = 0; + MKNBP(*p,r0); }