updated for version 7.3.201

Problem:    "} else" still causes following lines to be indented too much.
Solution:   Better detection for the "else" block. (Lech Lorens)
This commit is contained in:
Bram Moolenaar
2011-05-25 13:34:04 +02:00
parent 1a9c432846
commit 63882c14f3
4 changed files with 43 additions and 7 deletions
+15 -7
View File
@@ -7541,17 +7541,25 @@ get_c_indent()
/*
* When searching for a terminated line, don't use the
* one between the "if" and the "else".
* one between the "if" and the matching "else".
* Need to use the scope of this "else". XXX
* If whilelevel != 0 continue looking for a "do {".
*/
if (cin_iselse(l)
&& whilelevel == 0
&& ((trypos = find_start_brace(ind_maxcomment))
== NULL
if (cin_iselse(l) && whilelevel == 0)
{
/* If we're looking at "} else", let's make sure we
* find the opening brace of the enclosing scope,
* not the one from "if () {". */
if (*l == '}')
curwin->w_cursor.col =
(l - ml_get_curline()) + 1;
if ((trypos = find_start_brace(ind_maxcomment))
== NULL
|| find_match(LOOKFOR_IF, trypos->lnum,
ind_maxparen, ind_maxcomment) == FAIL))
break;
ind_maxparen, ind_maxcomment) == FAIL)
break;
}
}
/*
+15
View File
@@ -1412,6 +1412,21 @@ void func(void)
*/
}
STARTTEST
:set cino&
2kdd=][
ENDTEST
void func(void)
{
for (int i = 0; i < 10; ++i)
if (i & 1) {
foo(1);
} else
foo(0);
baz();
}
STARTTEST
:g/^STARTTEST/.,/^ENDTEST/d
:1;/start of AUTO/,$wq! test.out
+11
View File
@@ -1262,3 +1262,14 @@ void func(void)
foo();
}
void func(void)
{
for (int i = 0; i < 10; ++i)
if (i & 1) {
foo(1);
} else
foo(0);
baz();
}
+2
View File
@@ -709,6 +709,8 @@ static char *(features[]) =
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
201,
/**/
200,
/**/