shithub: mc

Download patch

ref: 2d534bb4fe76d68eb1ffb7805054d9acfef0e89e
parent: 6c44abcec8462f04e09db0ab62f74e4d1f384f5a
author: Ori Bernstein <[email protected]>
date: Fri Jan 29 18:33:58 EST 2016

Comment to explain why eager unification is safe.

--- a/parse/infer.c
+++ b/parse/infer.c
@@ -955,6 +955,14 @@
 	}
 
 	r = NULL;
+	/*
+	 * unify eagerly here, solving the problem of comparing two specialized types
+	 * that don't have pointer equality.
+	 *
+	 * If the types *actually* conflict, we will error out later in this function,
+	 * and the bogus unification won't matter. If the types *are* the same, though,
+	 * then this short circuits a whole bunch of infinite recursion.
+	 */
 	tytab[a->tid] = b;
 	if (a->type == Tyvar) {
 		ea = basetype(st, a);