Kaydet (Commit) 2af72d5d authored tarafından Martin v. Löwis's avatar Martin v. Löwis

Use symbolic constants for allowable short ranges.

üst 0bb44a4a
...@@ -66,6 +66,8 @@ typedef struct { char c; void *x; } s_void_p; ...@@ -66,6 +66,8 @@ typedef struct { char c; void *x; } s_void_p;
#define DOUBLE_ALIGN (sizeof(s_double) - sizeof(double)) #define DOUBLE_ALIGN (sizeof(s_double) - sizeof(double))
#define VOID_P_ALIGN (sizeof(s_void_p) - sizeof(void *)) #define VOID_P_ALIGN (sizeof(s_void_p) - sizeof(void *))
#define STRINGIFY(x) #x
#ifdef __powerc #ifdef __powerc
#pragma options align=reset #pragma options align=reset
#endif #endif
...@@ -519,9 +521,10 @@ np_short(char *p, PyObject *v, const formatdef *f) ...@@ -519,9 +521,10 @@ np_short(char *p, PyObject *v, const formatdef *f)
long x; long x;
if (get_long(v, &x) < 0) if (get_long(v, &x) < 0)
return -1; return -1;
if (x < -32768 || x > 32767){ if (x < SHRT_MIN || x > SHRT_MAX){
PyErr_SetString(StructError, PyErr_SetString(StructError,
"short format requires -32768<=number<=32767"); "short format requires " STRINGIFY(SHRT_MIN)
"<=number<=" STRINGIFY(SHRT_MAX));
return -1; return -1;
} }
* (short *)p = (short)x; * (short *)p = (short)x;
...@@ -534,9 +537,9 @@ np_ushort(char *p, PyObject *v, const formatdef *f) ...@@ -534,9 +537,9 @@ np_ushort(char *p, PyObject *v, const formatdef *f)
long x; long x;
if (get_long(v, &x) < 0) if (get_long(v, &x) < 0)
return -1; return -1;
if (x < 0 || x > 65535){ if (x < 0 || x > USHRT_MAX){
PyErr_SetString(StructError, PyErr_SetString(StructError,
"short format requires 0<=number<=65535"); "short format requires 0<=number<=" STRINGIFY(USHRT_MAX));
return -1; return -1;
} }
* (unsigned short *)p = (unsigned short)x; * (unsigned short *)p = (unsigned short)x;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment