From: Chris Lattner Date: Sat, 16 Feb 2008 01:20:36 +0000 (+0000) Subject: Fix CheckEndOfDirective to diagnose lines that contain macros that expand to X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=e9ba32357c380f587fc1296992822e1b47fbd22d;p=clang Fix CheckEndOfDirective to diagnose lines that contain macros that expand to zero tokens. This fixes PR2045, thanks to Neil for finding another incredibly subtle corner case :) git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@47203 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/Lex/Preprocessor.cpp b/Lex/Preprocessor.cpp index a291fe35df..7bd359ae18 100644 --- a/Lex/Preprocessor.cpp +++ b/Lex/Preprocessor.cpp @@ -1498,11 +1498,14 @@ void Preprocessor::ReadMacroName(Token &MacroNameTok, char isDefineUndef) { /// not, emit a diagnostic and consume up until the eom. void Preprocessor::CheckEndOfDirective(const char *DirType) { Token Tmp; - Lex(Tmp); + // Lex unexpanded tokens: macros might expand to zero tokens, causing us to + // miss diagnosing invalid lines. + LexUnexpandedToken(Tmp); + // There should be no tokens after the directive, but we allow them as an // extension. while (Tmp.is(tok::comment)) // Skip comments in -C mode. - Lex(Tmp); + LexUnexpandedToken(Tmp); if (Tmp.isNot(tok::eom)) { Diag(Tmp, diag::ext_pp_extra_tokens_at_eol, DirType); diff --git a/Sema/SemaDecl.cpp b/Sema/SemaDecl.cpp index 2f866c0497..61de36faf6 100644 --- a/Sema/SemaDecl.cpp +++ b/Sema/SemaDecl.cpp @@ -1032,8 +1032,7 @@ Sema::DeclTy *Sema::ActOnStartOfFunctionDef(Scope *FnBodyScope, Declarator &D) { } } Decl *decl = static_cast(ActOnDeclarator(GlobalScope, D, 0)); - FunctionDecl *FD = dyn_cast(decl); - assert(FD != 0 && "ActOnDeclarator() didn't return a FunctionDecl"); + FunctionDecl *FD = cast(decl); CurFunctionDecl = FD; // Create Decl objects for each parameter, adding them to the FunctionDecl. diff --git a/test/Preprocessor/undef-error.c b/test/Preprocessor/undef-error.c new file mode 100644 index 0000000000..af9f516f11 --- /dev/null +++ b/test/Preprocessor/undef-error.c @@ -0,0 +1,5 @@ +// RUN: not clang %s -pedantic-errors -E +// PR2045 + +#define b +#undef a b