Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add MPT #1442

Merged
merged 228 commits into from
Jun 1, 2020
Merged

Add MPT #1442

Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
228 commits
Select commit Hold shift + click to select a range
493f10b
first push
Jan 10, 2020
54613d3
add TryDelete
Jan 16, 2020
bec65ef
split nodes
Jan 16, 2020
a991041
add GetProof and ut
Jan 16, 2020
468b882
add ut
Jan 16, 2020
9dca50c
format
Jan 16, 2020
d407532
fix some
Jan 16, 2020
61467d7
fix interface
Jan 17, 2020
8605d63
format
Jan 17, 2020
f45396c
rm nullnode typee
Jan 17, 2020
3f083d2
Merge pull request #1 from neo-project/master
Jan 20, 2020
05aaade
Merge pull request #2 from neo-project/master
Feb 4, 2020
8f301d9
rm fullnode size
Feb 10, 2020
3d01c5b
rm Database commit
Feb 10, 2020
eb3c777
first push
Jan 10, 2020
8c05f76
add TryDelete
Jan 16, 2020
a1db507
split nodes
Jan 16, 2020
ac3c4a8
add GetProof and ut
Jan 16, 2020
6eeaa98
add ut
Jan 16, 2020
2037f78
format
Jan 16, 2020
260b1c1
fix some
Jan 16, 2020
2381013
fix interface
Jan 17, 2020
d47429f
format
Jan 17, 2020
d6c91c7
rm nullnode typee
Jan 17, 2020
08acc30
rm fullnode size
Feb 10, 2020
5be8a6d
rm Database commit
Feb 10, 2020
b1721a8
Merge branch 'feature/MPT' of github.com:KickSeason/neo into feature/MPT
Feb 10, 2020
1c8831f
Merge pull request #3 from neo-project/master
Feb 10, 2020
75cac28
format
Feb 11, 2020
c606275
Merge branch 'feature/MPT' of github.com:KickSeason/neo into feature/MPT
Feb 11, 2020
687e7d6
CalHash
Feb 11, 2020
3989c16
rm Clone()
Feb 11, 2020
79ee48b
use const variable
Feb 11, 2020
63bd578
new line in ut
Feb 11, 2020
6fa37ef
fix some
Feb 11, 2020
40f3b7d
capitalize method name
Feb 12, 2020
bd2db12
fix some
Feb 12, 2020
0b46273
fix ut
Feb 12, 2020
51a823d
Merge pull request #4 from neo-project/master
Feb 12, 2020
39da07b
Merge pull request #5 from neo-project/master
Feb 12, 2020
e88b524
Merge branch 'master' into feature/MPT
Feb 12, 2020
e261c02
format
Feb 12, 2020
c2043c2
fix size and exception
Feb 13, 2020
8c8ee91
format
Feb 13, 2020
8342cb1
format
Feb 14, 2020
7f5314a
rm Serialize and Deserialize use Encode and Decode
Feb 14, 2020
7d01510
format
Feb 14, 2020
0321ab6
format
Feb 14, 2020
c87dfea
format
Feb 14, 2020
f5c8df4
rm prefix
Feb 17, 2020
6cd152e
assign enum value
Feb 17, 2020
978c52a
fix some
Feb 20, 2020
e8afc1a
format
Feb 20, 2020
af83056
empty byte array
Feb 20, 2020
069eede
check if change when commit
Feb 20, 2020
bb89eac
unit test
Feb 20, 2020
d26c149
format
Feb 21, 2020
79f98ce
change nonEmptyChildren to childrenIndexes
Feb 21, 2020
1d0041c
change mpttrie initialize and ut
Feb 21, 2020
d415f27
rm blanks
Feb 21, 2020
a4f3e22
change public to private
Feb 21, 2020
56bf677
calhash to genhash
Feb 21, 2020
78293e0
change variable name
Feb 21, 2020
2a1745b
use Crypto.Hash256
Feb 24, 2020
bb404d4
add ready only trie
Feb 24, 2020
59d0c60
change name MPTDatabase to MPTDb
Feb 24, 2020
5c1013c
1. remove value node delete, same value has same hash and share data …
Feb 25, 2020
b31e255
use list instead dictionary
Feb 27, 2020
64719df
Merge branch 'master' into feature/MPT
vncoelho Mar 7, 2020
9ec487a
change dict to list
Mar 9, 2020
ac0a30f
Merge branch 'feature/MPT' of github.com:KickSeason/neo into feature/MPT
Mar 9, 2020
4a81a91
use hashset
Mar 9, 2020
1e36f3b
add read only trie, and fix branch node only remain value child
Mar 18, 2020
ddd44be
Merge branch 'master' into feature/MPT
Mar 19, 2020
3ef79fd
change name
Mar 19, 2020
15d658f
Merge branch 'feature/MPT' of github.com:KickSeason/neo into feature/MPT
Mar 19, 2020
2c01995
format
Mar 21, 2020
e5f04cb
format
Mar 21, 2020
0f6a0e3
Merge branch 'master' into feature/MPT
Mar 23, 2020
4afd976
return instead of throw
Mar 23, 2020
e7e1ce3
Merge branch 'feature/MPT' of github.com:KickSeason/neo into feature/MPT
Mar 23, 2020
c9851b3
Merge branch 'master' into feature/MPT
Mar 23, 2020
caa9426
Merge branch 'master' of github.com:neo-project/neo
Mar 24, 2020
b9ee482
Merge branch 'master' into feature/MPT
shargon Mar 24, 2020
6d11e2e
mv trie/helper to neo/helper
Mar 25, 2020
dce98a3
Merge branch 'feature/MPT' of github.com:KickSeason/neo into feature/MPT
Mar 25, 2020
37e5e02
Optimize
shargon Mar 25, 2020
d6a43dd
Optimize
shargon Mar 25, 2020
57a9cf2
Clean file
shargon Mar 25, 2020
5905b12
use Array.Resize
Mar 26, 2020
2918ce5
one class one file
Mar 26, 2020
eac80cb
change valuenode to leafnode
Mar 26, 2020
78b7f2a
file name
Mar 26, 2020
a0bcb39
format
Mar 26, 2020
e292b3d
use uint256
Mar 26, 2020
23835e4
change name
Mar 26, 2020
57b9dc6
modify ByteArray.Add
Mar 26, 2020
64096b9
Merge branch 'master' into feature/MPT
Mar 26, 2020
65ae1fc
Merge branch 'master' into feature/MPT
Mar 27, 2020
53811e3
Merge branch 'master' into feature/MPT
shargon Mar 31, 2020
6b72dd1
optimize take prefix
Mar 31, 2020
f9a300a
optimize take prefix
Mar 31, 2020
0261593
add equal ut
Mar 31, 2020
4b5459b
Simplify CommonPrefix
shargon Apr 1, 2020
dadb274
add max key
Apr 1, 2020
4022a41
Merge branch 'feature/MPT' of github.com:KickSeason/neo into feature/MPT
Apr 1, 2020
6204d0b
use itore
Apr 1, 2020
7e4d12e
rm
Apr 1, 2020
cca3fbd
fix max length
Apr 1, 2020
b0ffd64
use ISnapshot and fix ut
Apr 1, 2020
4002dec
format
Apr 1, 2020
2c11831
Optimize Skip
shargon Apr 1, 2020
ae64dcc
Clean file
shargon Apr 1, 2020
eaf7dcf
Merge branch 'master' into feature/MPT
shargon Apr 1, 2020
8ba4e68
change property name
Apr 2, 2020
f6b8d33
add null check
Apr 2, 2020
9c8d09c
rm linq
Apr 2, 2020
da484e9
Merge branch 'master' into feature/MPT
Apr 9, 2020
7a73e44
concat
Apr 9, 2020
5a8b5f1
use SequenceEqual
Apr 9, 2020
96ffeb0
fix double dispose stream
Apr 9, 2020
e17a481
use start with
Apr 10, 2020
b21c15d
Merge branch 'master' into feature/MPT
Apr 10, 2020
4fa4015
fix some
Apr 10, 2020
e9943e4
Merge branch 'feature/MPT' of github.com:KickSeason/neo into feature/MPT
Apr 10, 2020
0e5747b
use startswith
Apr 10, 2020
051a678
Merge branch 'master' into feature/MPT
Apr 10, 2020
cebeabe
Remove Helper.Skip()
erikzhang Apr 10, 2020
f37f43c
Remove Helper.Add()
erikzhang Apr 10, 2020
5fa00cf
Move methods
erikzhang Apr 10, 2020
1c7b492
fix
Apr 10, 2020
c09ef1f
Remove try for dispose
shargon Apr 10, 2020
3bc6ab7
Fix ReadBytes error
shargon Apr 10, 2020
1fc4053
Clean code
shargon Apr 10, 2020
278c3b2
Merge branch 'master' into feature/MPT
Apr 11, 2020
20d27a0
add max value lenght
Apr 11, 2020
7e59d8a
Merge branch 'master' into feature/MPT
Apr 11, 2020
a63f9c3
Merge branch 'feature/MPT' of github.com:KickSeason/neo into feature/MPT
Apr 11, 2020
920adc6
add read max lenght
Apr 14, 2020
73f4d65
branchnode value index
Apr 15, 2020
c6075c0
Merge branch 'master' into feature/MPT
shargon Apr 15, 2020
aa06d4c
Merge branch 'master' of github.com:neo-project/neo
Apr 23, 2020
394a87c
code
Apr 24, 2020
1a95fe4
Merge branch 'feature/MPT' of github.com:KickSeason/neo into feature/MPT
Apr 24, 2020
5ddf390
fix add longer key
Apr 24, 2020
fb6ddfd
fix ut
Apr 24, 2020
0deb9f5
Merge branch 'master' into feature/MPT
Apr 24, 2020
1140d45
fix size
Apr 24, 2020
9a5ad98
avoid empth key extension node
Apr 26, 2020
174e441
use ISerializable as key value
Apr 28, 2020
5b5f0ad
Merge branch 'master' into feature/MPT
Apr 28, 2020
53613c2
add find and split class
Apr 29, 2020
f8b5963
Merge branch 'feature/MPT' of github.com:KickSeason/neo into feature/MPT
Apr 29, 2020
6c1ab3b
format
Apr 29, 2020
ae4c590
define mpt element accessor
Apr 29, 2020
6c80b67
Merge branch 'master' into feature/MPT
Apr 29, 2020
66b1df1
Merge branch 'feature/MPT' of github.com:KickSeason/neo into feature/MPT
Apr 30, 2020
14bc074
assign default value of TestKey and TestValue in constructor
Apr 30, 2020
3650852
set value null when not found
Apr 30, 2020
47dd1c5
use .Length < 1
Apr 30, 2020
4f5eb93
Merge branch 'master' into feature/MPT
May 6, 2020
826fc16
Merge branch 'master' into feature/MPT
May 8, 2020
d4be6ac
Merge branch 'master' of github.com:neo-project/neo
May 11, 2020
ca753a3
Move namespace
erikzhang May 12, 2020
dbfff2c
Move Helper.CommonPrefix()
erikzhang May 12, 2020
dc54eef
Remove Helper.cs
erikzhang May 12, 2020
48d0b61
optimize
erikzhang May 12, 2020
69b2fcc
Update src/neo/Cryptography/MPT/BranchNode.cs
shargon May 12, 2020
d4c21ea
Update src/neo/Cryptography/MPT/MPTReadOnlyDb.cs
shargon May 12, 2020
99e7040
Update src/neo/Cryptography/MPT/MPTReadOnlyDb.cs
shargon May 12, 2020
359ba37
Update src/neo/Cryptography/MPT/MPTTrie.cs
shargon May 12, 2020
bd1284e
Update src/neo/Cryptography/MPT/MPTReadOnlyTrie.cs
shargon May 12, 2020
8f3b069
Update src/neo/Cryptography/MPT/MPTReadOnlyTrie.cs
shargon May 12, 2020
d01b3ed
Update src/neo/Cryptography/MPT/MPTDb.cs
shargon May 12, 2020
a999e1f
Merge branch 'master' into feature/MPT
shargon May 12, 2020
6e1a4b7
Fix UT
shargon May 12, 2020
ad13492
Some VS recommendations
shargon May 12, 2020
fca0884
dotnet format
shargon May 12, 2020
70d0804
Order the result value of Find method
May 15, 2020
5b2462d
Optimize
erikzhang May 15, 2020
6a0411d
Merge branch 'master' into feature/MPT
erikzhang May 15, 2020
01f3b76
Optimize
erikzhang May 17, 2020
5b37105
Use ReflectionCache
erikzhang May 17, 2020
f744d7f
EmptyNode
erikzhang May 17, 2020
b3be508
Remove MPTNode.Dirty
erikzhang May 17, 2020
6bea24d
Remove GenHash() and GetHash()
erikzhang May 17, 2020
11599b3
Optimize EncodeSpecific()
erikzhang May 17, 2020
7914efb
Optimize DecodeSpecific()
erikzhang May 17, 2020
b6e41bc
Merge branch 'master' into feature/MPT
erikzhang May 17, 2020
9e185be
Optimize, simplify and format
erikzhang May 17, 2020
3e5646b
Format
erikzhang May 17, 2020
39274d3
Update MPTNode.cs
erikzhang May 17, 2020
b6af8cd
Merge branch 'master' into feature/MPT
erikzhang May 17, 2020
9ea1ff7
use MemoryStore replace ProofStore
May 18, 2020
03ca94d
rm ToJson()
May 18, 2020
d6b976d
Merge branch 'master' into feature/MPT
erikzhang May 18, 2020
f662cb0
remove ReadOnlyTrie
May 18, 2020
43a0eba
Merge branch 'master' of github.com:neo-project/neo
May 19, 2020
6895937
Use constant prefix
erikzhang May 20, 2020
a223dbd
Rename
erikzhang May 20, 2020
0d91319
Remove MPTDb
erikzhang May 20, 2020
2d21d44
Remove MPTTrie.GetRoot()
erikzhang May 20, 2020
86dd270
Update MPTTrie.cs
erikzhang May 20, 2020
2a8bb6f
Simplify declaring the partial class
erikzhang May 20, 2020
6801a80
Move PutToStore()
erikzhang May 20, 2020
ded26b9
Remove MPTTrie.Get()
erikzhang May 20, 2020
497dcd8
Modify MPTTrie.GetProof()
erikzhang May 20, 2020
c27d094
Format
erikzhang May 20, 2020
ac2c295
Merge branch 'master' into feature/MPT
erikzhang May 20, 2020
df8048d
rm repeated put
May 20, 2020
bd2011f
using
erikzhang May 21, 2020
6839484
Merge branch 'master' into feature/MPT
erikzhang May 21, 2020
6275b0a
Optimize
erikzhang May 26, 2020
2ab6d2e
Merge branch 'master' into feature/MPT
erikzhang May 26, 2020
5f71a37
Merge branch 'master' into feature/MPT
May 26, 2020
e9d047d
Merge branch 'master' of github.com:neo-project/neo
May 26, 2020
1742c55
Merge branch 'master' into feature/MPT
May 26, 2020
822291d
Merge branch 'feature/MPT' of github.com:KickSeason/neo into feature/MPT
May 28, 2020
f915b56
fix mpt find
May 28, 2020
e5e691b
recover key from nibles
May 28, 2020
1623aaf
Merge branch 'master' into feature/MPT
erikzhang May 28, 2020
2bcda02
Readability and format
erikzhang May 28, 2020
d0e33c4
fix find
May 28, 2020
e6087c2
Merge branch 'feature/MPT' of github.com:KickSeason/neo into feature/MPT
May 28, 2020
f35103b
enhance ut
May 28, 2020
528283b
enhance ut(2)
May 28, 2020
8c4c526
Merge branch 'master' into feature/MPT
Jun 1, 2020
eb37222
sync with master
Jun 1, 2020
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
35 changes: 35 additions & 0 deletions src/neo/Cryptography/MPT/BranchNode.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,35 @@
using System.IO;

