From 483fcca507af1f6cd0b5210c79b1eb540344150c Mon Sep 17 00:00:00 2001 From: AlexTereshenkov <50622389+AlexTereshenkov@users.noreply.github.com> Date: Fri, 19 Mar 2021 10:09:21 +0000 Subject: [PATCH] Strip ANSI escape codes --- sphinx_click/ext.py | 9 +++++---- tests/test_formatter.py | 36 +++++++++++++++++++++++++++++++++++- 2 files changed, 40 insertions(+), 5 deletions(-) diff --git a/sphinx_click/ext.py b/sphinx_click/ext.py index 0aa15af..7692dfe 100644 --- a/sphinx_click/ext.py +++ b/sphinx_click/ext.py @@ -145,7 +145,7 @@ def _format_option(opt): if opt[1]: yield '' for line in statemachine.string2lines( - opt[1], tab_width=4, convert_whitespace=True + ANSI_ESC_SEQ_RE.sub('', opt[1]), tab_width=4, convert_whitespace=True ): yield _indent(line) @@ -241,12 +241,13 @@ def _format_epilog(ctx): We parse this as reStructuredText, allowing users to embed rich information in their help messages if they so choose. """ - epilog_string = ctx.command.epilog - if not epilog_string: + if not ctx.command.epilog: return for line in statemachine.string2lines( - epilog_string, tab_width=4, convert_whitespace=True + ANSI_ESC_SEQ_RE.sub('', ctx.command.epilog), + tab_width=4, + convert_whitespace=True, ): yield line yield '' diff --git a/tests/test_formatter.py b/tests/test_formatter.py index 7d32199..93de929 100644 --- a/tests/test_formatter.py +++ b/tests/test_formatter.py @@ -269,7 +269,23 @@ def hello(name): def test_ansi_escape_sequences(self): """Validate that ANSI escape sequences are stripped.""" - @click.command() + @click.command(epilog='\033[31mA sample epilog.\033[0m') + @click.option( + '--name', + help='Name to say \033[94mhello\033[0m to.', + required=True, + type=str, + ) + @click.option( + '--choice', + help='A sample option with choices', + type=click.Choice(['\033[94mOption1\033[0m', '\033[94mOption2\033[0m']), + ) + @click.option( + '--param', + default=lambda: None, + show_default='Something computed at \033[94mruntime\033[0m', + ) def foobar(): """A sample command with **sparkles**. @@ -293,6 +309,24 @@ def foobar(): .. code-block:: shell foobar [OPTIONS] + + .. rubric:: Options + + .. option:: --name + + **Required** Name to say hello to. + + .. option:: --choice + + A sample option with choices + + :options: Option1 | Option2 + + .. option:: --param + + :default: Something computed at runtime + + A sample epilog. """ ).lstrip(), '\n'.join(output),