diff options
| author | Benjamin Peterson <benjamin@python.org> | 2010-07-07 18:54:59 +0000 | 
|---|---|---|
| committer | Benjamin Peterson <benjamin@python.org> | 2010-07-07 18:54:59 +0000 | 
| commit | de73c4587f665bdbf748715461691e9584f30c0f (patch) | |
| tree | b60e603250af75b81fc6c6b2b2c79701248ae947 /Modules/_struct.c | |
| parent | e789016a70c161829627bf7497238f2d52b4b004 (diff) | |
| download | cpython-git-de73c4587f665bdbf748715461691e9584f30c0f.tar.gz | |
don't ignore exceptions from PyObject_IsTrue
Diffstat (limited to 'Modules/_struct.c')
| -rw-r--r-- | Modules/_struct.c | 10 | 
1 files changed, 8 insertions, 2 deletions
| diff --git a/Modules/_struct.c b/Modules/_struct.c index e1d016b0f5..b5f18a96ad 100644 --- a/Modules/_struct.c +++ b/Modules/_struct.c @@ -591,9 +591,13 @@ np_ulonglong(char *p, PyObject *v, const formatdef *f)  static int  np_bool(char *p, PyObject *v, const formatdef *f)  { -    BOOL_TYPE y; +    int y; +    BOOL_TYPE x;      y = PyObject_IsTrue(v); -    memcpy(p, (char *)&y, sizeof y); +    if (y < 0) +        return -1; +    x = y; +    memcpy(p, (char *)&x, sizeof x);      return 0;  } @@ -865,6 +869,8 @@ bp_bool(char *p, PyObject *v, const formatdef *f)  {      char y;      y = PyObject_IsTrue(v); +    if (y < 0) +        return -1;      memcpy(p, (char *)&y, sizeof y);      return 0;  } | 
