From 3e99f50c2be1e2570b805f70ef54c9d0c711dea9 Mon Sep 17 00:00:00 2001 From: Alexandre Petit-Bianco Date: Thu, 7 Sep 2000 18:24:41 +0000 Subject: verify.c (merge_types): Load the types to merge if necessary. 2000-09-05 Alexandre Petit-Bianco * verify.c (merge_types): Load the types to merge if necessary. (http://gcc.gnu.org/ml/gcc-patches/2000-09/msg00245.html) From-SVN: r36243 --- gcc/java/ChangeLog | 4 ++++ gcc/java/verify.c | 14 ++++++++++++++ 2 files changed, 18 insertions(+) (limited to 'gcc/java') diff --git a/gcc/java/ChangeLog b/gcc/java/ChangeLog index 425f801..d8f85fc 100644 --- a/gcc/java/ChangeLog +++ b/gcc/java/ChangeLog @@ -2,6 +2,10 @@ * lang-specs.h: Also recognize `-femit-class-files'. +2000-09-05 Alexandre Petit-Bianco + + * verify.c (merge_types): Load the types to merge if necessary. + 2000-09-02 Anthony Green * jcf-io.c: Include zlib.h. diff --git a/gcc/java/verify.c b/gcc/java/verify.c index 4c2e4c8..fcaf7f3 100644 --- a/gcc/java/verify.c +++ b/gcc/java/verify.c @@ -131,6 +131,20 @@ merge_types (type1, type2) tt1 = HANDLE_TO_CLASS_TYPE (TREE_TYPE (type1)); tt2 = HANDLE_TO_CLASS_TYPE (TREE_TYPE (type2)); + /* If tt{1,2} haven't been properly loaded, now is a good time + to do it. */ + if (!TYPE_SIZE (tt1)) + { + load_class (tt1, 1); + safe_layout_class (tt1); + } + + if (!TYPE_SIZE (tt2)) + { + load_class (tt2, 1); + safe_layout_class (tt2); + } + if (TYPE_ARRAY_P (tt1) || TYPE_ARRAY_P (tt2)) { if (TYPE_ARRAY_P (tt1) == TYPE_ARRAY_P (tt2)) -- cgit v1.1