Skip to content
Snippets Groups Projects
Commit 48d27921 authored by Bram Moolenaar's avatar Bram Moolenaar
Browse files

updated for version 7.3.549

Problem:    In 'cinoptions' "0s" is interpreted as one shiftwidth. (David
            Pineau)
Solution:   Use the zero as zero. (Lech Lorens)
parent 27ba0885
No related merge requests found
......@@ -6635,6 +6635,7 @@ get_c_indent()
int whilelevel;
linenr_T lnum;
char_u *options;
char_u *digits;
int fraction = 0; /* init for GCC */
int divider;
int n;
......@@ -6650,6 +6651,7 @@ get_c_indent()
l = options++;
if (*options == '-')
++options;
digits = options; /* remember where the digits start */
n = getdigits(&options);
divider = 0;
if (*options == '.') /* ".5s" means a fraction */
......@@ -6666,7 +6668,7 @@ get_c_indent()
}
if (*options == 's') /* "2s" means two times 'shiftwidth' */
{
if (n == 0 && fraction == 0)
if (options == digits)
n = curbuf->b_p_sw; /* just "s" is one 'shiftwidth' */
else
{
......
......@@ -975,6 +975,24 @@ main ( int first_par, /*
}
STARTTEST
:set cin
:set cino=es,n0s
/main
=][
ENDTEST
main(void)
{
/* Make sure that cino=X0s is not parsed like cino=Xs. */
if (cond)
foo();
else
{
bar();
}
}
STARTTEST
:set cin
:set cino=
......
......@@ -940,6 +940,18 @@ main ( int first_par, /*
}
main(void)
{
/* Make sure that cino=X0s is not parsed like cino=Xs. */
if (cond)
foo();
else
{
bar();
}
}
{
do
{
......
......@@ -714,6 +714,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
549,
/**/
548,
/**/
......
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment