]> granicus.if.org Git - clang/commit
Throw the switch to exclusively use Evaluate (along with the small
authorEli Friedman <eli.friedman@gmail.com>
Sun, 22 Feb 2009 06:45:27 +0000 (06:45 +0000)
committerEli Friedman <eli.friedman@gmail.com>
Sun, 22 Feb 2009 06:45:27 +0000 (06:45 +0000)
commit578a97249c10eb83f25b408de1edfb70f5a4233c
treeacb8a7a848aa0a7c2ca6e17a929e7e3ec2668b83
parente28099bf301ad8b0b77cb11f94caad3c38d97dda
Throw the switch to exclusively use Evaluate (along with the small
helper isConstantInitializer) to check whether an initializer is
constant.  This passes tests, but it's possible that it'll cause
regressions with real-world code.

Future work:
1. The diagnostics obtained this way are lower quality at the moment;
some work both here and in Evaluate is needed for accurate diagnostics.
2. We probably need some extra code when we're in -pedantic mode so we
can strictly enforce the rules in C99 6.6p7.
3. Dead code cleanup (this should wait until after 2, because we might
want to re-use some of the code).

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@65265 91177308-0d34-0410-b5e6-96231b3b80d8
lib/Sema/SemaDecl.cpp
test/Sema/const-ptr-int-ptr-cast.c
test/Sema/static-init.c