From: Anders Carlsson Date: Thu, 6 Dec 2007 20:10:20 +0000 (+0000) Subject: Add workaround to get test/Parser/compound_literal.c working again. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=b2f08e06f02d8e7de60f6614472bc7a414c3a405;p=clang Add workaround to get test/Parser/compound_literal.c working again. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@44666 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/Sema/SemaExpr.cpp b/Sema/SemaExpr.cpp index ed71934621..379a033d41 100644 --- a/Sema/SemaExpr.cpp +++ b/Sema/SemaExpr.cpp @@ -689,9 +689,15 @@ ActOnCompoundLiteral(SourceLocation LParenLoc, TypeTy *Ty, //assert((InitExpr != 0) && "ActOnCompoundLiteral(): missing expression"); Expr *literalExpr = static_cast(InitExpr); - // FIXME: add more semantic analysis (C99 6.5.2.5). - if (CheckInitializer(literalExpr, literalType, false)) - return 0; + // FIXME: This is just a temporary workaround to get + // test/Parser/compound_literal.c passing. (CheckInitializer does not support + // initializing a char array from a single string literal). + if (!literalType->isArrayType() || + !literalType->getAsArrayType()->getElementType()->isCharType()) { + // FIXME: add more semantic analysis (C99 6.5.2.5). + if (CheckInitializer(literalExpr, literalType, false)) + return 0; + } return new CompoundLiteralExpr(literalType, literalExpr); }