aboutsummaryrefslogtreecommitdiff
path: root/gcc/java/expr.c
diff options
context:
space:
mode:
authorPer Bothner <bothner@gcc.gnu.org>1998-11-14 09:22:22 -0800
committerPer Bothner <bothner@gcc.gnu.org>1998-11-14 09:22:22 -0800
commit46cf461c83489859531d548d57e1751f8c5cb68c (patch)
treec372fadfdc48e2a6b988a0d96a60b47f714f4b8d /gcc/java/expr.c
parentbd8dc16507f210e0d01954e65e5d93061c560d5b (diff)
downloadgcc-46cf461c83489859531d548d57e1751f8c5cb68c.zip
gcc-46cf461c83489859531d548d57e1751f8c5cb68c.tar.gz
gcc-46cf461c83489859531d548d57e1751f8c5cb68c.tar.bz2
Allow uses of interface types to verify.
� Allow uses of interface types to verify. This is not really type-safe, but it matches what Sun does, and is OK as long as there are appropriate run-time checks. * verify.c (merge_types): If merging two interface types, just set the result to java.lang.Object. * expr.c (pop_type): Any interface is matches by java.lang.Object. From-SVN: r23656
Diffstat (limited to 'gcc/java/expr.c')
-rw-r--r--gcc/java/expr.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/gcc/java/expr.c b/gcc/java/expr.c
index 0df6106..9bd1ca7 100644
--- a/gcc/java/expr.c
+++ b/gcc/java/expr.c
@@ -268,6 +268,12 @@ pop_type (type)
return type;
else if (can_widen_reference_to (t, type))
return t;
+ /* This is a kludge, but matches what Sun's verifier does.
+ It can be tricked, but is safe as long as type errors
+ (i.e. interface method calls) are caught at run-time. */
+ else if (CLASS_INTERFACE (TYPE_NAME (TREE_TYPE (type)))
+ && t == object_ptr_type_node)
+ return t;
}
error ("unexpected type on stack");
return t;