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

[HOLD] feat: updatable mmr #31

Open
wants to merge 2 commits into
base: master
Choose a base branch
from

Conversation

quake
Copy link
Member

@quake quake commented Mar 10, 2023

this PR allows user to update an existing leaf node to the new value, this extends the usage of mmr, e.g. we may use mmr as an internal data structure for accumulator: https://github.com/quake/dca-bench/blob/master/src/mmr/accumulator.rs

please note that this PR breaks the store trait:

pub trait MMRStoreReadOps<Elem> {
-    fn get_elem(&self, pos: u64) -> Result<Option<Elem>>;
+    fn get(&self, pos: u64) -> Result<Option<Elem>>;
}

pub trait MMRStoreWriteOps<Elem> {
-    fn append(&mut self, pos: u64, elems: Vec<Elem>) -> Result<()>;
+    fn insert(&mut self, pos: u64, elem: Elem) -> Result<()>;
}

We need to release a new crate version together with PR #26

@quake quake requested review from yangby-cryptape and jjyr March 10, 2023 08:54
@quake quake changed the title feat: updatable mmr [HOLD] feat: updatable mmr Mar 13, 2023
@quake quake force-pushed the quake/updatable branch from 671406a to 267702a Compare July 27, 2023 01:38
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants