commonMain.it.unibo.tuprolog.solve.stdlib.primitive.AtomConcat.kt Maven / Gradle / Ivy
package it.unibo.tuprolog.solve.stdlib.primitive
import it.unibo.tuprolog.core.Atom
import it.unibo.tuprolog.core.Substitution
import it.unibo.tuprolog.core.Term
import it.unibo.tuprolog.core.Var
import it.unibo.tuprolog.solve.ExecutionContext
import it.unibo.tuprolog.solve.primitive.Solve
import it.unibo.tuprolog.solve.primitive.TernaryRelation
/**
* atom_concat(ab, cd, abcd).
*/
object AtomConcat : TernaryRelation.Functional("atom_concat") {
override fun Solve.Request.computeOneSubstitution(
first: Term,
second: Term,
third: Term,
): Substitution {
return when {
third is Var -> {
ensuringArgumentIsInstantiated(0)
ensuringArgumentIsAtom(0)
ensuringArgumentIsInstantiated(1)
ensuringArgumentIsAtom(1)
val result = (first as Atom).value + (second as Atom).value
Substitution.of(third, Atom.of(result))
}
first is Var -> {
ensuringArgumentIsInstantiated(1)
ensuringArgumentIsAtom(1)
ensuringArgumentIsInstantiated(2)
ensuringArgumentIsAtom(2)
val result = (third as Atom).value.substringBefore((second as Atom).value)
Substitution.of(first, Atom.of(result))
}
second is Var -> {
ensuringArgumentIsInstantiated(0)
ensuringArgumentIsAtom(0)
ensuringArgumentIsInstantiated(2)
ensuringArgumentIsAtom(2)
val result = (third as Atom).value.substringAfter((first as Atom).value)
Substitution.of(second, Atom.of(result))
}
else -> {
ensuringArgumentIsAtom(0)
ensuringArgumentIsAtom(1)
ensuringArgumentIsAtom(2)
val firstString = (first as Atom).value
val secondString = (second as Atom).value
val thirdString = firstString + secondString
mgu(third, Atom.of(thirdString))
}
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy