mirror of
https://github.com/serai-dex/serai.git
synced 2025-01-14 14:54:51 +00:00
880565cb81
Some checks failed
Coordinator Tests / build (push) Has been cancelled
crypto/ Tests / test-crypto (push) Has been cancelled
Full Stack Tests / build (push) Has been cancelled
Lint / clippy (macos-13) (push) Has been cancelled
Lint / clippy (macos-14) (push) Has been cancelled
Lint / clippy (ubuntu-latest) (push) Has been cancelled
Lint / clippy (windows-latest) (push) Has been cancelled
Lint / deny (push) Has been cancelled
Lint / fmt (push) Has been cancelled
Lint / machete (push) Has been cancelled
Message Queue Tests / build (push) Has been cancelled
Monero Tests / unit-tests (push) Has been cancelled
Reproducible Runtime / build (push) Has been cancelled
Tests / test-infra (push) Has been cancelled
common/ Tests / test-common (push) Has been cancelled
Monero Tests / integration-tests (v0.17.3.2) (push) Has been cancelled
Monero Tests / integration-tests (v0.18.2.0) (push) Has been cancelled
networks/ Tests / test-networks (push) Has been cancelled
no-std build / build (push) Has been cancelled
Processor Tests / build (push) Has been cancelled
Tests / test-substrate (push) Has been cancelled
Tests / test-serai-client (push) Has been cancelled
Preserves the fn accessors within the Monero crates so that we can use statics in some cfgs yet not all (in order to provide support for more low-memory devices) with the exception of `H` (which truly should be cached).
82 lines
2 KiB
Rust
82 lines
2 KiB
Rust
use std::{
|
|
io::Write,
|
|
env,
|
|
path::Path,
|
|
fs::{File, remove_file},
|
|
};
|
|
|
|
#[cfg(feature = "compile-time-generators")]
|
|
fn generators(prefix: &'static str, path: &str) {
|
|
use curve25519_dalek::EdwardsPoint;
|
|
|
|
use monero_generators::bulletproofs_generators;
|
|
|
|
fn serialize(generators_string: &mut String, points: &[EdwardsPoint]) {
|
|
for generator in points {
|
|
generators_string.extend(
|
|
format!(
|
|
"
|
|
curve25519_dalek::edwards::CompressedEdwardsY({:?}).decompress().unwrap(),
|
|
",
|
|
generator.compress().to_bytes()
|
|
)
|
|
.chars(),
|
|
);
|
|
}
|
|
}
|
|
|
|
let generators = bulletproofs_generators(prefix.as_bytes());
|
|
#[allow(non_snake_case)]
|
|
let mut G_str = String::new();
|
|
serialize(&mut G_str, &generators.G);
|
|
#[allow(non_snake_case)]
|
|
let mut H_str = String::new();
|
|
serialize(&mut H_str, &generators.H);
|
|
|
|
let path = Path::new(&env::var("OUT_DIR").unwrap()).join(path);
|
|
let _ = remove_file(&path);
|
|
File::create(&path)
|
|
.unwrap()
|
|
.write_all(
|
|
format!(
|
|
"
|
|
pub(crate) static GENERATORS: LazyLock<Generators> = LazyLock::new(|| Generators {{
|
|
G: std_shims::vec![
|
|
{G_str}
|
|
],
|
|
H: std_shims::vec![
|
|
{H_str}
|
|
],
|
|
}});
|
|
",
|
|
)
|
|
.as_bytes(),
|
|
)
|
|
.unwrap();
|
|
}
|
|
|
|
#[cfg(not(feature = "compile-time-generators"))]
|
|
fn generators(prefix: &'static str, path: &str) {
|
|
let path = Path::new(&env::var("OUT_DIR").unwrap()).join(path);
|
|
let _ = remove_file(&path);
|
|
File::create(&path)
|
|
.unwrap()
|
|
.write_all(
|
|
format!(
|
|
r#"
|
|
pub(crate) static GENERATORS: LazyLock<Generators> = LazyLock::new(|| {{
|
|
monero_generators::bulletproofs_generators(b"{prefix}")
|
|
}});
|
|
"#,
|
|
)
|
|
.as_bytes(),
|
|
)
|
|
.unwrap();
|
|
}
|
|
|
|
fn main() {
|
|
println!("cargo:rerun-if-changed=build.rs");
|
|
|
|
generators("bulletproof", "generators.rs");
|
|
generators("bulletproof_plus", "generators_plus.rs");
|
|
}
|