diff options
author | Steve Naroff <snaroff@apple.com> | 2007-09-12 14:07:44 +0000 |
---|---|---|
committer | Steve Naroff <snaroff@apple.com> | 2007-09-12 14:07:44 +0000 |
commit | bb204693855fe87a6e4b23dfd053722026dbe87c (patch) | |
tree | df19766a862976819cb17a5cdcb6ec24b7d482a1 /Parse/ParseDecl.cpp | |
parent | 155383b0fcd0a12a103310010f8c0d084b90b090 (diff) |
Fix the following bug submitted by Ted Kremenek:
void func() {
int xx = xx; // incorrectly diagnosed 'xx' as an undeclared identifier.
}
This smallish bug resulted in a largish fix. Here are some highlights:
- Needed to make sure ParseDeclarator is called *before* parsing any
initializer. Removed the "Init" argument to ParseDeclarator.
- Added AddInitializerToDecl() to the Action & Sema classes.
In Sema, this hook is responsible for validating the initializer and
installing it into the respective decl.
- Moved several semantic checks from ParseDeclarator() to
FinalizeDeclaratorGroup(). Previously, this hook was only responsible for
reversing a list. Now it plays a much larger semantic role.
All of the above changes ended up simplifying ParseDeclarator(), which
is goodness...
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@41877 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'Parse/ParseDecl.cpp')
-rw-r--r-- | Parse/ParseDecl.cpp | 12 |
1 files changed, 6 insertions, 6 deletions
diff --git a/Parse/ParseDecl.cpp b/Parse/ParseDecl.cpp index dc9edc332c..be3711106b 100644 --- a/Parse/ParseDecl.cpp +++ b/Parse/ParseDecl.cpp @@ -262,7 +262,11 @@ ParseInitDeclaratorListAfterFirstDeclarator(Declarator &D) { // If attributes are present, parse them. if (Tok.getKind() == tok::kw___attribute) D.AddAttributes(ParseAttributes()); - + + // Inform the current actions module that we just parsed this declarator. + // FIXME: pass asm & attributes. + LastDeclInGroup = Actions.ParseDeclarator(CurScope, D, LastDeclInGroup); + // Parse declarator '=' initializer. ExprResult Init; if (Tok.getKind() == tok::equal) { @@ -272,13 +276,9 @@ ParseInitDeclaratorListAfterFirstDeclarator(Declarator &D) { SkipUntil(tok::semi); return 0; } + Actions.AddInitializerToDecl(LastDeclInGroup, Init.Val); } - // Inform the current actions module that we just parsed this declarator. - // FIXME: pass asm & attributes. - LastDeclInGroup = Actions.ParseDeclarator(CurScope, D, Init.Val, - LastDeclInGroup); - // If we don't have a comma, it is either the end of the list (a ';') or an // error, bail out. if (Tok.getKind() != tok::comma) |