24 lines
687 B
Plaintext
24 lines
687 B
Plaintext
|
|
%reduce:
|
|
unify(Pointer, Param1, Param2)
|
|
:- unify(Pointer, T1, T2), type(T1, TName, Num), type(T2, TName, Num)
|
|
, param(T1, Param1, PNum), param(T2, Param2, PNum)
|
|
.
|
|
|
|
%Ich lasse das Subst hier aus. Vector Beispiel funktioniert womöglich auch ohne
|
|
|
|
%swap:
|
|
unify(Pointer, B, A) :- unify(Pointer, A, B).
|
|
|
|
%Subst neu implementieren.
|
|
%Subst muss von hinten nach vorne durchgehen.
|
|
%Mit occurs kann man prüfen, welche unify(P, A, B) ausgetauscht werden müssen
|
|
|
|
%Diese Fälle dürfen nicht auftreten:
|
|
%TODO (möglicherweise braucht man sie nicht; Die Unifikation geht hier nie schief)
|
|
|
|
%Occurs Regeln:
|
|
occurs(A, A) :- typeVar(A).
|
|
occurs(A, T) :- type(T, _,_), param(T, B, _), occurs(A, B).
|
|
|