1use crate::keys::*;
2use crate::TrieNode;
3use crate::{SubTrie, SubTrieMut, SubTrieResult};
4use std::borrow::Borrow;
56use nibble_vec::Nibblet;
78impl<'a, K, V> SubTrie<'a, K, V>
9where
10K: TrieKey,
11{
12/// Look up the value for the given key, which should be an extension of this subtrie's key.
13 ///
14 /// The key may be any borrowed form of the trie's key type, but TrieKey on the borrowed
15 /// form *must* match those for the key type
16pub fn get<Q: ?Sized>(&self, key: &Q) -> SubTrieResult<&V>
17where
18K: Borrow<Q>,
19 Q: TrieKey,
20 {
21 subtrie_get(&self.prefix, self.node, key)
22 }
23}
2425fn subtrie_get<'a, K, Q: ?Sized, V>(
26 prefix: &Nibblet,
27 node: &'a TrieNode<K, V>,
28 key: &Q,
29) -> SubTrieResult<&'a V>
30where
31K: TrieKey,
32 K: Borrow<Q>,
33 Q: TrieKey,
34{
35let key_enc = key.encode();
36match match_keys(0, prefix, &key_enc) {
37 KeyMatch::Full => Ok(node.value()),
38 KeyMatch::FirstPrefix => Ok(node
39 .get(&stripped(key_enc, prefix))
40 .and_then(TrieNode::value)),
41_ => Err(()),
42 }
43}
4445impl<'a, K, V> SubTrieMut<'a, K, V>
46where
47K: TrieKey,
48{
49/// Mutable reference to the node's value.
50pub fn value_mut(&mut self) -> Option<&mut V> {
51self.node.value_mut()
52 }
5354/// Look up the value for the given key, which should be an extension of this subtrie's key.
55 ///
56 /// The key may be any borrowed form of the trie's key type, but TrieKey on the borrowed
57 /// form *must* match those for the key type
58pub fn get<Q: ?Sized>(&self, key: &Q) -> SubTrieResult<&V>
59where
60K: Borrow<Q>,
61 Q: TrieKey,
62 {
63 subtrie_get(&self.prefix, &*self.node, key)
64 }
6566/// Insert a value in this subtrie. The key should be an extension of this subtrie's key.
67pub fn insert(&mut self, key: K, value: V) -> SubTrieResult<V> {
68let key_enc = key.encode();
69let previous = match match_keys(0, &self.prefix, &key_enc) {
70 KeyMatch::Full => self.node.replace_value(key, value),
71 KeyMatch::FirstPrefix => self
72.node
73 .insert(key, value, stripped(key_enc, &self.prefix)),
74_ => {
75return Err(());
76 }
77 };
7879if previous.is_none() {
80*self.length += 1;
81 }
8283Ok(previous)
84 }
8586/// Remove a value from this subtrie. The key should be an extension of this subtrie's key.
87 ///
88 /// The key may be any borrowed form of the trie's key type, but TrieKey on the borrowed
89 /// form *must* match those for the key type
90pub fn remove<Q: ?Sized>(&mut self, key: &Q) -> SubTrieResult<V>
91where
92K: Borrow<Q>,
93 Q: TrieKey,
94 {
95let key_enc = key.encode();
96let removed = match match_keys(0, &self.prefix, &key_enc) {
97 KeyMatch::Full => self.node.take_value(key),
98 KeyMatch::FirstPrefix => self.node.remove(key),
99_ => {
100return Err(());
101 }
102 };
103104if removed.is_some() {
105*self.length -= 1;
106 }
107108Ok(removed)
109 }
110}
111112fn stripped(mut key: Nibblet, prefix: &Nibblet) -> Nibblet {
113 key.split(prefix.len())
114}