diff options
| author | Eli Friedman <eli.friedman@gmail.com> | 2008-05-20 05:22:08 +0000 |
|---|---|---|
| committer | Eli Friedman <eli.friedman@gmail.com> | 2008-05-20 05:22:08 +0000 |
| commit | 37a186d76568fa1b5a6fc6a79f653f2067cc9ca9 (patch) | |
| tree | 9201c59107a3f2a488d0a20660528ec186c37adb /clang/lib/Sema/SemaExpr.cpp | |
| parent | 78aa98f7b80647a196a18691ca18d36072fd827e (diff) | |
| download | bcm5719-llvm-37a186d76568fa1b5a6fc6a79f653f2067cc9ca9.tar.gz bcm5719-llvm-37a186d76568fa1b5a6fc6a79f653f2067cc9ca9.zip | |
Add some more checking for compound literals.
llvm-svn: 51300
Diffstat (limited to 'clang/lib/Sema/SemaExpr.cpp')
| -rw-r--r-- | clang/lib/Sema/SemaExpr.cpp | 15 |
1 files changed, 14 insertions, 1 deletions
diff --git a/clang/lib/Sema/SemaExpr.cpp b/clang/lib/Sema/SemaExpr.cpp index e5ac14e092c..e85ad03694a 100644 --- a/clang/lib/Sema/SemaExpr.cpp +++ b/clang/lib/Sema/SemaExpr.cpp @@ -738,7 +738,20 @@ ActOnCompoundLiteral(SourceLocation LParenLoc, TypeTy *Ty, //assert((InitExpr != 0) && "ActOnCompoundLiteral(): missing expression"); Expr *literalExpr = static_cast<Expr*>(InitExpr); - // FIXME: add more semantic analysis (C99 6.5.2.5). + if (literalType->isArrayType()) { + if (literalType->getAsVariableArrayType()) + return Diag(LParenLoc, + diag::err_variable_object_no_init, + SourceRange(LParenLoc, + literalExpr->getSourceRange().getEnd())); + } else if (literalType->isIncompleteType()) { + return Diag(LParenLoc, + diag::err_typecheck_decl_incomplete_type, + literalType.getAsString(), + SourceRange(LParenLoc, + literalExpr->getSourceRange().getEnd())); + } + if (CheckInitializerTypes(literalExpr, literalType)) return true; |

