mirror of
https://github.com/vim/vim.git
synced 2025-09-26 04:04:07 -04:00
updated for version 7.4.057
Problem: byteidx() does not work for composing characters. Solution: Add byteidxcomp().
This commit is contained in:
36
src/eval.c
36
src/eval.c
@@ -474,7 +474,9 @@ static void f_bufname __ARGS((typval_T *argvars, typval_T *rettv));
|
||||
static void f_bufnr __ARGS((typval_T *argvars, typval_T *rettv));
|
||||
static void f_bufwinnr __ARGS((typval_T *argvars, typval_T *rettv));
|
||||
static void f_byte2line __ARGS((typval_T *argvars, typval_T *rettv));
|
||||
static void byteidx __ARGS((typval_T *argvars, typval_T *rettv, int comp));
|
||||
static void f_byteidx __ARGS((typval_T *argvars, typval_T *rettv));
|
||||
static void f_byteidxcomp __ARGS((typval_T *argvars, typval_T *rettv));
|
||||
static void f_call __ARGS((typval_T *argvars, typval_T *rettv));
|
||||
#ifdef FEAT_FLOAT
|
||||
static void f_ceil __ARGS((typval_T *argvars, typval_T *rettv));
|
||||
@@ -7861,6 +7863,7 @@ static struct fst
|
||||
{"bufwinnr", 1, 1, f_bufwinnr},
|
||||
{"byte2line", 1, 1, f_byte2line},
|
||||
{"byteidx", 2, 2, f_byteidx},
|
||||
{"byteidxcomp", 2, 2, f_byteidxcomp},
|
||||
{"call", 2, 3, f_call},
|
||||
#ifdef FEAT_FLOAT
|
||||
{"ceil", 1, 1, f_ceil},
|
||||
@@ -9177,13 +9180,11 @@ f_byte2line(argvars, rettv)
|
||||
#endif
|
||||
}
|
||||
|
||||
/*
|
||||
* "byteidx()" function
|
||||
*/
|
||||
static void
|
||||
f_byteidx(argvars, rettv)
|
||||
byteidx(argvars, rettv, comp)
|
||||
typval_T *argvars;
|
||||
typval_T *rettv;
|
||||
int comp;
|
||||
{
|
||||
#ifdef FEAT_MBYTE
|
||||
char_u *t;
|
||||
@@ -9203,7 +9204,10 @@ f_byteidx(argvars, rettv)
|
||||
{
|
||||
if (*t == NUL) /* EOL reached */
|
||||
return;
|
||||
t += (*mb_ptr2len)(t);
|
||||
if (enc_utf8 && comp)
|
||||
t += utf_ptr2len(t);
|
||||
else
|
||||
t += (*mb_ptr2len)(t);
|
||||
}
|
||||
rettv->vval.v_number = (varnumber_T)(t - str);
|
||||
#else
|
||||
@@ -9212,6 +9216,28 @@ f_byteidx(argvars, rettv)
|
||||
#endif
|
||||
}
|
||||
|
||||
/*
|
||||
* "byteidx()" function
|
||||
*/
|
||||
static void
|
||||
f_byteidx(argvars, rettv)
|
||||
typval_T *argvars;
|
||||
typval_T *rettv;
|
||||
{
|
||||
byteidx(argvars, rettv, FALSE);
|
||||
}
|
||||
|
||||
/*
|
||||
* "byteidxcomp()" function
|
||||
*/
|
||||
static void
|
||||
f_byteidxcomp(argvars, rettv)
|
||||
typval_T *argvars;
|
||||
typval_T *rettv;
|
||||
{
|
||||
byteidx(argvars, rettv, TRUE);
|
||||
}
|
||||
|
||||
int
|
||||
func_call(name, args, selfdict, rettv)
|
||||
char_u *name;
|
||||
|
Reference in New Issue
Block a user