Authors: Richard A. O'Keefe, L.Damas, V.S.Costa and Markus Triska
Elements of an association list have 2 components: A (unique)
key and a value. Keys should be ground, values need
not be. An association list can be used to fetch elements via their keys
and to enumerate its elements in ascending order of their keys. The
library(assoc)
module uses AVL trees to implement
association lists. This makes inserting, changing and fetching a single
element an O(log(N)) (where N denotes the number of elements in the
list) expected time (and worst-case time) operation.
- assoc_to_list(+Assoc,
-List)
-
List is a list of Key-Value pairs corresponding to the
associations in Assoc in ascending order of keys.
- empty_assoc(-Assoc)
-
Assoc is unified with an empty association list.
- gen_assoc(?Key,
+Assoc, ?Value)
-
Enumerate matching elements of Assoc in ascending order of
their keys via backtracking.
- get_assoc(+Key,
+Assoc, ?Value)
-
Value is the value associated with Key in the
association list Assoc.
- get_assoc(+Key,
+Assoc, ?Old, ?NewAssoc, ?New)
-
NewAssoc is an association list identical to
Assoc except that the value associated with Key is New
instead of Old.
- list_to_assoc(+List,
?Assoc)
-
Assoc is an association list corresponding to the Key-Value
pairs in List.
- map_assoc(:Goal,
+Assoc)
-
Goal(V) is true for every value V in Assoc.
- map_assoc(:Goal,
+AssocIn, ?AssocOut)
-
AssocOut is AssocIn with Goal applied
to all corresponding pairs of values.
- max_assoc(+Assoc,
?Key, ?Value)
-
Key and Value are key and value of the element
with the largest key in Assoc.
- min_assoc(+Assoc,
?Key, ?Value)
-
Key and Value are key and value of the element
with the smallest key in Assoc.
- ord_list_to_assoc(+List,
?Assoc)
-
Assoc is an association list correpsond to the Key-Value
pairs in List, which must occur in ascending order of their
keys.
- put_assoc(+Key,
+Assoc, +Value, ?NewAssoc)
-
NewAssoc is an association list identical to
Assoc except that Key is associated with
Value. This can be used to insert and change associations.