category
arbitrary¶
Adds predicates for generating and shrinking random values for selected types to the library type object. User extensible.
static
Logtalk specific types:
entity,object,protocol,category,entity_identifier,object_identifier,protocol_identifier,category_identifier,event,predicate
Prolog module related types (when the backend compiler supports modules):
module,module_identifier,qualified_callable
Prolog base types:
term,var,nonvar,atomic,atom,number,integer,float,compound,callable,ground
Atom derived types:
atom(CharSet),atom(CharSet,Length),non_empty_atom,non_empty_atom(CharSet),boolean,character,character(CharSet),char,char(CharSet),operator_specifier
Number derived types:
positive_number,negative_number,non_positive_number,non_negative_number
Float derived types:
positive_float,negative_float,non_positive_float,non_negative_float,probability
Integer derived types:
positive_integer,negative_integer,non_positive_integer,non_negative_integer,byte,character_code,character_code(CharSet),code,code(CharSet),operator_priority
List types (compound derived types):
list,non_empty_list,partial_list,list_or_partial_list,list(Type),list(Type,Length),list(Type,Min,Max),list(Type,Length,Min,Max),non_empty_list(Type),codes,chars
Difference list types (compound derived types):
difference_list,difference_list(Type)
Other compound derived types:
predicate_indicator,non_terminal_indicator,predicate_or_non_terminal_indicator,clause,clause_or_partial_clause,grammar_rule,pair,pair(KeyType,ValueType)
Other types:
between(Type,Lower,Upper),property(Type,LambdaExpression),one_of(Type,Set),var_or(Type),ground(Type),types(Types)
Registering new types: Add clauses for the
arbitrary/1-2multifile predicates and optionally for theshrinker/1andshrink/3multifile predicates. The clauses must have a bound first argument to avoid introducing spurious choice-points.
Character sets:
ascii_identifier,ascii_printable,ascii_full,byte,unicode_bmp,unicode_full
Default character sets: The default character set when using a parameterizable type that takes a character set parameter depends on the type.
Default character sets: Entity, predicate, and non-terminal identifier types plus compound and callable types default to an
ascii_identifierfunctor. Character and character code types default toascii_full. Other types default toascii_printable.
Caveats: The type argument (and any type parameterization) to the predicates is not type-checked (or checked for consistency) for performance reasons.
Public predicates¶
arbitrary/1¶
Table of defined types for which an arbitrary value can be generated. A new type can be registered by defining a clause for this predicate and adding a clause for the arbitrary/2 multifile predicate.
static, multifilearbitrary(Type)arbitrary(?callable) - zero_or_morearbitrary/2¶
Generates an arbitrary term of the specified type. Fails if the type is not supported. A new generator can be defined by adding a clause for this predicate and registering it via the arbitrary/1 predicate.
static, multifilearbitrary(Type,Term)arbitrary(@callable,-term) - zero_or_oneshrinker/1¶
Table of defined types for which a shrinker is provided. A new shrinker can be registered by defining a clause for this predicate and adding a definition for the shrink/3 multifile predicate.
static, multifileshrinker(Type)shrinker(?callable) - zero_or_moreshrink/3¶
Shrinks a value to a smaller value if possible. Must generate a finite number of solutions. Fails if the type is not supported. A new shrinker can be defined by adding a clause for this predicate and registering it via the shrinker/1 predicate.
static, multifileshrink(Type,Large,Small)shrink(@callable,@term,-term) - zero_or_moreedge_case/2¶
Table of type edge cases. Fails if the given type have no defined edge cases. New edge cases for existing or new types can be added by defining a clause for this multifile predicate.
static, multifileedge_case(Type,Term)edge_case(?callable,?term) - zero_or_moreget_seed/1¶
Gets the current random generator seed. Seed should be regarded as an opaque ground term.
staticget_seed(Seed)get_seed(-ground) - oneset_seed/1¶
Sets the random generator seed to a given value returned by calling the get_seed/1 predicate.
staticset_seed(Seed)set_seed(+ground) - oneProtected predicates¶
(no local declarations; see entity ancestors if any)
Private predicates¶
(no local declarations; see entity ancestors if any)