All Downloads are FREE. Search and download functionalities are using the official Maven repository.

commonMain.it.unibo.tuprolog.solve.stdlib.primitive.AtomChars.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.exception.error.TypeError
import it.unibo.tuprolog.solve.primitive.BinaryRelation
import it.unibo.tuprolog.solve.primitive.Solve
import it.unibo.tuprolog.unify.Unificator.Companion.mguWith
import it.unibo.tuprolog.core.List as LogicList

object AtomChars : BinaryRelation.Functional("atom_chars") {
    override fun Solve.Request.computeOneSubstitution(first: Term, second: Term): Substitution =
        when {
            first is Var && second is Var -> {
                ensuringAllArgumentsAreInstantiated()
                Substitution.failed()
            }
            first is Var -> {
                ensuringArgumentIsList(1)
                val chars = second as LogicList
                val atom: Atom = Atom.of(
                    chars.toSequence().map {
                        if (it is Atom) {
                            it.value[0]
                        } else {
                            throw TypeError.forArgumentList(context, signature, TypeError.Expected.CHARACTER, it, 1)
                        }
                    }.joinToString("")
                )
                Substitution.of(first, atom)
            }
            second is Var -> {
                ensuringArgumentIsAtom(0)
                val charArray = (first as Atom).value.toCharArray()
                val chars = LogicList.of(charArray.map { Atom.of("" + it) })
                Substitution.of(second, chars)
            }
            else -> {
                ensuringArgumentIsAtom(0)
                ensuringArgumentIsList(1)
                val chars = LogicList.of(
                    (first as Atom).value.toCharArray().map { Atom.of("" + it) }
                )
                chars mguWith second
            }
        }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy