Commit 6aeb2fe6 authored by Terry Jan Reedy's avatar Terry Jan Reedy Committed by GitHub

bpo-26806: IDLE should run without docstrings (#14657)

After fcf1d003, IDLE startup failed with python compiled without docstrings.
parent 3a3db970
...@@ -292,6 +292,14 @@ class TestSysRecursionLimitWrappers(unittest.TestCase): ...@@ -292,6 +292,14 @@ class TestSysRecursionLimitWrappers(unittest.TestCase):
new_reclimit = sys.getrecursionlimit() new_reclimit = sys.getrecursionlimit()
self.assertEqual(new_reclimit, orig_reclimit) self.assertEqual(new_reclimit, orig_reclimit)
def test_fixdoc(self):
def func(): "docstring"
run.fixdoc(func, "more")
self.assertEqual(func.__doc__, "docstring\n\nmore")
func.__doc__ = None
run.fixdoc(func, "more")
self.assertEqual(func.__doc__, "more")
if __name__ == '__main__': if __name__ == '__main__':
unittest.main(verbosity=2) unittest.main(verbosity=2)
...@@ -307,7 +307,12 @@ def fix_scaling(root): ...@@ -307,7 +307,12 @@ def fix_scaling(root):
font['size'] = round(-0.75*size) font['size'] = round(-0.75*size)
def fixdoc(fun, text):
tem = (fun.__doc__ + '\n\n') if fun.__doc__ is not None else ''
fun.__doc__ = tem + textwrap.fill(textwrap.dedent(text))
RECURSIONLIMIT_DELTA = 30 RECURSIONLIMIT_DELTA = 30
def install_recursionlimit_wrappers(): def install_recursionlimit_wrappers():
"""Install wrappers to always add 30 to the recursion limit.""" """Install wrappers to always add 30 to the recursion limit."""
# see: bpo-26806 # see: bpo-26806
...@@ -329,19 +334,17 @@ def install_recursionlimit_wrappers(): ...@@ -329,19 +334,17 @@ def install_recursionlimit_wrappers():
return setrecursionlimit.__wrapped__(limit + RECURSIONLIMIT_DELTA) return setrecursionlimit.__wrapped__(limit + RECURSIONLIMIT_DELTA)
setrecursionlimit.__doc__ += "\n\n" + textwrap.fill(textwrap.dedent(f"""\ fixdoc(setrecursionlimit, f"""\
This IDLE wrapper adds {RECURSIONLIMIT_DELTA} to prevent possible This IDLE wrapper adds {RECURSIONLIMIT_DELTA} to prevent possible
uninterruptible loops. uninterruptible loops.""")
""").strip())
@functools.wraps(sys.getrecursionlimit) @functools.wraps(sys.getrecursionlimit)
def getrecursionlimit(): def getrecursionlimit():
return getrecursionlimit.__wrapped__() - RECURSIONLIMIT_DELTA return getrecursionlimit.__wrapped__() - RECURSIONLIMIT_DELTA
getrecursionlimit.__doc__ += "\n\n" + textwrap.fill(textwrap.dedent(f"""\ fixdoc(getrecursionlimit, f"""\
This IDLE wrapper subtracts {RECURSIONLIMIT_DELTA} to compensate for This IDLE wrapper subtracts {RECURSIONLIMIT_DELTA} to compensate
the {RECURSIONLIMIT_DELTA} IDLE adds when setting the limit. for the {RECURSIONLIMIT_DELTA} IDLE adds when setting the limit.""")
""").strip())
# add the delta to the default recursion limit, to compensate # add the delta to the default recursion limit, to compensate
sys.setrecursionlimit(sys.getrecursionlimit() + RECURSIONLIMIT_DELTA) sys.setrecursionlimit(sys.getrecursionlimit() + RECURSIONLIMIT_DELTA)
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment