[ Non-logical Variables, Arrays, Bags, Shelves and Stores | Reference Manual | Alphabetic Index ]

store_update(+StoreHandle, ++Key, -OldValue, ?NewValue)

Update an existing entry in a store object
StoreHandle
A store handle or store name
Key
A ground term
OldValue
A variable or arbitrary term (output)
NewValue
An arbitrary term

Description

Looks up a store entry under the given key. If one exists, the old value is unified with OldValue, and the store entry is overwritten with NewValue. Otherwise the predicate fails. It could be defined as:
        store_update(Store, Key, OldValue, NewValue) :-
            with_mutex(Store, (
                    store_get(Store, Key, Entry),
                    store_set(Store, Key, NewValue),
                    OldValue = Entry    % after update!
            )).

The key can be arbitrarily complex, but must be a ground term. The value can be an arbitrary term, and may contain uninstantiated variables. Note that values are copied when being stored or retrieved, therefore a retrieved nonground value will contain fresh variables rather than the original ones (this is similar to the behaviour of bags, shelves and global variables).

The complexity of the update operation is linear in the size of the key and both values, which are copied. For indexing purposes, a hash value is computed from the key, and the full depth of the key is taken into account.

Note: If StoreHandle is not a handle, then it must be an atom or a compound term, and the store is identified by this term's toplevel functor together with the context module.

Modes and Determinism

Modules

This predicate is sensitive to its module context (tool predicate, see @/2).

Exceptions

(4) instantiation fault
StoreHandle is uninstantiated
(4) instantiation fault
Key is not ground
(5) type error
StoreHandle is neither atom nor compound term nor store handle
(45) named object does not exist
StoreHandle is not the name of a store

Examples

    ?- store_create(Handle),
       store_update(Handle, tom, Old, first).	% no entry yet

    No (0.00s cpu)


    ?- store_create(Handle),
       store_set(Handle, tom, first),
       store_update(Handle, tom, Old, second),
       store_get(Handle, tom, New).
    
    Handle = $&(store,"17h3")
    Old = first
    New = second
    Yes (0.00s cpu)
    No (0.00s cpu)
    

See Also

store / 1, store_create / 1, store_contains / 2, store_count / 2, store_get / 3, store_inc / 2, store_insert / 3, store_set / 3, store_test_and_set / 4