forked from JavaTX/JavaCompilerCore
refactoring
This commit is contained in:
parent
27f6abefe8
commit
d8e7df425d
@ -66,16 +66,17 @@ public class MartelliMontanariUnify implements IUnify {
|
|||||||
// f<t1,...,tn> = f<s1,...,sm> are not unifiable
|
// f<t1,...,tn> = f<s1,...,sm> are not unifiable
|
||||||
if(rhsTypeParams.size() != lhsTypeParams.size())
|
if(rhsTypeParams.size() != lhsTypeParams.size())
|
||||||
return Optional.empty(); // conflict
|
return Optional.empty(); // conflict
|
||||||
|
// f = g is not unifiable (cannot be f = f because erase rule would have been applied)
|
||||||
|
//if(rhsTypeParams.size() == 0)
|
||||||
|
//return Optional.empty();
|
||||||
|
|
||||||
if(rhsTypeParams.size() != 0) {
|
// Unpack the arguments
|
||||||
// Unpack the arguments
|
for(int i = 0; i < rhsTypeParams.size(); i++)
|
||||||
for(int i = 0; i < rhsTypeParams.size(); i++)
|
result.add(new UnifyPair(rhsTypeParams.get(i), lhsTypeParams.get(i), PairOperator.EQUALSDOT));
|
||||||
result.add(new UnifyPair(rhsTypeParams.get(i), lhsTypeParams.get(i), PairOperator.EQUALSDOT));
|
|
||||||
|
|
||||||
termsList.remove(idx);
|
termsList.remove(idx);
|
||||||
termsList.addAll(result);
|
termsList.addAll(result);
|
||||||
continue;
|
continue;
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// SWAP - Rule
|
// SWAP - Rule
|
||||||
|
Loading…
Reference in New Issue
Block a user