Most list operations are defined in the library library(lists)
described in section ??. Some that are implemented with more
low-level primitives are built-in and described here.
)
or a term with functor `.
' and arity 2
and the second argument is a list. (39)
This predicate acts as if defined by the following definition:
is_list(X) :- var(X), !, fail. is_list([]). is_list([_|T]) :- is_list(T). |
Key-Value
,
that is, terms whose principal functor is (-)/2, whose first argument is
the sorting key, and whose second argument is the satellite data to be
carried along with the key. keysort/2
sorts List like msort/2,
but only compares the keys. It is used to sort terms not on standard
order, but on any criterion that can be expressed on a multi-dimensional
scale. Sorting on more than one criterion can be done using terms as
keys, putting the first criterion as argument 1, the second as argument
2, etc. The order of multiple elements that have the same Key
is not changed. The implementation is in C, using natural merge sort.
<
, const>
or
=
. If built-in predicate compare/3
is used, the result is the same as sort/2.
See also keysort/2. (41)