summaryrefslogtreecommitdiff
path: root/Objects/rangeobject.c
diff options
context:
space:
mode:
authorSerhiy Storchaka <storchaka@gmail.com>2016-10-08 21:52:41 +0300
committerSerhiy Storchaka <storchaka@gmail.com>2016-10-08 21:52:41 +0300
commitaa078674e01090b000f7af89734a4d8b64a4422d (patch)
treef1d7d59c489c740ca9be297997c86f0c3dbae30e /Objects/rangeobject.c
parent1d56113ed7e3fdab6dc3b644b886d6f720e6cb54 (diff)
parentc7f490c8b19d5458d692f243279f7ad898f13ec4 (diff)
downloadcpython-git-aa078674e01090b000f7af89734a4d8b64a4422d.tar.gz
Merge with 3.6.
Diffstat (limited to 'Objects/rangeobject.c')
-rw-r--r--Objects/rangeobject.c21
1 files changed, 18 insertions, 3 deletions
diff --git a/Objects/rangeobject.c b/Objects/rangeobject.c
index e7c3709c4a..8449fc7a24 100644
--- a/Objects/rangeobject.c
+++ b/Objects/rangeobject.c
@@ -930,12 +930,27 @@ rangeiter_new(PyTypeObject *type, PyObject *args, PyObject *kw)
{
long start, stop, step;
- if (!_PyArg_NoKeywords("rangeiter()", kw))
+ if (PyErr_WarnEx(PyExc_DeprecationWarning,
+ "range_iterator(): creating instances of range_iterator "
+ "by calling range_iterator type is deprecated",
+ 1)) {
return NULL;
+ }
+
+ if (!_PyArg_NoKeywords("range_iterator()", kw)) {
+ return NULL;
+ }
- if (!PyArg_ParseTuple(args, "lll;rangeiter() requires 3 int arguments",
- &start, &stop, &step))
+ if (!PyArg_ParseTuple(args,
+ "lll;range_iterator() requires 3 int arguments",
+ &start, &stop, &step)) {
return NULL;
+ }
+ if (step == 0) {
+ PyErr_SetString(PyExc_ValueError,
+ "range_iterator() arg 3 must not be zero");
+ return NULL;
+ }
return fast_range_iter(start, stop, step);
}