From 5d48268fad613bdf6cebcb3930f3d2d275e4b3fd Mon Sep 17 00:00:00 2001 From: Volker Reichelt Date: Mon, 31 Jul 2006 22:52:20 +0000 Subject: re PR c++/6634 (wrong parsing of "long long double") PR c++/6634 * decl.c (grokdeclarator): Check whether "long" or "short" was specified for non-integral types. * g++.dg/parse/long1.C: Add more tests. From-SVN: r115843 --- gcc/cp/ChangeLog | 6 ++++++ gcc/cp/decl.c | 2 ++ gcc/testsuite/ChangeLog | 5 +++++ gcc/testsuite/g++.dg/parse/long1.C | 4 ++++ 4 files changed, 17 insertions(+) diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 1a8b91f..4e85be1 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,9 @@ +2006-07-31 Volker Reichelt + + PR c++/6634 + * decl.c (grokdeclarator): Check whether "long" or "short" was + specified for non-integral types. + 2006-07-28 Volker Reichelt * Make-lang.in: Use $(HEADER_H) instead of header.h in dependencies. diff --git a/gcc/cp/decl.c b/gcc/cp/decl.c index 20ad2e9..e9cf4b8 100644 --- a/gcc/cp/decl.c +++ b/gcc/cp/decl.c @@ -7198,6 +7198,8 @@ grokdeclarator (const cp_declarator *declarator, error ("% invalid for %qs", name); else if (short_p && TREE_CODE (type) == REAL_TYPE) error ("% invalid for %qs", name); + else if ((long_p || short_p) && TREE_CODE (type) != INTEGER_TYPE) + error ("% or % invalid for %qs", name); else if ((long_p || short_p) && explicit_char) error ("% or % specified with char for %qs", name); else if (long_p && short_p) diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index bfc82a7..9887b2c 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2006-07-31 Volker Reichelt + + PR c++/6634 + * g++.dg/parse/long1.C: Add more tests. + 2006-07-30 Francois-Xavier Coudert * gfortran.dg/lrshift_1.c: New file. diff --git a/gcc/testsuite/g++.dg/parse/long1.C b/gcc/testsuite/g++.dg/parse/long1.C index 628c86c..c22d791 100644 --- a/gcc/testsuite/g++.dg/parse/long1.C +++ b/gcc/testsuite/g++.dg/parse/long1.C @@ -5,3 +5,7 @@ long long double x; // { dg-error "long long" } long double y; long float z; // { dg-error "long" } + +typedef short void SV; // { dg-error "short" } +typedef long struct A LA; // { dg-error "long" } +typedef short char SC; // { dg-error "short" } -- cgit v1.1