commonMain.it.unibo.tuprolog.solve.stdlib.rule.NegationAsFailure.kt Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of solve-classic-metadata Show documentation
Show all versions of solve-classic-metadata Show documentation
Stable, state-machine-based implementation of Prolog's SLDNF resolution principle
package it.unibo.tuprolog.solve.stdlib.rule
import it.unibo.tuprolog.core.Scope
import it.unibo.tuprolog.core.Term
import it.unibo.tuprolog.solve.ExecutionContext
import it.unibo.tuprolog.solve.rule.RuleWrapper
import it.unibo.tuprolog.solve.stdlib.magic.MagicCut
import it.unibo.tuprolog.solve.stdlib.primitive.EnsureExecutable
import kotlin.collections.List as KtList
import kotlin.collections.listOf as ktListOf
sealed class NegationAsFailure : RuleWrapper(FUNCTOR, ARITY) {
override val Scope.head: KtList
get() = ktListOf(
varOf("X")
)
abstract override val Scope.body: Term
object Fail : NegationAsFailure() {
override val Scope.body: Term
get() = tupleOf(
structOf(EnsureExecutable.functor, varOf("X")),
structOf(Call.functor, varOf("X")),
MagicCut,
truthOf(false)
)
}
object Success : NegationAsFailure() {
override val Scope.body: Term
get() = truthOf(true)
}
companion object {
const val FUNCTOR: String = "\\+"
const val ARITY: Int = 1
}
}