2024-08-14 08:54:44 +00:00
|
|
|
# nimbus-eth1
|
|
|
|
# Copyright (c) 2023-2024 Status Research & Development GmbH
|
|
|
|
# Licensed under either of
|
|
|
|
# * Apache License, version 2.0, ([LICENSE-APACHE](LICENSE-APACHE) or
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0)
|
|
|
|
# * MIT license ([LICENSE-MIT](LICENSE-MIT) or
|
|
|
|
# http://opensource.org/licenses/MIT)
|
|
|
|
# at your option. This file may not be copied, modified, or distributed
|
|
|
|
# except according to those terms.
|
|
|
|
|
2024-08-14 12:09:30 +00:00
|
|
|
{.push raises: [].}
|
2024-08-14 08:54:44 +00:00
|
|
|
|
2024-08-14 12:09:30 +00:00
|
|
|
import
|
|
|
|
eth/common,
|
|
|
|
".."/[aristo_desc, aristo_get, aristo_layers],
|
|
|
|
./delete_helpers
|
2024-08-14 08:54:44 +00:00
|
|
|
|
2024-08-14 12:09:30 +00:00
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
# Private heplers
|
|
|
|
# ------------------------------------------------------------------------------
|
2024-08-14 08:54:44 +00:00
|
|
|
|
2024-09-02 10:34:42 +00:00
|
|
|
proc delSubTreeNow(
|
|
|
|
db: AristoDbRef;
|
|
|
|
rvid: RootedVertexID;
|
|
|
|
): Result[void,AristoError] =
|
|
|
|
## Delete sub-tree now
|
|
|
|
let (vtx, _) = db.getVtxRc(rvid).valueOr:
|
|
|
|
if error == GetVtxNotFound:
|
|
|
|
return ok()
|
|
|
|
return err(error)
|
|
|
|
|
|
|
|
if vtx.vType == Branch:
|
|
|
|
for n in 0..15:
|
|
|
|
if vtx.bVid[n].isValid:
|
|
|
|
? db.delSubTreeNow((rvid.root,vtx.bVid[n]))
|
|
|
|
|
|
|
|
db.disposeOfVtx(rvid)
|
|
|
|
|
|
|
|
ok()
|
|
|
|
|
|
|
|
|
|
|
|
proc delStoTreeNow(
|
|
|
|
db: AristoDbRef; # Database, top layer
|
|
|
|
rvid: RootedVertexID; # Root vertex
|
|
|
|
accPath: Hash256; # Accounts cache designator
|
|
|
|
stoPath: NibblesBuf; # Current storage path
|
2024-08-14 12:09:30 +00:00
|
|
|
): Result[void,AristoError] =
|
2024-09-02 10:34:42 +00:00
|
|
|
## Implementation of *delete* sub-trie.
|
|
|
|
|
2024-08-14 12:09:30 +00:00
|
|
|
let (vtx, _) = db.getVtxRc(rvid).valueOr:
|
|
|
|
if error == GetVtxNotFound:
|
|
|
|
return ok()
|
|
|
|
return err(error)
|
|
|
|
|
|
|
|
case vtx.vType
|
|
|
|
of Branch:
|
|
|
|
for i in 0..15:
|
|
|
|
if vtx.bVid[i].isValid:
|
2024-09-02 10:34:42 +00:00
|
|
|
? db.delStoTreeNow(
|
2024-08-14 12:09:30 +00:00
|
|
|
(rvid.root, vtx.bVid[i]), accPath,
|
|
|
|
stoPath & vtx.ePfx & NibblesBuf.nibble(byte i))
|
|
|
|
|
|
|
|
of Leaf:
|
|
|
|
let stoPath = Hash256(data: (stoPath & vtx.lPfx).getBytes())
|
|
|
|
db.layersPutStoLeaf(AccountKey.mixUp(accPath, stoPath), nil)
|
|
|
|
|
|
|
|
db.disposeOfVtx(rvid)
|
|
|
|
|
2024-09-02 10:34:42 +00:00
|
|
|
ok()
|
|
|
|
|
2024-08-14 12:09:30 +00:00
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
# Public functions
|
|
|
|
# ------------------------------------------------------------------------------
|
|
|
|
|
|
|
|
proc delSubTreeImpl*(
|
2024-09-02 10:34:42 +00:00
|
|
|
db: AristoDbRef;
|
|
|
|
root: VertexID;
|
2024-08-14 12:09:30 +00:00
|
|
|
): Result[void,AristoError] =
|
2024-09-02 10:34:42 +00:00
|
|
|
db.delSubTreeNow (root,root)
|
2024-08-14 12:09:30 +00:00
|
|
|
|
|
|
|
|
|
|
|
proc delStoTreeImpl*(
|
|
|
|
db: AristoDbRef; # Database, top layer
|
|
|
|
rvid: RootedVertexID; # Root vertex
|
|
|
|
accPath: Hash256;
|
|
|
|
): Result[void,AristoError] =
|
2024-09-02 10:34:42 +00:00
|
|
|
## Implementation of *delete* sub-trie.
|
|
|
|
db.delStoTreeNow(rvid, accPath, NibblesBuf())
|
2024-08-14 12:09:30 +00:00
|
|
|
|
|
|
|
# ------------------------------------------------------------------------------
|
2024-08-14 08:54:44 +00:00
|
|
|
# End
|
2024-08-14 12:09:30 +00:00
|
|
|
# ------------------------------------------------------------------------------
|