diff options
author | Tim Peters <tim.peters@gmail.com> | 2001-08-29 02:28:42 (GMT) |
---|---|---|
committer | Tim Peters <tim.peters@gmail.com> | 2001-08-29 02:28:42 (GMT) |
commit | 8211237db89e1d77aff9d4da80059bae1cb3e881 (patch) | |
tree | d84233fb30e453664bee4bf16d7b71e14c49ec24 /Python | |
parent | da21ce3e3109c4a45f89386db42be4f0463aec11 (diff) | |
download | cpython-8211237db89e1d77aff9d4da80059bae1cb3e881.zip cpython-8211237db89e1d77aff9d4da80059bae1cb3e881.tar.gz cpython-8211237db89e1d77aff9d4da80059bae1cb3e881.tar.bz2 |
marshal.c r_long64: When reading a TYPE_INT64 value on a box with 32-bit
ints, convert to PyLong (rather than throwing away the high-order 32 bits).
Diffstat (limited to 'Python')
-rw-r--r-- | Python/marshal.c | 36 |
1 files changed, 24 insertions, 12 deletions
diff --git a/Python/marshal.c b/Python/marshal.c index 5ef11ef..029f2b9 100644 --- a/Python/marshal.c +++ b/Python/marshal.c @@ -342,23 +342,35 @@ r_long(RFILE *p) return x; } -static long +/* r_long64 deals with the TYPE_INT64 code. On a machine with + sizeof(long) > 4, it returns a Python int object, else a Python long + object. Note that w_long64 writes out TYPE_INT if 32 bits is enough, + so there's no inefficiency here in returning a PyLong on 32-bit boxes + for everything written via TYPE_INT64 (i.e., if an int is written via + TYPE_INT64, it *needs* more than 32 bits). +*/ +static PyObject * r_long64(RFILE *p) { - register long x; - x = r_long(p); + long lo4 = r_long(p); + long hi4 = r_long(p); #if SIZEOF_LONG > 4 - x = (x & 0xFFFFFFFFL) | (r_long(p) << 32); + long x = (hi4 << 32) | (lo4 & 0xFFFFFFFFL); + return PyInt_FromLong(x); #else - if (r_long(p) != 0) { - PyObject *f = PySys_GetObject("stderr"); - if (f != NULL) - (void) PyFile_WriteString( - "Warning: un-marshal 64-bit int in 32-bit mode\n", - f); + unsigned char buf[8]; + int one = 1; + int is_little_endian = (int)*(char*)&one; + if (is_little_endian) { + memcpy(buf, &lo4, 4); + memcpy(buf+4, &hi4, 4); } + else { + memcpy(buf, &hi4, 4); + memcpy(buf+4, &lo4, 4); + } + return _PyLong_FromByteArray(buf, 8, is_little_endian, 1); #endif - return x; } static PyObject * @@ -394,7 +406,7 @@ r_object(RFILE *p) return PyInt_FromLong(r_long(p)); case TYPE_INT64: - return PyInt_FromLong(r_long64(p)); + return r_long64(p); case TYPE_LONG: { |