namespace Neo.Cryptography.MPT
{
public class BranchNode : MPTNode
{
public const int ChildCount = 17;
erikzhang marked this conversation as resolved.
Show resolved Hide resolved
public readonly MPTNode[] Children = new MPTNode[ChildCount];

protected override NodeType Type => NodeType.BranchNode;

public BranchNode()
{
for (int i = 0; i < ChildCount; i++)
{
Children[i] = HashNode.EmptyNode;
}
}

internal override void EncodeSpecific(BinaryWriter writer)
{
for (int i = 0; i < ChildCount; i++)
WriteHash(writer, Children[i].Hash);
}

internal override void DecodeSpecific(BinaryReader reader)
{
for (int i = 0; i < ChildCount; i++)
{
Children[i] = new HashNode();
Children[i].DecodeSpecific(reader);
}
}
}
}
30 changes: 30 additions & 0 deletions src/neo/Cryptography/MPT/ExtensionNode.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
using Neo.IO;
using Neo.SmartContract;
using System.IO;

namespace Neo.Cryptography.MPT
{
public class ExtensionNode : MPTNode
{
//max lenght when store StorageKey
public const int MaxKeyLength = (ApplicationEngine.MaxStorageValueSize + sizeof(int)) * 2;

public byte[] Key;
public MPTNode Next;

protected override NodeType Type => NodeType.ExtensionNode;

internal override void EncodeSpecific(BinaryWriter writer)
{
writer.WriteVarBytes(Key);
WriteHash(writer, Next.Hash);
}

internal override void DecodeSpecific(BinaryReader reader)
{
Key = reader.ReadVarBytes(MaxKeyLength);
Next = new HashNode();
Next.DecodeSpecific(reader);
}
}
}
41 changes: 41 additions & 0 deletions src/neo/Cryptography/MPT/HashNode.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
using Neo.IO;
using System;
using System.IO;

