diff options
author | Tom Rini <trini@konsulko.com> | 2023-03-28 10:57:34 -0400 |
---|---|---|
committer | Tom Rini <trini@konsulko.com> | 2023-03-28 10:57:34 -0400 |
commit | 27fbae57ab879bb02abb1784b1fb858dd6c2a0de (patch) | |
tree | 09e08eefd123e358b5012df3dd88f233547b64d8 /common/cli_getch.c | |
parent | 41a88ad529b3943b1e465846eb24fe2c29203e35 (diff) | |
parent | be0169f07e38b81dd96bca2e80610592d89f8550 (diff) |
Merge branch '2023-03-28-correct-several-cli_getch-bugs'
- Merge a regression fix (for an issue that we raised post v2023.01)
with cli_getch(), and include a test now.
Diffstat (limited to 'common/cli_getch.c')
-rw-r--r-- | common/cli_getch.c | 5 |
1 files changed, 3 insertions, 2 deletions
diff --git a/common/cli_getch.c b/common/cli_getch.c index 87c23edcf4b..61d4cb261b8 100644 --- a/common/cli_getch.c +++ b/common/cli_getch.c @@ -129,7 +129,7 @@ static int cli_ch_esc(struct cli_ch_state *cch, int ichar, *actp = act; - return act == ESC_CONVERTED ? ichar : 0; + return ichar; } int cli_ch_process(struct cli_ch_state *cch, int ichar) @@ -145,6 +145,7 @@ int cli_ch_process(struct cli_ch_state *cch, int ichar) return cch->esc_save[cch->emit_upto++]; cch->emit_upto = 0; cch->emitting = false; + cch->esc_len = 0; } return 0; } else if (ichar == -ETIMEDOUT) { @@ -185,7 +186,7 @@ int cli_ch_process(struct cli_ch_state *cch, int ichar) cch->esc_save[cch->esc_len++] = ichar; ichar = cch->esc_save[cch->emit_upto++]; cch->emitting = true; - break; + return ichar; case ESC_CONVERTED: /* valid escape sequence, return the resulting char */ cch->esc_len = 0; |