diff options
author | Ned Batchelder <ned@nedbatchelder.com> | 2022-02-05 13:46:16 -0500 |
---|---|---|
committer | Ned Batchelder <ned@nedbatchelder.com> | 2022-02-06 11:09:53 -0500 |
commit | ac8c29a77c0d7d4a1a0b6b694d2951e252732bcb (patch) | |
tree | 64e040485b2386b26af2cf201bdaa9f758252d48 /coverage/env.py | |
parent | 82ae658412ede7519d6212724e45714f8daa765e (diff) | |
download | python-coveragepy-git-ac8c29a77c0d7d4a1a0b6b694d2951e252732bcb.tar.gz |
test: make if_not_debug optimization testing a little more rational
Diffstat (limited to 'coverage/env.py')
-rw-r--r-- | coverage/env.py | 31 |
1 files changed, 16 insertions, 15 deletions
diff --git a/coverage/env.py b/coverage/env.py index b76a206b..3b24c390 100644 --- a/coverage/env.py +++ b/coverage/env.py @@ -39,22 +39,23 @@ class PYBEHAVIOR: else: optimize_if_debug = not pep626 - # Is "if not __debug__" optimized away? - optimize_if_not_debug = (not PYPY) and (PYVERSION >= (3, 7, 0, 'alpha', 4)) + # Is "if not __debug__" optimized away? The exact details have changed + # across versions. + optimize_if_not_debug = 0 if pep626: - optimize_if_not_debug = False - if PYPY: - optimize_if_not_debug = True - - # Is "if not __debug__" optimized away even better? - optimize_if_not_debug2 = (not PYPY) and (PYVERSION >= (3, 8, 0, 'beta', 1)) - if pep626: - optimize_if_not_debug2 = False - if PYPY and (PYVERSION >= (3, 9)): - optimize_if_not_debug2 = True - - # Yet another way to optimize "if not __debug__"? - optimize_if_not_debug3 = (PYPY and (3, 8) <= PYVERSION <= (3, 9)) + optimize_if_not_debug = 1 + elif PYPY: + if PYVERSION >= (3, 9): + optimize_if_not_debug = 2 + elif PYVERSION[:2] == (3, 8): + optimize_if_not_debug = 3 + elif PYVERSION[:2] <= (3, 7): + optimize_if_not_debug = 1 + else: + if PYVERSION >= (3, 8, 0, 'beta', 1): + optimize_if_not_debug = 2 + elif PYVERSION >= (3, 7, 0, 'alpha', 4): + optimize_if_not_debug = 1 # Can co_lnotab have negative deltas? negative_lnotab = not (PYPY and PYPYVERSION < (7, 2)) |