diff options
author | Tim Peters <tim.peters@gmail.com> | 2004-08-30 02:58:59 (GMT) |
---|---|---|
committer | Tim Peters <tim.peters@gmail.com> | 2004-08-30 02:58:59 (GMT) |
commit | cd97da3b1d61be00bb06f3264a60418dbdb83bd8 (patch) | |
tree | ee915c66c474c9ab112aeed79de79370524d656f | |
parent | 47e52ee0c5c8868db903d476b49c3368fce4d79a (diff) | |
download | cpython-cd97da3b1d61be00bb06f3264a60418dbdb83bd8.zip cpython-cd97da3b1d61be00bb06f3264a60418dbdb83bd8.tar.gz cpython-cd97da3b1d61be00bb06f3264a60418dbdb83bd8.tar.bz2 |
long_pow(): Fix more instances of leaks in error cases.
Bugfix candidate -- although long_pow() is so different now I doubt a
patch would apply to 2.3.
-rw-r--r-- | Objects/longobject.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/Objects/longobject.c b/Objects/longobject.c index 05c42ad..0103e5c 100644 --- a/Objects/longobject.c +++ b/Objects/longobject.c @@ -2343,7 +2343,7 @@ long_pow(PyObject *v, PyObject *w, PyObject *x) if (c) { PyErr_SetString(PyExc_TypeError, "pow() 2nd argument " "cannot be negative when 3rd argument specified"); - return NULL; + goto Error; } else { /* else return a float. This works because we know @@ -2361,7 +2361,7 @@ long_pow(PyObject *v, PyObject *w, PyObject *x) if (c->ob_size == 0) { PyErr_SetString(PyExc_ValueError, "pow() 3rd argument cannot be 0"); - goto Done; + goto Error; } /* if modulus < 0: @@ -2390,7 +2390,7 @@ long_pow(PyObject *v, PyObject *w, PyObject *x) Having the base positive just makes things easier. */ if (a->ob_size < 0) { if (l_divmod(a, c, NULL, &temp) < 0) - goto Done; + goto Error; Py_DECREF(a); a = temp; temp = NULL; |