diff options
author | Kevin Van Brunt <kmvanbrunt@gmail.com> | 2020-09-30 14:19:13 -0400 |
---|---|---|
committer | Kevin Van Brunt <kmvanbrunt@gmail.com> | 2020-09-30 20:36:46 -0400 |
commit | 018c329a4df9f3b84227cf33a14f9482f3e7eb2a (patch) | |
tree | aaaedcef9a4391b9952d0da48e54e8672ef738c1 /cmd2/utils.py | |
parent | ed7b9e5185fd14808aa26e61a26968b9753beee0 (diff) | |
download | cmd2-git-018c329a4df9f3b84227cf33a14f9482f3e7eb2a.tar.gz |
Fixed issue where quoted redirectors and terminators in aliases and macros were not being
restored when read from a startup script.
Diffstat (limited to 'cmd2/utils.py')
-rw-r--r-- | cmd2/utils.py | 30 |
1 files changed, 21 insertions, 9 deletions
diff --git a/cmd2/utils.py b/cmd2/utils.py index b6dadf1c..45ca494c 100644 --- a/cmd2/utils.py +++ b/cmd2/utils.py @@ -318,17 +318,29 @@ def natural_sort(list_to_sort: Iterable[str]) -> List[str]: return sorted(list_to_sort, key=natural_keys) -def unquote_specific_tokens(args: List[str], tokens_to_unquote: List[str]) -> None: +def quote_specific_tokens(tokens: List[str], tokens_to_quote: List[str]) -> None: """ - Unquote a specific tokens in a list of command-line arguments - This is used when certain tokens have to be passed to another command - :param args: the command line args - :param tokens_to_unquote: the tokens, which if present in args, to unquote + Quote specific tokens in a list + + :param tokens: token list being edited + :param tokens_to_quote: the tokens, which if present in tokens, to quote + """ + for i, token in enumerate(tokens): + if token in tokens_to_quote: + tokens[i] = quote_string(token) + + +def unquote_specific_tokens(tokens: List[str], tokens_to_unquote: List[str]) -> None: + """ + Unquote specific tokens in a list + + :param tokens: token list being edited + :param tokens_to_unquote: the tokens, which if present in tokens, to unquote """ - for i, arg in enumerate(args): - unquoted_arg = strip_quotes(arg) - if unquoted_arg in tokens_to_unquote: - args[i] = unquoted_arg + for i, token in enumerate(tokens): + unquoted_token = strip_quotes(token) + if unquoted_token in tokens_to_unquote: + tokens[i] = unquoted_token def expand_user(token: str) -> str: |