aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJoseph Myers <joseph@codesourcery.com>2005-11-03 03:30:36 +0000
committerJoseph Myers <jsm28@gcc.gnu.org>2005-11-03 03:30:36 +0000
commita92c58c27304547c9c75e4cbb0a2ad92f55c17e0 (patch)
tree0bb7ecb15bb976867a17f2fbee102eb3956a45b4
parent150cdc9e16e86173fe7116e12dbcc4cc8fb6b789 (diff)
downloadgcc-a92c58c27304547c9c75e4cbb0a2ad92f55c17e0.zip
gcc-a92c58c27304547c9c75e4cbb0a2ad92f55c17e0.tar.gz
gcc-a92c58c27304547c9c75e4cbb0a2ad92f55c17e0.tar.bz2
re PR c/24329 (segfault with -Wall and long integer literal)
PR c/24329 * c-pretty-print.c (pp_c_type_specifier): Do not recurse if c_common_type_for_mode returns an unnamed type. testsuite: * gcc.dg/format/unnamed-1.c: New test. From-SVN: r106421
-rw-r--r--gcc/ChangeLog6
-rw-r--r--gcc/c-pretty-print.c27
-rw-r--r--gcc/testsuite/ChangeLog5
-rw-r--r--gcc/testsuite/gcc.dg/format/unnamed-1.c22
4 files changed, 57 insertions, 3 deletions
diff --git a/gcc/ChangeLog b/gcc/ChangeLog
index a2e518a..8de34f2 100644
--- a/gcc/ChangeLog
+++ b/gcc/ChangeLog
@@ -1,3 +1,9 @@
+2005-11-03 Joseph S. Myers <joseph@codesourcery.com>
+
+ PR c/24329
+ * c-pretty-print.c (pp_c_type_specifier): Do not recurse if
+ c_common_type_for_mode returns an unnamed type.
+
2005-11-02 Richard Henderson <rth@redhat.com>
PR target/9350
diff --git a/gcc/c-pretty-print.c b/gcc/c-pretty-print.c
index bbc19be..5e67a96 100644
--- a/gcc/c-pretty-print.c
+++ b/gcc/c-pretty-print.c
@@ -323,11 +323,32 @@ pp_c_type_specifier (c_pretty_printer *pp, tree t)
{
int prec = TYPE_PRECISION (t);
t = c_common_type_for_mode (TYPE_MODE (t), TYPE_UNSIGNED (t));
- pp_c_type_specifier (pp, t);
- if (TYPE_PRECISION (t) != prec)
+ if (TYPE_NAME (t))
+ {
+ pp_c_type_specifier (pp, t);
+ if (TYPE_PRECISION (t) != prec)
+ {
+ pp_string (pp, ":");
+ pp_decimal_int (pp, prec);
+ }
+ }
+ else
{
- pp_string (pp, ":");
+ switch (code)
+ {
+ case INTEGER_TYPE:
+ pp_string (pp, (TYPE_UNSIGNED (t)
+ ? "<unnamed-unsigned:"
+ : "<unnamed-signed:"));
+ break;
+ case REAL_TYPE:
+ pp_string (pp, "<unnamed-float:");
+ break;
+ default:
+ gcc_unreachable ();
+ }
pp_decimal_int (pp, prec);
+ pp_string (pp, ">");
}
}
break;
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index b52603b..3934527 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,8 @@
+2005-11-03 Joseph S. Myers <joseph@codesourcery.com>
+
+ PR c/24329
+ * gcc.dg/format/unnamed-1.c: New test.
+
2005-11-02 Mark Mitchell <mark@codesourcery.com>
PR c++/22434
diff --git a/gcc/testsuite/gcc.dg/format/unnamed-1.c b/gcc/testsuite/gcc.dg/format/unnamed-1.c
new file mode 100644
index 0000000..5fc11a1
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/format/unnamed-1.c
@@ -0,0 +1,22 @@
+/* Test for warnings with possibly unnamed integer types. Bug 24329. */
+/* Origin: Joseph Myers <joseph@codesourcery.com> */
+/* { dg-do compile } */
+/* { dg-options "-Wformat" } */
+
+#include "format.h"
+
+/* Definition of TItype follows same logic as in gcc.dg/titype-1.c,
+ but must be a #define to avoid giving the type a name. */
+#if defined(__LP64__) && !defined(__hppa__)
+#define TItype int __attribute__ ((mode (TI)))
+#else
+#define TItype long
+#endif
+
+void
+f (TItype x)
+{
+ printf("%d", x); /* { dg-warning "expects type" } */
+ printf("%d", 141592653589793238462643383279502884197169399375105820974944); /* { dg-warning "expects type" } */
+ /* { dg-warning "unsigned only|too large" "constant" { target *-*-* } 20 } */
+}