From 98decfafb9cae3ff96ec1c72532fcf79613554d5 Mon Sep 17 00:00:00 2001 From: Jakub Jelinek Date: Mon, 23 Jun 2003 16:52:00 +0200 Subject: [PATCH] mangle.c (hash_type): val is the TREE_LIST itself, not a pointer to it. * mangle.c (hash_type): val is the TREE_LIST itself, not a pointer to it. * g++.dg/opt/operator1.C: New test. From-SVN: r68364 --- gcc/cp/ChangeLog | 5 +++++ gcc/cp/mangle.c | 2 +- gcc/testsuite/ChangeLog | 4 ++++ gcc/testsuite/g++.dg/opt/operator1.C | 10 ++++++++++ 4 files changed, 20 insertions(+), 1 deletion(-) create mode 100644 gcc/testsuite/g++.dg/opt/operator1.C diff --git a/gcc/cp/ChangeLog b/gcc/cp/ChangeLog index 7809040519e2..77d85a68d75c 100644 --- a/gcc/cp/ChangeLog +++ b/gcc/cp/ChangeLog @@ -1,3 +1,8 @@ +2003-06-23 Jakub Jelinek + + * mangle.c (hash_type): val is the TREE_LIST itself, not a pointer + to it. + 2003-06-21 Gabriel Dos Reis PR c++/10784 diff --git a/gcc/cp/mangle.c b/gcc/cp/mangle.c index 2040ae996d6a..e4c75b473c6b 100644 --- a/gcc/cp/mangle.c +++ b/gcc/cp/mangle.c @@ -2597,7 +2597,7 @@ static GTY ((param_is (union tree_node))) htab_t conv_type_names; static hashval_t hash_type (const void *val) { - return htab_hash_pointer (TREE_PURPOSE (*((tree *) val))); + return htab_hash_pointer (TREE_PURPOSE ((tree) val)); } /* Compare VAL1 (a node in the table) with VAL2 (a TYPE). */ diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 099c83060e2b..985998ac5ff6 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,7 @@ +2003-06-23 Jakub Jelinek + + * g++.dg/opt/operator1.C: New test. + 2003-06-22 Roger Sayle * gcc.c-torture/execute/string-opt-16.c: New test case. diff --git a/gcc/testsuite/g++.dg/opt/operator1.C b/gcc/testsuite/g++.dg/opt/operator1.C new file mode 100644 index 000000000000..9f286b9f98c6 --- /dev/null +++ b/gcc/testsuite/g++.dg/opt/operator1.C @@ -0,0 +1,10 @@ +// Tests whether g++ can handle large number of operators +// { dg-do compile } + +#define OP0(n) struct I##n { int i; }; operator I##n (); +#define OP1(n) OP0(n) +#define OP2(n) OP1(n##0) OP1(n##1) OP1(n##2) OP1(n##3) OP1(n##4) +#define OP3(n) OP2(n##0) OP2(n##1) OP2(n##2) OP2(n##3) OP2(n##4) +struct S { + OP3(0) OP3(1) OP3(2) OP3(3) OP3(4) OP3(5) +}; -- 2.47.3