updated for version 7.3.178
Problem: C-indent doesn't handle code right after { correctly.
Solution: Fix detecting unterminated line. (Lech Lorens)
diff --git a/src/misc1.c b/src/misc1.c
index 76c9525..3a94c3c 100644
--- a/src/misc1.c
+++ b/src/misc1.c
@@ -4983,7 +4983,7 @@
}
/*
- * Return TRUE if there there is no code at *s. White space and comments are
+ * Return TRUE if there is no code at *s. White space and comments are
* not considered code.
*/
static int
@@ -5458,8 +5458,11 @@
}
/*
- * Recognize a line that starts with '{' or '}', or ends with ';', '{' or '}'.
+ * Recognize a line that starts with '{' or '}', or ends with ';', ',', '{' or
+ * '}'.
* Don't consider "} else" a terminated line.
+ * Don't consider a line where there are unmatched opening braces before '}',
+ * ';' or ',' a terminated line.
* Return the character terminating the line (ending char's have precedence if
* both apply in order to determine initializations).
*/
@@ -5470,6 +5473,7 @@
int incl_comma; /* recognize a trailing comma */
{
char_u found_start = 0;
+ unsigned n_open = 0;
s = cin_skipcomment(s);
@@ -5480,10 +5484,19 @@
{
/* skip over comments, "" strings and 'c'haracters */
s = skip_string(cin_skipcomment(s));
- if ((*s == ';' || (incl_open && *s == '{') || *s == '}'
- || (incl_comma && *s == ','))
+ if (*s == '}' && n_open > 0)
+ --n_open;
+ if (n_open == 0
+ && (*s == ';' || *s == '}' || (incl_comma && *s == ','))
&& cin_nocode(s + 1))
return *s;
+ else if (*s == '{')
+ {
+ if (incl_open && cin_nocode(s + 1))
+ return *s;
+ else
+ ++n_open;
+ }
if (*s)
s++;
diff --git a/src/testdir/test3.in b/src/testdir/test3.in
index 62402fb..8576e27 100644
--- a/src/testdir/test3.in
+++ b/src/testdir/test3.in
Binary files differ
diff --git a/src/testdir/test3.ok b/src/testdir/test3.ok
index 4e2a648..3764453 100644
--- a/src/testdir/test3.ok
+++ b/src/testdir/test3.ok
@@ -1204,3 +1204,15 @@
{
}
+
+void func(void)
+{
+ if(x==y)
+ if(y==z)
+ foo=1;
+ else { bar=1;
+ baz=2;
+ }
+ printf("Foo!\n");
+}
+
diff --git a/src/version.c b/src/version.c
index 0c24bd2..f69bf4e 100644
--- a/src/version.c
+++ b/src/version.c
@@ -715,6 +715,8 @@
static int included_patches[] =
{ /* Add new patch number below this line */
/**/
+ 178,
+/**/
177,
/**/
176,