namespace Neo.Cryptography.MPT
{
public class HashNode : MPTNode
{
private UInt256 hash;

public override UInt256 Hash => hash;
protected override NodeType Type => NodeType.HashNode;
public bool IsEmpty => Hash is null;
public static HashNode EmptyNode { get; } = new HashNode();

public HashNode()
{
}

public HashNode(UInt256 hash)
{
this.hash = hash;
}

internal override void EncodeSpecific(BinaryWriter writer)
{
WriteHash(writer, hash);
}

internal override void DecodeSpecific(BinaryReader reader)
{
byte[] buffer = reader.ReadVarBytes(UInt256.Length);
hash = buffer.Length switch
{
0 => null,
UInt256.Length => new UInt256(buffer),
_ => throw new FormatException()
};
}
}
}
36 changes: 36 additions & 0 deletions src/neo/Cryptography/MPT/LeafNode.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,36 @@
using Neo.IO;
using Neo.SmartContract;
using System;
using System.IO;

namespace Neo.Cryptography.MPT
{
public class LeafNode : MPTNode
{
//the max size when store StorageItem
public const int MaxValueLength = 3 + ApplicationEngine.MaxStorageValueSize + sizeof(bool);

public byte[] Value;

protected override NodeType Type => NodeType.LeafNode;

public LeafNode()
{
}

public LeafNode(ReadOnlySpan<byte> value)
{
Value = value.ToArray();
}

internal override void EncodeSpecific(BinaryWriter writer)
{
writer.WriteVarBytes(Value);
}

internal override void DecodeSpecific(BinaryReader reader)
{
Value = reader.ReadVarBytes(MaxValueLength);
}
}
}
61 changes: 61 additions & 0 deletions src/neo/Cryptography/MPT/MPTNode.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
using Neo.IO;
using Neo.IO.Caching;
using System;
using System.IO;

