diff options
-rw-r--r-- | gcc/cp/ChangeLog | 6 | ||||
-rw-r--r-- | gcc/cp/decl.c | 2 | ||||
-rw-r--r-- | gcc/testsuite/ChangeLog | 5 | ||||
-rw-r--r-- | gcc/testsuite/g++.dg/parse/long1.C | 4 |
4 files changed, 17 insertions, 0 deletions
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 <reichelt@igpm.rwth-aachen.de> + + PR c++/6634 + * decl.c (grokdeclarator): Check whether "long" or "short" was + specified for non-integral types. + 2006-07-28 Volker Reichelt <reichelt@igpm.rwth-aachen.de> * 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 ("%<long%> invalid for %qs", name); else if (short_p && TREE_CODE (type) == REAL_TYPE) error ("%<short%> invalid for %qs", name); + else if ((long_p || short_p) && TREE_CODE (type) != INTEGER_TYPE) + error ("%<long%> or %<short%> invalid for %qs", name); else if ((long_p || short_p) && explicit_char) error ("%<long%> or %<short%> 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 <reichelt@igpm.rwth-aachen.de> + + PR c++/6634 + * g++.dg/parse/long1.C: Add more tests. + 2006-07-30 Francois-Xavier Coudert <coudert@clipper.ens.fr> * 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" } |