From 2f29e5e8678c5a39d6affeb527024eedb27f731e Mon Sep 17 00:00:00 2001 From: Tom Tromey Date: Thu, 13 Mar 2003 18:35:01 +0000 Subject: [PATCH] parse.y (resolve_inner_class): Error if qualifier is a primitive type. * parse.y (resolve_inner_class): Error if qualifier is a primitive type. From-SVN: r64314 --- gcc/java/ChangeLog | 5 +++++ gcc/java/parse.y | 11 +++++++++-- 2 files changed, 14 insertions(+), 2 deletions(-) diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog index 13fa86ab2ad..46f29507fe2 100644 --- a/gcc/java/ChangeLog +++ b/gcc/java/ChangeLog @@ -1,3 +1,8 @@ +2003-03-13 Tom Tromey + + * parse.y (resolve_inner_class): Error if qualifier is a primitive + type. + 2003-03-04 Andrew Haley * gjavah.c (is_first_data_member): New global variable. diff --git a/gcc/java/parse.y b/gcc/java/parse.y index 82293edfc72..b8abc0e67b1 100644 --- a/gcc/java/parse.y +++ b/gcc/java/parse.y @@ -3527,9 +3527,16 @@ resolve_inner_class (htab_t circularity_hash, tree cl, tree *enclosing, return decl; } - /* Now go to the upper classes, bail out if necessary. We will + /* Now go to the upper classes, bail out if necessary. We will analyze the returned SUPER and act accordingly (see - do_resolve_class.) */ + do_resolve_class). */ + if (JPRIMITIVE_TYPE_P (TREE_TYPE (local_enclosing)) + || TREE_TYPE (local_enclosing) == void_type_node) + { + parse_error_context (cl, "Qualifier must be a reference"); + local_enclosing = NULL_TREE; + break; + } local_super = CLASSTYPE_SUPER (TREE_TYPE (local_enclosing)); if (!local_super || local_super == object_type_node) break; -- 2.30.2