namespace Neo.Cryptography.MPT
{
public abstract class MPTNode
{
private UInt256 hash;

public virtual UInt256 Hash => hash ??= new UInt256(Crypto.Hash256(Encode()));
protected abstract NodeType Type { get; }

public void SetDirty()
{
hash = null;
}

public byte[] Encode()
{
using MemoryStream ms = new MemoryStream();
using BinaryWriter writer = new BinaryWriter(ms);

writer.Write((byte)Type);
EncodeSpecific(writer);
writer.Flush();

return ms.ToArray();
}

internal abstract void EncodeSpecific(BinaryWriter writer);

public static unsafe MPTNode Decode(ReadOnlySpan<byte> data)
{
ZhangTao1596 marked this conversation as resolved.
Show resolved Hide resolved
if (data.IsEmpty) return null;

fixed (byte* pointer = data)
{
using UnmanagedMemoryStream stream = new UnmanagedMemoryStream(pointer, data.Length);
using BinaryReader reader = new BinaryReader(stream);

MPTNode n = (MPTNode)ReflectionCache<NodeType>.CreateInstance((NodeType)reader.ReadByte());
if (n is null) throw new InvalidOperationException();

n.DecodeSpecific(reader);
return n;
}
}

internal abstract void DecodeSpecific(BinaryReader reader);

protected void WriteHash(BinaryWriter writer, UInt256 hash)
{
if (hash is null)
writer.Write((byte)0);
else
writer.WriteVarBytes(hash.ToArray());
}
}
}
16 changes: 16 additions & 0 deletions src/neo/Cryptography/MPT/MPTNodeType.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
using Neo.IO.Caching;

