From 7c5ab81c6bfa87fe32f5f61fc1931ba1f113299b Mon Sep 17 00:00:00 2001 From: bryce Date: Tue, 30 Oct 2001 04:43:16 +0000 Subject: * mangle.c (find_compression_record_match): Don't match compression records for package name elements unless they occur at the start of the name. Fix for PR java/4717. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@46628 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/java/ChangeLog | 6 ++++++ gcc/java/mangle.c | 12 ++++++++++++ 2 files changed, 18 insertions(+) (limited to 'gcc/java') diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog index 7b6b4efa5f2..5049cfd5833 100644 --- a/gcc/java/ChangeLog +++ b/gcc/java/ChangeLog @@ -1,3 +1,9 @@ +2001-10-29 Bryce McKinlay + + * mangle.c (find_compression_record_match): Don't match compression + records for package name elements unless they occur at the start of + the name. Fix for PR java/4717. + 2001-10-25 Bryce McKinlay * expr.c (expand_java_field_op): Don't special-case references to diff --git a/gcc/java/mangle.c b/gcc/java/mangle.c index f0bda0eaa77..aa95086fc2a 100644 --- a/gcc/java/mangle.c +++ b/gcc/java/mangle.c @@ -327,8 +327,20 @@ find_compression_record_match (type, next_current) { match = i = j; saved_current = current; + i++; break; } + else + { + /* We don't want to match an element that appears in the middle + of a package name, so skip forward to the next complete type name. + IDENTIFIER_NODEs are partial package names while RECORD_TYPEs + represent complete type names. */ + while (j < compression_next + && TREE_CODE (TREE_VEC_ELT (compression_table, j)) == + IDENTIFIER_NODE) + j++; + } } if (!next_current) -- cgit v1.2.1