forked from OSchip/llvm-project
Tighten up the "cannot return array or function type" diagnostic to
say either "array type" or "function type", whichever it is. No reason to make the user guess. llvm-svn: 93164
This commit is contained in:
parent
0ef736fef2
commit
bb91767b82
|
@ -1484,7 +1484,7 @@ def note_protected_by___block : Note<
|
|||
"jump bypasses setup of __block variable">;
|
||||
|
||||
def err_func_returning_array_function : Error<
|
||||
"function cannot return array or function type %0">;
|
||||
"function cannot return %select{array|function}0 type %1">;
|
||||
def err_field_declared_as_function : Error<"field %0 declared as a function">;
|
||||
def err_field_incomplete : Error<"field has incomplete type %0">;
|
||||
def ext_variable_sized_type_in_struct : ExtWarn<
|
||||
|
|
|
@ -743,7 +743,8 @@ QualType Sema::BuildFunctionType(QualType T,
|
|||
bool Variadic, unsigned Quals,
|
||||
SourceLocation Loc, DeclarationName Entity) {
|
||||
if (T->isArrayType() || T->isFunctionType()) {
|
||||
Diag(Loc, diag::err_func_returning_array_function) << T;
|
||||
Diag(Loc, diag::err_func_returning_array_function)
|
||||
<< T->isFunctionType() << T;
|
||||
return QualType();
|
||||
}
|
||||
|
||||
|
@ -1045,9 +1046,11 @@ QualType Sema::GetTypeForDeclarator(Declarator &D, Scope *S,
|
|||
const DeclaratorChunk::FunctionTypeInfo &FTI = DeclType.Fun;
|
||||
|
||||
// C99 6.7.5.3p1: The return type may not be a function or array type.
|
||||
// For conversion functions, we'll diagnose this particular error later.
|
||||
if ((T->isArrayType() || T->isFunctionType()) &&
|
||||
(D.getName().getKind() != UnqualifiedId::IK_ConversionFunctionId)) {
|
||||
Diag(DeclType.Loc, diag::err_func_returning_array_function) << T;
|
||||
Diag(DeclType.Loc, diag::err_func_returning_array_function)
|
||||
<< T->isFunctionType() << T;
|
||||
T = Context.IntTy;
|
||||
D.setInvalidType(true);
|
||||
}
|
||||
|
|
|
@ -1,7 +1,7 @@
|
|||
// RUN: %clang_cc1 %s -verify -fsyntax-only
|
||||
typedef char T[4];
|
||||
|
||||
T foo(int n, int m) { } // expected-error {{cannot return array or function}}
|
||||
T foo(int n, int m) { } // expected-error {{cannot return array type}}
|
||||
|
||||
void foof(const char *, ...) __attribute__((__format__(__printf__, 1, 2))), barf (void);
|
||||
|
||||
|
|
|
@ -6,7 +6,7 @@ void test() {
|
|||
|
||||
|
||||
// PR2400
|
||||
typedef xtype (*x)(void* handle); // expected-error {{function cannot return array or function type}} expected-warning {{type specifier missing, defaults to 'int'}} expected-warning {{type specifier missing, defaults to 'int'}}
|
||||
typedef xtype (*x)(void* handle); // expected-error {{function cannot return function type}} expected-warning {{type specifier missing, defaults to 'int'}} expected-warning {{type specifier missing, defaults to 'int'}}
|
||||
|
||||
typedef void ytype();
|
||||
|
||||
|
|
Loading…
Reference in New Issue