mirror of
https://github.com/vim/vim.git
synced 2025-10-24 08:54:47 -04:00
patch 9.1.1068: getchar() can't distinguish between C-I and Tab
Problem: getchar() can't distinguish between C-I and Tab. Solution: Add {opts} to pass extra flags to getchar() and getcharstr(), with "number" and "simplify" keys. related: #10603 closes: #16554 Signed-off-by: zeertzjq <zeertzjq@outlook.com> Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
committed by
Christian Brabandt
parent
cbc1f409c1
commit
e0a2ab397f
26
src/typval.c
26
src/typval.c
@@ -526,6 +526,20 @@ check_for_bool_arg(typval_T *args, int idx)
|
||||
return OK;
|
||||
}
|
||||
|
||||
/*
|
||||
* Give an error and return FAIL unless "args[idx]" is a bool or a number.
|
||||
*/
|
||||
int
|
||||
check_for_bool_or_number_arg(typval_T *args, int idx)
|
||||
{
|
||||
if (args[idx].v_type != VAR_BOOL && args[idx].v_type != VAR_NUMBER)
|
||||
{
|
||||
semsg(_(e_bool_or_number_required_for_argument_nr), idx + 1);
|
||||
return FAIL;
|
||||
}
|
||||
return OK;
|
||||
}
|
||||
|
||||
/*
|
||||
* Check for an optional bool argument at 'idx'.
|
||||
* Return FAIL if the type is wrong.
|
||||
@@ -538,6 +552,18 @@ check_for_opt_bool_arg(typval_T *args, int idx)
|
||||
return check_for_bool_arg(args, idx);
|
||||
}
|
||||
|
||||
/*
|
||||
* Check for an optional bool or number argument at 'idx'.
|
||||
* Return FAIL if the type is wrong.
|
||||
*/
|
||||
int
|
||||
check_for_opt_bool_or_number_arg(typval_T *args, int idx)
|
||||
{
|
||||
if (args[idx].v_type == VAR_UNKNOWN)
|
||||
return OK;
|
||||
return check_for_bool_or_number_arg(args, idx);
|
||||
}
|
||||
|
||||
/*
|
||||
* Give an error and return FAIL unless "args[idx]" is a blob.
|
||||
*/
|
||||
|
Reference in New Issue
Block a user