]> granicus.if.org Git - clang/commit
Fix the following bug submitted by Ted Kremenek:
authorSteve Naroff <snaroff@apple.com>
Wed, 12 Sep 2007 14:07:44 +0000 (14:07 +0000)
committerSteve Naroff <snaroff@apple.com>
Wed, 12 Sep 2007 14:07:44 +0000 (14:07 +0000)
commitbb204693855fe87a6e4b23dfd053722026dbe87c
treedf19766a862976819cb17a5cdcb6ec24b7d482a1
parent155383b0fcd0a12a103310010f8c0d084b90b090
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
Driver/PrintParserCallbacks.cpp
Parse/MinimalAction.cpp
Parse/ParseDecl.cpp
Parse/Parser.cpp
Sema/Sema.h
Sema/SemaDecl.cpp
include/clang/Parse/Action.h