Standard library

The standard library is currently located in a built-in module called std. The library contains three modules for now:

  • crypto - cryptographic and hash functions
    • ecc - elliptic curve cryptography
    • schnorr - EDDSA signatyre verification
  • convert - bit array conversion functions
  • array - array processing functions
  • ff - finite field functions

All the function signatures are listed in Appendix E.

Standard library items can be used directly or be imported with use:

use std::crypto::sha256;

fn main(preimage: [bool; 256]) -> ([bool; 256], (field, field)) {
    let input_sha256 = sha256(preimage); // through import

    let input_pedersen = std::crypto::pedersen(preimage); // directly

    (input_sha256, input_pedersen)