From: Fariborz Jahanian Date: Thu, 10 Jan 2008 17:58:07 +0000 (+0000) Subject: Warn (as gcc does) when @end does not close anything. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=94cdb25a49bd3716ab56ef6de0ea57d29e686bf2;p=clang Warn (as gcc does) when @end does not close anything. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@45834 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/Parse/ParseObjc.cpp b/Parse/ParseObjc.cpp index 989f1dce17..34694ef5c5 100644 --- a/Parse/ParseObjc.cpp +++ b/Parse/ParseObjc.cpp @@ -991,13 +991,10 @@ Parser::DeclTy *Parser::ParseObjCAtEndDeclaration(SourceLocation atLoc) { assert(Tok.isObjCAtKeyword(tok::objc_end) && "ParseObjCAtEndDeclaration(): Expected @end"); ConsumeToken(); // the "end" identifier - if (ObjCImpDecl) { - // Checking is not necessary except that a parse error might have caused - // @implementation not to have been parsed to completion and ObjCImpDecl - // could be 0. + if (ObjCImpDecl) Actions.ActOnAtEnd(atLoc, ObjCImpDecl); - } - + else + Diag(atLoc, diag::warn_expected_implementation); // missing @implementation return ObjCImpDecl; } diff --git a/include/clang/Basic/DiagnosticKinds.def b/include/clang/Basic/DiagnosticKinds.def index 289f770ec6..f041a3a47b 100644 --- a/include/clang/Basic/DiagnosticKinds.def +++ b/include/clang/Basic/DiagnosticKinds.def @@ -478,6 +478,8 @@ DIAG(err_selector_element_type, ERROR, "selector element is not of valid object type (its type is '%0')") DIAG(err_toomany_element_decls, ERROR, "Only one element declaration is allowed") +DIAG(warn_expected_implementation, WARNING, + "‘@end’ must appear in an @implementation context") //===----------------------------------------------------------------------===// // Semantic Analysis diff --git a/test/Parser/objc-missing-impl.m b/test/Parser/objc-missing-impl.m new file mode 100644 index 0000000000..062130d358 --- /dev/null +++ b/test/Parser/objc-missing-impl.m @@ -0,0 +1,2 @@ +// RUN: clang -fsyntax-only -verify %s +@end // expected-warning {{‘@end’ must appear in an @implementation context}}