mirror of
https://github.com/vim/vim.git
synced 2025-09-24 03:44:06 -04:00
patch 9.0.2114: overflow detection not accurate when adding digits
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>
This commit is contained in:
25
src/misc1.c
25
src/misc1.c
@@ -975,9 +975,8 @@ get_number(
|
|||||||
c = safe_vgetc();
|
c = safe_vgetc();
|
||||||
if (VIM_ISDIGIT(c))
|
if (VIM_ISDIGIT(c))
|
||||||
{
|
{
|
||||||
if (n > INT_MAX / 10)
|
if (vim_append_digit_int(&n, c - '0') == FAIL)
|
||||||
return 0;
|
return 0;
|
||||||
n = n * 10 + c - '0';
|
|
||||||
msg_putchar(c);
|
msg_putchar(c);
|
||||||
++typed;
|
++typed;
|
||||||
}
|
}
|
||||||
@@ -2817,3 +2816,25 @@ may_trigger_modechanged(void)
|
|||||||
restore_v_event(v_event, &save_v_event);
|
restore_v_event(v_event, &save_v_event);
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// For overflow detection, add a digit safely to an int value.
|
||||||
|
int
|
||||||
|
vim_append_digit_int(int *value, int digit)
|
||||||
|
{
|
||||||
|
int x = *value;
|
||||||
|
if (x > ((INT_MAX - digit) / 10))
|
||||||
|
return FAIL;
|
||||||
|
*value = x * 10 + digit;
|
||||||
|
return OK;
|
||||||
|
}
|
||||||
|
|
||||||
|
// For overflow detection, add a digit safely to a long value.
|
||||||
|
int
|
||||||
|
vim_append_digit_long(long *value, int digit)
|
||||||
|
{
|
||||||
|
long x = *value;
|
||||||
|
if (x > ((LONG_MAX - (long)digit) / 10))
|
||||||
|
return FAIL;
|
||||||
|
*value = x * 10 + (long)digit;
|
||||||
|
return OK;
|
||||||
|
}
|
||||||
|
@@ -2563,12 +2563,11 @@ nv_z_get_count(cmdarg_T *cap, int *nchar_arg)
|
|||||||
n /= 10;
|
n /= 10;
|
||||||
else if (VIM_ISDIGIT(nchar))
|
else if (VIM_ISDIGIT(nchar))
|
||||||
{
|
{
|
||||||
if (n > LONG_MAX / 10)
|
if (vim_append_digit_long(&n, nchar - '0') == FAIL)
|
||||||
{
|
{
|
||||||
clearopbeep(cap->oap);
|
clearopbeep(cap->oap);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
n = n * 10 + (nchar - '0');
|
|
||||||
}
|
}
|
||||||
else if (nchar == CAR)
|
else if (nchar == CAR)
|
||||||
{
|
{
|
||||||
|
@@ -53,4 +53,6 @@ int path_with_url(char_u *fname);
|
|||||||
dict_T *get_v_event(save_v_event_T *sve);
|
dict_T *get_v_event(save_v_event_T *sve);
|
||||||
void restore_v_event(dict_T *v_event, save_v_event_T *sve);
|
void restore_v_event(dict_T *v_event, save_v_event_T *sve);
|
||||||
void may_trigger_modechanged(void);
|
void may_trigger_modechanged(void);
|
||||||
|
int vim_append_digit_int(int *value, int digit);
|
||||||
|
int vim_append_digit_long(long *value, int digit);
|
||||||
/* vim: set ft=c : */
|
/* vim: set ft=c : */
|
||||||
|
@@ -704,6 +704,8 @@ static char *(features[]) =
|
|||||||
|
|
||||||
static int included_patches[] =
|
static int included_patches[] =
|
||||||
{ /* Add new patch number below this line */
|
{ /* Add new patch number below this line */
|
||||||
|
/**/
|
||||||
|
2114,
|
||||||
/**/
|
/**/
|
||||||
2113,
|
2113,
|
||||||
/**/
|
/**/
|
||||||
|
Reference in New Issue
Block a user