diff options
author | Chris Lattner <sabre@nondot.org> | 2008-01-31 06:10:07 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2008-01-31 06:10:07 +0000 |
commit | 7f024fe0c605c3a9177a7166db23cd1061d189c8 (patch) | |
tree | 492f50ef13c4b73d5c7b74ff25e6f1c221ab0165 | |
parent | 4973fb9273332128edd94717c250deb541b0fa0e (diff) | |
download | bcm5719-llvm-7f024fe0c605c3a9177a7166db23cd1061d189c8.tar.gz bcm5719-llvm-7f024fe0c605c3a9177a7166db23cd1061d189c8.zip |
Fix PR1965: missing diagnostics for parameters that are missing
type specifiers. This required updating some (buggy) tests, and the
testcase was previously accidentally committed.
llvm-svn: 46603
-rw-r--r-- | clang/Parse/ParseDecl.cpp | 14 | ||||
-rw-r--r-- | clang/include/clang/Basic/DiagnosticKinds.def | 5 | ||||
-rw-r--r-- | clang/test/Parser/declarators.c | 2 |
3 files changed, 20 insertions, 1 deletions
diff --git a/clang/Parse/ParseDecl.cpp b/clang/Parse/ParseDecl.cpp index 003554fbaa9..91e77b95e09 100644 --- a/clang/Parse/ParseDecl.cpp +++ b/clang/Parse/ParseDecl.cpp @@ -1350,6 +1350,20 @@ void Parser::ParseParenDeclarator(Declarator &D) { ParmII->getName()); ParmII = 0; } + + // If no parameter was specified, verify that *something* was specified, + // otherwise we have a missing type and identifier. + if (!DS.hasTypeSpecifier()) { + if (ParmII) + Diag(ParmDecl.getIdentifierLoc(), + diag::err_param_requires_type_specifier, ParmII->getName()); + else + Diag(Tok.getLocation(), diag::err_anon_param_requires_type_specifier); + + // Default the parameter to 'int'. + const char *PrevSpec = 0; + DS.SetTypeSpecType(DeclSpec::TST_int, Tok.getLocation(), PrevSpec); + } ParamInfo.push_back(DeclaratorChunk::ParamInfo(ParmII, ParmDecl.getIdentifierLoc(), ParamTy.Val, ParmDecl.getInvalidType(), diff --git a/clang/include/clang/Basic/DiagnosticKinds.def b/clang/include/clang/Basic/DiagnosticKinds.def index 78f6c61c512..02d3159c6ad 100644 --- a/clang/include/clang/Basic/DiagnosticKinds.def +++ b/clang/include/clang/Basic/DiagnosticKinds.def @@ -542,6 +542,11 @@ DIAG(ext_vla, EXTENSION, "variable length arrays are a C99 feature, accepted as an extension") DIAG(err_invalid_storage_class_in_func_decl, ERROR, "invalid storage class specifier in function declarator") +DIAG(err_anon_param_requires_type_specifier, ERROR, + "type specifier required for unnamed parameter") +DIAG(err_param_requires_type_specifier, ERROR, + "type specifier required for parameter '%0'") + DIAG(err_invalid_reference_qualifier_application, ERROR, "'%0' qualifier may not be applied to a reference") DIAG(err_declarator_need_ident, ERROR, diff --git a/clang/test/Parser/declarators.c b/clang/test/Parser/declarators.c index 91cd81653bf..e00035c8e0f 100644 --- a/clang/test/Parser/declarators.c +++ b/clang/test/Parser/declarators.c @@ -6,7 +6,7 @@ void f0(); void f1(int [*]); void f2(int [const *]); void f3(int [volatile const*]); -int f4(*XX)(void); /* expected-error {{cannot return}} */ +int f4(*XX)(void); /* expected-error {{cannot return}} expected-error {{type specifier required}} */ char ((((*X)))); |