namespace Neo.Cryptography.MPT
{
public enum NodeType : byte
{
[ReflectionCache(typeof(BranchNode))]
BranchNode = 0x00,
[ReflectionCache(typeof(ExtensionNode))]
ExtensionNode = 0x01,
[ReflectionCache(typeof(HashNode))]
HashNode = 0x02,
[ReflectionCache(typeof(LeafNode))]
LeafNode = 0x03,
}
}
120 changes: 120 additions & 0 deletions src/neo/Cryptography/MPT/MPTTrie.Delete.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,120 @@
using Neo.IO;
using System;
using System.Collections.Generic;
using static Neo.Helper;

namespace Neo.Cryptography.MPT
{
partial class MPTTrie<TKey, TValue>
{
public bool Delete(TKey key)
{
var path = ToNibbles(key.ToArray());
if (path.Length == 0) return false;
return TryDelete(ref root, path);
}

private bool TryDelete(ref MPTNode node, ReadOnlySpan<byte> path)
{
switch (node)
{
case LeafNode _:
{
if (path.IsEmpty)
{
node = HashNode.EmptyNode;
return true;
}
return false;
}
case ExtensionNode extensionNode:
{
if (path.StartsWith(extensionNode.Key))
{
var result = TryDelete(ref extensionNode.Next, path[extensionNode.Key.Length..]);
if (!result) return false;
if (extensionNode.Next is HashNode hashNode && hashNode.IsEmpty)
{
node = extensionNode.Next;
return true;
}
if (extensionNode.Next is ExtensionNode sn)
{
extensionNode.Key = Concat(extensionNode.Key, sn.Key);
extensionNode.Next = sn.Next;
}
extensionNode.SetDirty();
PutToStore(extensionNode);
return true;
}
return false;
}
case BranchNode branchNode:
{
bool result;
if (path.IsEmpty)
{
result = TryDelete(ref branchNode.Children[BranchNode.ChildCount - 1], path);
}
else
{
result = TryDelete(ref branchNode.Children[path[0]], path[1..]);
}
if (!result) return false;
List<byte> childrenIndexes = new List<byte>(BranchNode.ChildCount);
for (int i = 0; i < BranchNode.ChildCount; i++)
{
if (branchNode.Children[i] is HashNode hn && hn.IsEmpty) continue;
childrenIndexes.Add((byte)i);
}
if (childrenIndexes.Count > 1)
{
branchNode.SetDirty();
PutToStore(branchNode);
return true;
}
var lastChildIndex = childrenIndexes[0];
var lastChild = branchNode.Children[lastChildIndex];
if (lastChildIndex == BranchNode.ChildCount - 1)
{
node = lastChild;
return true;
}
if (lastChild is HashNode hashNode)
{
lastChild = Resolve(hashNode);
if (lastChild is null) return false;
}
if (lastChild is ExtensionNode exNode)
{
exNode.Key = Concat(childrenIndexes.ToArray(), exNode.Key);
exNode.SetDirty();
PutToStore(exNode);
node = exNode;
return true;
}
node = new ExtensionNode()
{
Key = childrenIndexes.ToArray(),
Next = lastChild,
};
PutToStore(node);
return true;
}
case HashNode hashNode:
{
if (hashNode.IsEmpty)
{
return true;
}
var newNode = Resolve(hashNode);
if (newNode is null) return false;
node = newNode;
return TryDelete(ref node, path);
}
default:
return false;
}
}
}
}
Loading