aboutsummaryrefslogtreecommitdiff
path: root/gcc/java
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/java')
-rw-r--r--gcc/java/ChangeLog4
-rw-r--r--gcc/java/verify.c14
2 files changed, 18 insertions, 0 deletions
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 <apbianco@cygnus.com>
+
+ * verify.c (merge_types): Load the types to merge if necessary.
+
2000-09-02 Anthony Green <green@redhat.com>
* 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))