diff options
Diffstat (limited to 'gcc/java/parse.c')
-rw-r--r-- | gcc/java/parse.c | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/gcc/java/parse.c b/gcc/java/parse.c index 59a1b5a..0434edf 100644 --- a/gcc/java/parse.c +++ b/gcc/java/parse.c @@ -10632,6 +10632,9 @@ qualify_ambiguous_name (id) && TREE_CODE (TREE_TYPE (qual_wfl)) == EXPR_WITH_FILE_LOCATION) name = EXPR_WFL_NODE (TREE_TYPE (qual_wfl)); + else if (code == INTEGER_CST) + name = qual_wfl; + else if ((code == ARRAY_REF || code == CALL_EXPR || code == MODIFY_EXPR) && TREE_CODE (TREE_OPERAND (qual_wfl, 0)) == EXPR_WITH_FILE_LOCATION) name = EXPR_WFL_NODE (TREE_OPERAND (qual_wfl, 0)); @@ -10686,8 +10689,9 @@ qualify_ambiguous_name (id) declaration or parameter declaration, then it is an expression name. We don't carry this test out if we're in the context of the use of SUPER or THIS */ - if (!this_found && !super_found && - TREE_CODE (name) != STRING_CST && (decl = IDENTIFIER_LOCAL_VALUE (name))) + if (!this_found && !super_found + && TREE_CODE (name) != STRING_CST && TREE_CODE (name) != INTEGER_CST + && (decl = IDENTIFIER_LOCAL_VALUE (name))) { RESOLVE_EXPRESSION_NAME_P (qual_wfl) = 1; QUAL_RESOLUTION (qual) = decl; @@ -10713,8 +10717,8 @@ qualify_ambiguous_name (id) - NAME is declared by exactly on type-import-on-demand declaration of the compilation unit containing NAME. - NAME is actually a STRING_CST. */ - else if (TREE_CODE (name) == STRING_CST || - (decl = resolve_and_layout (name, NULL_TREE))) + else if (TREE_CODE (name) == STRING_CST || TREE_CODE (name) == INTEGER_CST + || (decl = resolve_and_layout (name, NULL_TREE))) { RESOLVE_TYPE_NAME_P (qual_wfl) = 1; QUAL_RESOLUTION (qual) = decl; |