diff options
Diffstat (limited to 'zkvms/zkwasm/guest/src/lib.rs')
| -rw-r--r-- | zkvms/zkwasm/guest/src/lib.rs | 54 |
1 files changed, 54 insertions, 0 deletions
diff --git a/zkvms/zkwasm/guest/src/lib.rs b/zkvms/zkwasm/guest/src/lib.rs new file mode 100644 index 0000000..5c00fc0 --- /dev/null +++ b/zkvms/zkwasm/guest/src/lib.rs @@ -0,0 +1,54 @@ +use wasm_bindgen::prelude::wasm_bindgen; +use wrapper_macro::make_wrapper; +// https://github.com/DelphinusLab/zkWasm-rust/blob/main/src/lib.rs +use zkwasm_rust_sdk::{require, wasm_input, wasm_output}; + +fn read_private() -> u64 { + unsafe { wasm_input(0) } +} + +fn assert(cond: bool) { + unsafe { require(cond); } +} + +fn write(value: u64) { + unsafe { wasm_output(value); } +} + +static VERTICES: u64 = 10; + +macro_rules! read { + // HACK for graph_coloring + (Vec , u32) => { + { + let mut ret = Vec::new(); + for _ in 0..2 { + ret.push(read!(u32)); + } + ret + } + }; + // Vec<Vec<...<Vec<primitive>>>> is converted by entrypoint_expr! to + // Vec,Vec,...,Vec,primitive + (Vec , $($type:tt)*) => { + { + let mut ret = Vec::new(); + for _ in 0..VERTICES { + ret.push(read!($($type)*)); + } + ret + } + }; + (bool) => { + (read_private() != 0) + }; + // Has to be primitive! + ($type:ty) => { + (read_private() as $type) + }; +} + +#[wasm_bindgen] +pub fn zkmain() { + zkp::entrypoint_expr!() +} |
