Jordan Hrycaj cbe5131927
Simplify aristo tree deletion functionality (#2563)
* Cleaning up, removing cruft and debugging statements

* Make `aristo_delta` fluffy compatible

why:
  A sub-module that uses `chronicles` must import all possible
  modules used by a parent module that imports the sub-module.

* update TODO
2024-08-14 12:09:30 +00:00

1.1 KiB

  • Some comletions might be needed for the aristo_part module which is a re-implementation of the module supporting proof-mode/partial trees.

    • Complete partMergeStorageData(). This function might not be needed at all unless snap-sync is really revived.
    • For snap-sync, write a proof function verifying whether the partial tree is correct relative to the PartStateRef descriptor.
    • One might need to re-visit the removeCompletedNodes() module when using snap-sync proof features. The algorithm used here assumes that the list of proof nodes is rather small. Also, a right boundary leaf node is typically cleared. This needs to be re-checked when writing the proof function mentioned above.
  • aristo_nearby also qualifies for a re-write, now

  • Revisit tree deletion. The idea is to finally use ranges of nodes by exploiting the root ID prefix of a RootedVertexID. The RocksDb backend seems to support this kind of operation, see https://rocksdb.org/blog/2018/11/21/delete-range.html. For the application part there are some great ideas floating which need to be followed up some time.