From ddfb919a5c45165f5da5ea9f6271375042d258f5 Mon Sep 17 00:00:00 2001 From: bothner Date: Sun, 21 Jan 2001 19:08:10 +0000 Subject: * expr.c (pop_type_0): Only return object_ptr_type_node on mismatch if expeting an interface type. Refines Tom's change of 2000-09-12. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@39168 138bc75d-0d04-0410-961f-82ee72b054a4 --- gcc/java/expr.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'gcc/java/expr.c') diff --git a/gcc/java/expr.c b/gcc/java/expr.c index 8b5eab752a0..8dadacb35a4 100644 --- a/gcc/java/expr.c +++ b/gcc/java/expr.c @@ -352,8 +352,8 @@ pop_type_0 (type, messagep) /* 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. */ - /* FIXME: this is worse than a kludge, probably. */ - return object_ptr_type_node; + else if (CLASS_INTERFACE (TYPE_NAME (TREE_TYPE (type)))) + return object_ptr_type_node; } { const char *str1 = "expected type '"; -- cgit v1.2.3