diff options
Diffstat (limited to 'clang')
| -rw-r--r-- | clang/lib/Parse/ParseExpr.cpp | 15 | ||||
| -rw-r--r-- | clang/test/Index/complete-objc-message.m | 5 |
2 files changed, 15 insertions, 5 deletions
diff --git a/clang/lib/Parse/ParseExpr.cpp b/clang/lib/Parse/ParseExpr.cpp index 55d2ba222f5..4113c4fac25 100644 --- a/clang/lib/Parse/ParseExpr.cpp +++ b/clang/lib/Parse/ParseExpr.cpp @@ -669,12 +669,17 @@ ExprResult Parser::ParseCastExpression(bool isUnaryExpression, break; } - // If we have an Objective-C class name followed by an identifier and - // either ':' or ']', this is an Objective-C class message send that's - // missing the opening '['. Recovery appropriately. - if (getLang().ObjC1 && Tok.is(tok::identifier) && !InMessageExpression) { + // If we have an Objective-C class name followed by an identifier + // and either ':' or ']', this is an Objective-C class message + // send that's missing the opening '['. Recovery + // appropriately. Also take this path if we're performing code + // completion after an Objective-C class name. + if (getLang().ObjC1 && + ((Tok.is(tok::identifier) && !InMessageExpression) || + Tok.is(tok::code_completion))) { const Token& Next = NextToken(); - if (Next.is(tok::colon) || Next.is(tok::r_square)) + if (Tok.is(tok::code_completion) || + Next.is(tok::colon) || Next.is(tok::r_square)) if (ParsedType Typ = Actions.getTypeName(II, ILoc, getCurScope())) if (Typ.get()->isObjCObjectOrInterfaceType()) { // Fake up a Declarator to use with ActOnTypeName. diff --git a/clang/test/Index/complete-objc-message.m b/clang/test/Index/complete-objc-message.m index 4e662b32ec8..0658d53c651 100644 --- a/clang/test/Index/complete-objc-message.m +++ b/clang/test/Index/complete-objc-message.m @@ -171,6 +171,10 @@ void test_redundancy(C *c) { } @end +void test_missing_open_more() { + A *a = A class_method3]; +} + // RUN: c-index-test -code-completion-at=%s:23:19 %s | FileCheck -check-prefix=CHECK-CC1 %s // CHECK-CC1: {TypedText categoryClassMethod} // CHECK-CC1: {TypedText classMethod1:}{Placeholder (id)}{HorizontalSpace }{TypedText withKeyword:}{Placeholder (int)} @@ -294,3 +298,4 @@ void test_redundancy(C *c) { // RUN: c-index-test -code-completion-at=%s:141:23 %s | FileCheck -check-prefix=CHECK-CCD %s // RUN: c-index-test -code-completion-at=%s:141:30 %s | FileCheck -check-prefix=CHECK-CCE %s +// RUN: c-index-test -code-completion-at=%s:175:12 %s | FileCheck -check-prefix=CHECK-CLASS-RESULT %s |

