Class List
java.lang.Object
org.projog.core.term.List
- All Implemented Interfaces:
Term
Represents a data structure with two
Terms - a head and a tail.
The head and tail can be any Terms - including other Lists. By having a List with a
List as its tail it is possible to represent an ordered sequence of Terms of any length. The end of
an ordered sequence of Terms is normally represented as a tail having the value of an EmptyList.
- See Also:
-
Constructor Summary
Constructors -
Method Summary
Modifier and TypeMethodDescriptionvoidReverts this term back to its original state prior to any unifications.Returns a copy of this term.booleangetArgument(int index) Returns the term at the specified position in this term's arguments.getName()ReturnsListFactory.LIST_PREDICATE_NAME.intReturns the number of arguments in this term.getTerm()Returns the current instantiated state of this term.getType()ReturnsTermType.LIST.inthashCode()booleanReturnstrueis this term is immutable.toString()booleanAttempts to unify this term to the specified term.Methods inherited from interface Term
copy, fourthArgument, getBound, thirdArgument
-
Constructor Details
-
List
Creates a new list with the specified head and tail.Consider using
ListFactoryrather than calling directly.- Parameters:
head- the head of the new listtail- the tail of the new list
-
-
Method Details
-
getName
ReturnsListFactory.LIST_PREDICATE_NAME.- Specified by:
getNamein interfaceTerm- Returns:
ListFactory.LIST_PREDICATE_NAME
-
getNumberOfArguments
public int getNumberOfArguments()Description copied from interface:TermReturns the number of arguments in this term.- Specified by:
getNumberOfArgumentsin interfaceTerm- Returns:
- number of arguments in this term
-
firstArgument
- Specified by:
firstArgumentin interfaceTerm
-
secondArgument
- Specified by:
secondArgumentin interfaceTerm
-
getArgument
Description copied from interface:TermReturns the term at the specified position in this term's arguments.- Specified by:
getArgumentin interfaceTerm- Parameters:
index- index of the argument to return- Returns:
- the term at the specified position in this term's arguments
-
getType
ReturnsTermType.LIST.- Specified by:
getTypein interfaceTerm- Returns:
TermType.LIST
-
isImmutable
public boolean isImmutable()Description copied from interface:TermReturnstrueis this term is immutable.A term is considered immutable if its value will never change as a result of executing its
Term.unify(Term)orTerm.backtrack()methods. A term will not be considered immutable if it is aVariableor any of its arguments are not immutable.- Specified by:
isImmutablein interfaceTerm- Returns:
trueis this term is immutable
-
getTerm
-
copy
Description copied from interface:Term -
unify
Description copied from interface:TermAttempts to unify this term to the specified term.The rules for deciding if two terms are unifiable are as follows:
- An uninstantiated
Variablewill unify with any term. As a result theVariablewill become instantiated to the other term. The instantiaton will be undone whenTerm.backtrack()is next called on theVariable - Non-variable terms will unify with other terms that are of the same
TermTypeand have the same value. The exact meaning of "having the same value" will vary between term types but will include that the two terms being unified have the same number of arguments and that all of their corresponding arguments unify.
- An uninstantiated
-
backtrack
-
equals
-
hashCode
-
toString
-