=================================================================== RCS file: /home/cvs/OpenXM/src/ox_toolkit/ox.c,v retrieving revision 1.35 retrieving revision 1.37 diff -u -p -r1.35 -r1.37 --- OpenXM/src/ox_toolkit/ox.c 2013/10/20 14:58:20 1.35 +++ OpenXM/src/ox_toolkit/ox.c 2014/04/07 04:00:10 1.37 @@ -1,5 +1,5 @@ /* -*- mode: C; coding: euc-japan -*- */ -/* $OpenXM: OpenXM/src/ox_toolkit/ox.c,v 1.34 2007/03/14 10:30:54 ohara Exp $ */ +/* $OpenXM: OpenXM/src/ox_toolkit/ox.c,v 1.36 2013/10/20 15:29:12 iwane Exp $ */ /* This module includes functions for sending/receiveng CMO's. @@ -387,20 +387,22 @@ cmo *receive_cmo_tag(OXFILE *oxfp, int tag) static void receive_mpz(OXFILE *oxfp, mpz_ptr mpz) { int i; - int n = sizeof(mpz->_mp_d[0]) / sizeof(int); + int n = sizeof(mpz->_mp_d[0]) / sizeof(int); int size = receive_int32(oxfp); int len = abs(size); - int *ptr; - if (n == 1) { - resize_mpz(mpz, size); - } else { - resize_mpz(mpz, (size+1) / n); - } + int *ptr; + if (n == 1) { + resize_mpz(mpz, size); + } else if (size >= 0) { + resize_mpz(mpz, (size+1) / n); + } else { + resize_mpz(mpz, (size-1) / n); + } - ptr = (int *)mpz->_mp_d; - for(i= len-1; i>=0; i--) { - ptr[i] = receive_int32(oxfp); - } + ptr = (int *)mpz->_mp_d; + for(i=0; i_mp_d[0]) / sizeof(int); int len = abs(mpz->_mp_size) * n; int *ptr = (int *)mpz->_mp_d; + int size; send_int32(oxfp, mpz->_mp_size * n); + if (len > 0 && ptr[len-1] == 0) { + len--; + } + size = mpz->_mp_size < 0 ? -len : len; + send_int32(oxfp, size); for(i=0; i