summaryrefslogtreecommitdiffstats
path: root/Lib/random.py
diff options
context:
space:
mode:
authorMiro HronĨok <miro@hroncok.cz>2022-02-03 13:48:13 (GMT)
committerGitHub <noreply@github.com>2022-02-03 13:48:13 (GMT)
commit6baa98e538b2e26f16eaaf462f99496e98d2cfb1 (patch)
tree5cf899cacf875fedade890d321db3f1e1d4ad2ff /Lib/random.py
parent674ab66ebdf06f187e193a3d7bde13b71ba0f9af (diff)
downloadcpython-6baa98e538b2e26f16eaaf462f99496e98d2cfb1.zip
cpython-6baa98e538b2e26f16eaaf462f99496e98d2cfb1.tar.gz
cpython-6baa98e538b2e26f16eaaf462f99496e98d2cfb1.tar.bz2
bpo-46624: Defer to 3.12: "Remove deprecated support for non-integer values" (GH-31098)
Diffstat (limited to 'Lib/random.py')
-rw-r--r--Lib/random.py52
1 files changed, 42 insertions, 10 deletions
diff --git a/Lib/random.py b/Lib/random.py
index e8bc941..6d7b617 100644
--- a/Lib/random.py
+++ b/Lib/random.py
@@ -282,17 +282,27 @@ class Random(_random.Random):
## -------------------- integer methods -------------------
def randrange(self, start, stop=None, step=_ONE):
- """Choose a random item from range(stop) or range(start, stop[, step]).
+ """Choose a random item from range(start, stop[, step]).
- Roughly equivalent to ``choice(range(start, stop, step))``
- but supports arbitrarily large ranges and is optimized
- for common cases.
+ This fixes the problem with randint() which includes the
+ endpoint; in Python this is usually not what you want.
"""
# This code is a bit messy to make it fast for the
# common case while still doing adequate error checking.
- istart = _index(start)
+ try:
+ istart = _index(start)
+ except TypeError:
+ istart = int(start)
+ if istart != start:
+ _warn('randrange() will raise TypeError in the future',
+ DeprecationWarning, 2)
+ raise ValueError("non-integer arg 1 for randrange()")
+ _warn('non-integer arguments to randrange() have been deprecated '
+ 'since Python 3.10 and will be removed in a subsequent '
+ 'version',
+ DeprecationWarning, 2)
if stop is None:
# We don't check for "step != 1" because it hasn't been
# type checked and converted to an integer yet.
@@ -302,15 +312,37 @@ class Random(_random.Random):
return self._randbelow(istart)
raise ValueError("empty range for randrange()")
- # Stop argument supplied.
- istop = _index(stop)
+ # stop argument supplied.
+ try:
+ istop = _index(stop)
+ except TypeError:
+ istop = int(stop)
+ if istop != stop:
+ _warn('randrange() will raise TypeError in the future',
+ DeprecationWarning, 2)
+ raise ValueError("non-integer stop for randrange()")
+ _warn('non-integer arguments to randrange() have been deprecated '
+ 'since Python 3.10 and will be removed in a subsequent '
+ 'version',
+ DeprecationWarning, 2)
width = istop - istart
- istep = _index(step)
+ try:
+ istep = _index(step)
+ except TypeError:
+ istep = int(step)
+ if istep != step:
+ _warn('randrange() will raise TypeError in the future',
+ DeprecationWarning, 2)
+ raise ValueError("non-integer step for randrange()")
+ _warn('non-integer arguments to randrange() have been deprecated '
+ 'since Python 3.10 and will be removed in a subsequent '
+ 'version',
+ DeprecationWarning, 2)
# Fast path.
if istep == 1:
if width > 0:
return istart + self._randbelow(width)
- raise ValueError(f"empty range in randrange({start}, {stop}, {step})")
+ raise ValueError("empty range for randrange() (%d, %d, %d)" % (istart, istop, width))
# Non-unit step argument supplied.
if istep > 0:
@@ -320,7 +352,7 @@ class Random(_random.Random):
else:
raise ValueError("zero step for randrange()")
if n <= 0:
- raise ValueError(f"empty range in randrange({start}, {stop}, {step})")
+ raise ValueError("empty range for randrange()")
return istart + istep * self._randbelow(n)
def randint(self, a, b):