mirror of
https://github.com/vacp2p/zerokit.git
synced 2025-01-18 10:32:22 +00:00
chore(rln): expose leaves_set api (#213)
This commit is contained in:
parent
b51896c3a7
commit
f8fc455d08
@ -261,6 +261,12 @@ pub extern "C" fn get_leaf(ctx: *mut RLN, index: usize, output_buffer: *mut Buff
|
|||||||
call_with_output_arg!(ctx, get_leaf, output_buffer, index)
|
call_with_output_arg!(ctx, get_leaf, output_buffer, index)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[allow(clippy::not_unsafe_ptr_arg_deref)]
|
||||||
|
#[no_mangle]
|
||||||
|
pub extern "C" fn leaves_set(ctx: *mut RLN) -> usize {
|
||||||
|
ctx.process().leaves_set()
|
||||||
|
}
|
||||||
|
|
||||||
#[allow(clippy::not_unsafe_ptr_arg_deref)]
|
#[allow(clippy::not_unsafe_ptr_arg_deref)]
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
pub extern "C" fn set_next_leaf(ctx: *mut RLN, input_buffer: *const Buffer) -> bool {
|
pub extern "C" fn set_next_leaf(ctx: *mut RLN, input_buffer: *const Buffer) -> bool {
|
||||||
|
@ -143,6 +143,8 @@ mod test {
|
|||||||
assert!(success, "RLN object creation failed");
|
assert!(success, "RLN object creation failed");
|
||||||
let rln_pointer = unsafe { &mut *rln_pointer.assume_init() };
|
let rln_pointer = unsafe { &mut *rln_pointer.assume_init() };
|
||||||
|
|
||||||
|
assert_eq!(rln_pointer.leaves_set(), 0);
|
||||||
|
|
||||||
// We generate a vector of random leaves
|
// We generate a vector of random leaves
|
||||||
let mut leaves: Vec<Fr> = Vec::new();
|
let mut leaves: Vec<Fr> = Vec::new();
|
||||||
let mut rng = thread_rng();
|
let mut rng = thread_rng();
|
||||||
@ -159,6 +161,7 @@ mod test {
|
|||||||
let input_buffer = &Buffer::from(leaves_ser.as_ref());
|
let input_buffer = &Buffer::from(leaves_ser.as_ref());
|
||||||
let success = init_tree_with_leaves(rln_pointer, input_buffer);
|
let success = init_tree_with_leaves(rln_pointer, input_buffer);
|
||||||
assert!(success, "init tree with leaves call failed");
|
assert!(success, "init tree with leaves call failed");
|
||||||
|
assert_eq!(rln_pointer.leaves_set(), no_of_leaves);
|
||||||
|
|
||||||
// We get the root of the tree obtained adding leaves in batch
|
// We get the root of the tree obtained adding leaves in batch
|
||||||
let mut output_buffer = MaybeUninit::<Buffer>::uninit();
|
let mut output_buffer = MaybeUninit::<Buffer>::uninit();
|
||||||
|
Loading…
x
Reference in New Issue
Block a user