
com.thesett.aima.logic.fol.wam.builtins.Cut Maven / Gradle / Ivy
/*
* Copyright The Sett Ltd, 2005 to 2014.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package com.thesett.aima.logic.fol.wam.builtins;
import com.thesett.aima.logic.fol.Functor;
import com.thesett.aima.logic.fol.FunctorName;
import com.thesett.aima.logic.fol.Term;
import com.thesett.aima.logic.fol.Variable;
import com.thesett.aima.logic.fol.wam.compiler.DefaultBuiltIn;
import com.thesett.aima.logic.fol.wam.compiler.SymbolTableKeys;
import com.thesett.aima.logic.fol.wam.compiler.WAMInstruction;
import static com.thesett.aima.logic.fol.wam.compiler.WAMInstruction.WAMInstructionSet.Cut;
import static com.thesett.aima.logic.fol.wam.compiler.WAMInstruction.WAMInstructionSet.NeckCut;
import com.thesett.common.util.SizeableLinkedList;
import com.thesett.common.util.doublemaps.SymbolKey;
/**
* Cut implements the prolog '!' operator, that prevents back-tracking within a functor. '!' is true; that is it does
* not ever fail. All choice points between the cut and the parent goal are removed. The effect is to commit to use both
* the current clause and the variable substitutions found at the point of the cut.
*
*
CRC Card
* Responsibilities Collaborations
* Implement the cut operator.
*
*
* @author Rupert Smith
*/
public class Cut extends BaseBuiltIn
{
/**
* Creates a cut built-in to implement the specified functor.
*
* @param functor The functor to implement as a built-in.
* @param defaultBuiltIn The default built in, for standard compilation and interners and symbol tables.
*/
public Cut(Functor functor, DefaultBuiltIn defaultBuiltIn)
{
// Here the cut functor is transformed from ! to !(Y), where Y is a level variable that may be needed
// to hold the current choice point.
super(new Functor(functor.getName(), new Term[] { CutLevelVariable.CUT_LEVEL_VARIABLE }), defaultBuiltIn);
}
/** {@inheritDoc} */
public SizeableLinkedList© 2015 - 2025 Weber Informatics LLC | Privacy Policy