From 02ae6e2e4bdd2af6cd22372044124360152dfb72 Mon Sep 17 00:00:00 2001 From: Alexandre Petit-Bianco Date: Thu, 19 Oct 2000 07:51:54 +0000 Subject: [PATCH] parse.y (process_imports): Consider that one might be trying to import an innerclass. 2000-07-19 Alexandre Petit-Bianco * parse.y (process_imports): Consider that one might be trying to import an innerclass. Fixes gcj/254 (http://gcc.gnu.org/ml/gcc-patches/2000-10/msg00631.html) From-SVN: r36948 --- gcc/java/ChangeLog | 5 +++++ gcc/java/parse.y | 27 +++++++++++++++++++++++---- 2 files changed, 28 insertions(+), 4 deletions(-) diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog index ea73dc4a1c2..191b20930e8 100644 --- a/gcc/java/ChangeLog +++ b/gcc/java/ChangeLog @@ -669,6 +669,11 @@ Sun Aug 6 00:47:24 2000 Ovidiu Predescu * parse.h (SET_TYPE_FOR_RESOLUTION): Use GET_CPC. * parse.y (method_header): Likewise. +2000-07-19 Alexandre Petit-Bianco + + * parse.y (process_imports): Consider that one might be trying to + import an innerclass. Fixes gcj/254 + 2000-07-19 Alexandre Petit-Bianco * parse.y (find_as_inner_class): Handle the case where the diff --git a/gcc/java/parse.y b/gcc/java/parse.y index b3c2d87cba7..15426246734 100644 --- a/gcc/java/parse.y +++ b/gcc/java/parse.y @@ -6492,10 +6492,29 @@ process_imports () /* Don't load twice something already defined. */ if (IDENTIFIER_CLASS_VALUE (to_be_found)) continue; - QUALIFIED_P (to_be_found) = 1; - load_class (to_be_found, 0); - error_found = - check_pkg_class_access (to_be_found, TREE_PURPOSE (import)); + + while (1) + { + tree left; + + QUALIFIED_P (to_be_found) = 1; + load_class (to_be_found, 0); + error_found = + check_pkg_class_access (to_be_found, TREE_PURPOSE (import)); + + /* We found it, we can bail out */ + if (IDENTIFIER_CLASS_VALUE (to_be_found)) + break; + + /* We haven't found it. Maybe we're trying to access an + inner class. The only way for us to know is to try again + after having dropped a qualifier. If we can't break it further, + we have an error. */ + if (breakdown_qualified (&left, NULL, to_be_found)) + break; + + to_be_found = left; + } if (!IDENTIFIER_CLASS_VALUE (to_be_found)) { parse_error_context (TREE_PURPOSE (import), -- 2.30.2