Did you know ... | Search Documentation: |
Pack logtalk -- logtalk-3.85.0/docs/_sources/nested_dictionary_protocol_0.rst.txt |
.. index:: nested_dictionary_protocol .. _nested_dictionary_protocol/0:
.. rst-class:: right
protocol
nested_dictionary_protocol
Nested dictionary protocol.
| Availability:
| logtalk_load(nested_dictionaries(loader))
| Author: Paul Brown and Paulo Moura | Version: 0:1:0 | Date: 2021-04-07
| Compilation flags:
| static
| Dependencies: | (none)
| Remarks: | (none)
| Inherited public predicates: | (none)
.. contents:: :local: :backlinks: top
.. index:: new/1 .. _nested_dictionary_protocol/0::new/1:
new/1 ^^^^^^^^^
Create an empty (nested) dictionary.
| Compilation flags:
| static
| Template:
| new(Dictionary)
| Mode and number of proofs:
| new(--dictionary)
- one
.. index:: empty/1 .. _nested_dictionary_protocol/0::empty/1:
empty/1 ^^^^^^^^^^^
True iff the dictionary is empty.
| Compilation flags:
| static
| Template:
| empty(Dictionary)
| Mode and number of proofs:
| empty(@dictionary)
- zero_or_one
.. index:: as_nested_dictionary/2 .. _nested_dictionary_protocol/0::as_nested_dictionary/2:
as_nested_dictionary/2 ^^^^^^^^^^^^^^^^^^^^^^^^^^
Creates a (nested) dictionary term from a curly-brackted term representation.
| Compilation flags:
| static
| Template:
| as_nested_dictionary(Term,Dictionary)
| Mode and number of proofs:
| as_nested_dictionary(++term,--dictionary)
- one_or_error
.. index:: as_curly_bracketed/2 .. _nested_dictionary_protocol/0::as_curly_bracketed/2:
as_curly_bracketed/2 ^^^^^^^^^^^^^^^^^^^^^^^^
Creates a a curly-brackted term representation from a (nested) dictionary.
| Compilation flags:
| static
| Template:
| as_curly_bracketed(Dictionary,Term)
| Mode and number of proofs:
| as_curly_bracketed(+dictionary,--term)
- one_or_error
.. index:: lookup_in/3 .. _nested_dictionary_protocol/0::lookup_in/3:
lookup_in/3 ^^^^^^^^^^^^^^^
Lookup a chain of keys in a nested dictionary. Unifies Value
with Dictionary
when Keys
is the empty list.
| Compilation flags:
| static
| Template:
| lookup_in(Keys,Value,Dictionary)
| Mode and number of proofs:
| lookup_in(++list(ground),?term,+dictionary)
- zero_or_more
.. index:: update_in/4 .. _nested_dictionary_protocol/0::update_in/4:
update_in/4 ^^^^^^^^^^^^^^^
Updates the value found by traversing through the nested keys.
| Compilation flags:
| static
| Template:
| update_in(OldDictionary,Keys,Value,NewDictionary)
| Mode and number of proofs:
| update_in(+dictionary,++list(ground),++term,--dictionary)
- zero_or_one
.. index:: update_in/5 .. _nested_dictionary_protocol/0::update_in/5:
update_in/5 ^^^^^^^^^^^^^^^
Updates the value found by traversing through the nested keys, only succeeding if the value found after traversal matches the old value.
| Compilation flags:
| static
| Template:
| update_in(OldDictionary,Keys,OldValue,NewValue,NewDictionary)
| Mode and number of proofs:
| update_in(+dictionary,++list(ground),?term,++term,--dictionary)
- zero_or_one
.. index:: insert_in/4 .. _nested_dictionary_protocol/0::insert_in/4:
insert_in/4 ^^^^^^^^^^^^^^^
Inserts a key-value pair into a dictionary by traversing through the nested keys. When the key already exists, the associated value is updated.
| Compilation flags:
| static
| Template:
| insert_in(OldDictionary,Keys,Value,NewDictionary)
| Mode and number of proofs:
| insert_in(+dictionary,++list(ground),++term,--dictionary)
- zero_or_one
.. index:: delete_in/4 .. _nested_dictionary_protocol/0::delete_in/4:
delete_in/4 ^^^^^^^^^^^^^^^
Deletes a matching key-value pair from a dictionary by traversing through the nested keys, returning the updated dictionary.
| Compilation flags:
| static
| Template:
| delete_in(OldDictionary,Keys,Value,NewDictionary)
| Mode and number of proofs:
| delete_in(+dictionary,++list(ground),?term,--dictionary)
- zero_or_one
(none)
(none)
(none)
.. seealso::
:ref:`navltree <navltree/0>`, :ref:`nbintree <nbintree/0>`, :ref:`nrbtree <nrbtree/0>`