summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMark Dickinson <dickinsm@gmail.com>2016-09-17 16:50:50 (GMT)
committerMark Dickinson <dickinsm@gmail.com>2016-09-17 16:50:50 (GMT)
commit92ca535626c676499e807b0e7729280cfb5eb67a (patch)
tree7196ca79899a2efa71a0d6350e23661638b5aec1
parent042ce8a594257aff60b4d0291ad23a98b83a26fd (diff)
downloadcpython-92ca535626c676499e807b0e7729280cfb5eb67a.zip
cpython-92ca535626c676499e807b0e7729280cfb5eb67a.tar.gz
cpython-92ca535626c676499e807b0e7729280cfb5eb67a.tar.bz2
Issue #27222: various cleanups in long_rshift. Thanks Oren Milman.
-rw-r--r--Misc/NEWS3
-rw-r--r--Objects/longobject.c18
2 files changed, 10 insertions, 11 deletions
diff --git a/Misc/NEWS b/Misc/NEWS
index 76de19f..a4da864 100644
--- a/Misc/NEWS
+++ b/Misc/NEWS
@@ -10,6 +10,9 @@ What's New in Python 3.7.0 alpha 1
Core and Builtins
-----------------
+- Issue #27222: Clean up redundant code in long_rshift function. Thanks
+ Oren Milman.
+
- Upgrade internal unicode databases to Unicode version 9.0.0.
- Issue #28131: Fix a regression in zipimport's compile_source(). zipimport
diff --git a/Objects/longobject.c b/Objects/longobject.c
index a453241..0822f9b 100644
--- a/Objects/longobject.c
+++ b/Objects/longobject.c
@@ -4296,22 +4296,22 @@ long_rshift(PyLongObject *a, PyLongObject *b)
PyLongObject *a1, *a2;
a1 = (PyLongObject *) long_invert(a);
if (a1 == NULL)
- goto rshift_error;
+ return NULL;
a2 = (PyLongObject *) long_rshift(a1, b);
Py_DECREF(a1);
if (a2 == NULL)
- goto rshift_error;
+ return NULL;
z = (PyLongObject *) long_invert(a2);
Py_DECREF(a2);
}
else {
shiftby = PyLong_AsSsize_t((PyObject *)b);
if (shiftby == -1L && PyErr_Occurred())
- goto rshift_error;
+ return NULL;
if (shiftby < 0) {
PyErr_SetString(PyExc_ValueError,
"negative shift count");
- goto rshift_error;
+ return NULL;
}
wordshift = shiftby / PyLong_SHIFT;
newsize = Py_ABS(Py_SIZE(a)) - wordshift;
@@ -4323,19 +4323,15 @@ long_rshift(PyLongObject *a, PyLongObject *b)
himask = PyLong_MASK ^ lomask;
z = _PyLong_New(newsize);
if (z == NULL)
- goto rshift_error;
- if (Py_SIZE(a) < 0)
- Py_SIZE(z) = -(Py_SIZE(z));
+ return NULL;
for (i = 0, j = wordshift; i < newsize; i++, j++) {
z->ob_digit[i] = (a->ob_digit[j] >> loshift) & lomask;
if (i+1 < newsize)
z->ob_digit[i] |= (a->ob_digit[j+1] << hishift) & himask;
}
- z = long_normalize(z);
+ z = maybe_small_long(long_normalize(z));
}
- rshift_error:
- return (PyObject *) maybe_small_long(z);
-
+ return (PyObject *)z;
}
static PyObject *