diff options
author | Christian Brabandt <cb@256bit.org> | 2023-11-19 10:47:21 +0100 |
---|---|---|
committer | Christian Brabandt <cb@256bit.org> | 2023-11-19 10:47:21 +0100 |
commit | 22cbc8a4e17ce61aa460c451a26e1bff2c3d2af9 (patch) | |
tree | c2fe07c70767247997525c00d2b6fe2ab4df9bd7 /src/normal.c | |
parent | 22a97fc241361aa91bda84e5344d5b7c0cda3e81 (diff) |
patch 9.0.2114: overflow detection not accurate when adding digitsv9.0.2114
Problem: overflow detection not accurate when adding digits
Solution: Use a helper function
Use a helper function to better detect overflows before adding integer
digits to a long or an integer variable respectively. Signal the
overflow to the caller function.
closes: #13539
Signed-off-by: Christian Brabandt <cb@256bit.org>
Signed-off-by: Michael Henry <vim@drmikehenry.com>
Signed-off-by: Ernie Rael <errael@raelity.com>
Diffstat (limited to 'src/normal.c')
-rw-r--r-- | src/normal.c | 3 |
1 files changed, 1 insertions, 2 deletions
diff --git a/src/normal.c b/src/normal.c index 16b4b45069..61a19c13a4 100644 --- a/src/normal.c +++ b/src/normal.c @@ -2563,12 +2563,11 @@ nv_z_get_count(cmdarg_T *cap, int *nchar_arg) n /= 10; else if (VIM_ISDIGIT(nchar)) { - if (n > LONG_MAX / 10) + if (vim_append_digit_long(&n, nchar - '0') == FAIL) { clearopbeep(cap->oap); break; } - n = n * 10 + (nchar - '0'); } else if (nchar == CAR) { |