mirror of
https://github.com/neovim/neovim.git
synced 2024-12-31 17:13:26 -07:00
vim-patch:7.4.912
Problem: Wrong indenting for C++ constructor.
Solution: Recognize ::. (Anhong)
e01f4f86ce
This commit is contained in:
parent
72d5a88af5
commit
ade2298735
@ -857,13 +857,27 @@ static int cin_isfuncdecl(char_u **sp, linenr_T first_lnum, linenr_T min_lnum)
|
||||
return FALSE;
|
||||
|
||||
while (*s && *s != '(' && *s != ';' && *s != '\'' && *s != '"') {
|
||||
if (cin_iscomment(s)) /* ignore comments */
|
||||
// ignore comments
|
||||
if (cin_iscomment(s)) {
|
||||
s = cin_skipcomment(s);
|
||||
else
|
||||
++s;
|
||||
} else if (*s == ':') {
|
||||
if (*(s + 1) == ':') {
|
||||
s += 2;
|
||||
} else {
|
||||
// To avoid a mistake in the following situation:
|
||||
// A::A(int a, int b)
|
||||
// : a(0) // <--not a function decl
|
||||
// , b(0)
|
||||
// {...
|
||||
return false;
|
||||
}
|
||||
} else {
|
||||
s++;
|
||||
}
|
||||
}
|
||||
if (*s != '(') {
|
||||
return false; // ';', ' or " before any () or no '('
|
||||
}
|
||||
if (*s != '(')
|
||||
return FALSE; /* ';', ' or " before any () or no '(' */
|
||||
|
||||
while (*s && *s != ';' && *s != '\'' && *s != '"') {
|
||||
if (*s == ')' && cin_nocode(s + 1)) {
|
||||
|
@ -376,7 +376,7 @@ static int included_patches[] = {
|
||||
915,
|
||||
// 914,
|
||||
// 913 NA
|
||||
// 912,
|
||||
912,
|
||||
// 911 NA
|
||||
// 910 NA
|
||||
// 909,
|
||||
|
@ -674,6 +674,13 @@ describe('cindent', function()
|
||||
{
|
||||
}
|
||||
|
||||
A::A(int a, int b)
|
||||
: aa(a),
|
||||
bb(b),
|
||||
cc(c)
|
||||
{
|
||||
}
|
||||
|
||||
class CAbc :
|
||||
public BaseClass1,
|
||||
protected BaseClass2
|
||||
@ -1629,6 +1636,13 @@ describe('cindent', function()
|
||||
{
|
||||
}
|
||||
|
||||
A::A(int a, int b)
|
||||
: aa(a),
|
||||
bb(b),
|
||||
cc(c)
|
||||
{
|
||||
}
|
||||
|
||||
class CAbc :
|
||||
public BaseClass1,
|
||||
protected BaseClass2
|
||||
|
Loading…
Reference in New Issue
Block a user