public interface PredicateFactory
Predicate
.
There are two general types of predicates:
pj_add_predicate/2
and pj_add_arithmetic_operator/2
. The pj_add_predicate/2
predicate allows
other predicates to be "plugged-in" to Projog.
Note: Rather than directly implementing PredicateFactory
it is recommended to extend either
AbstractSingleResultPredicate
or
AbstractPredicateFactory
.
Modifier and Type | Method and Description |
---|---|
Predicate |
getPredicate(Term[] args)
Returns a
Predicate to be used in the evaluation of a goal. |
default boolean |
isAlwaysCutOnBacktrack()
Will attempting to re-evaluate this implementation always result in a cut?
|
boolean |
isRetryable()
Should instances of this implementation be re-evaluated when backtracking?
|
Predicate getPredicate(Term[] args)
Predicate
to be used in the evaluation of a goal.args
- the arguments to use in the evaluation of the goalPredicate.evaluate()
boolean isRetryable()
Some goals (e.g. X is 1
) are only meant to be evaluated once (the statement is either true or false) while
others (e.g. repeat(3)
) are meant to be evaluated multiple times. For instances of Predicate
that
are designed to possibly have Predicate.evaluate()
called on them multiple times for the same individual
query this method should return true
. For instances of Predicate
that are designed to only be
evaluated once per individual query this method should return false
.
true
if an attempt should be made to re-evaluate instances of implementing classes when
backtracking, false
otherwisedefault boolean isAlwaysCutOnBacktrack()
true
if a cut will always be encountered when attempting to re-evaluate, false
otherwiseCopyright © 2024. All rights reserved.