Correct r124242 making sure function chunk that gets diagnosed is really about the block.

Clairvoyance by John!

llvm-svn: 124264
This commit is contained in:
Argyrios Kyrtzidis 2011-01-26 01:26:44 +00:00
parent 8781b7dded
commit 7e71884ecb
2 changed files with 5 additions and 1 deletions

View File

@ -1622,7 +1622,10 @@ TypeSourceInfo *Sema::GetTypeForDeclarator(Declarator &D, Scope *S,
if ((T->isArrayType() || T->isFunctionType()) &&
(D.getName().getKind() != UnqualifiedId::IK_ConversionFunctionId)) {
unsigned diagID = diag::err_func_returning_array_function;
if (D.getContext() == Declarator::BlockLiteralContext)
// Last processing chunk in block context means this function chunk
// represents the block.
if (chunkIndex == 0 &&
D.getContext() == Declarator::BlockLiteralContext)
diagID = diag::err_block_returning_array_function;
Diag(DeclType.Loc, diagID) << T->isFunctionType() << T;
T = Context.IntTy;

View File

@ -98,6 +98,7 @@ bptr foo5(int j) {
int (*funcptr3[5])(long);
int sz8 = sizeof(^int (*[5])(long) {return funcptr3;}); // expected-error {{block cannot return array type}} expected-warning {{incompatible pointer to integer conversion}}
int sz9 = sizeof(^int(*())()[3]{ }); // expected-error {{function cannot return array type}}
void foo6() {
int (^b)(int) __attribute__((noreturn));