#![cfg_attr(not(feature = "std"), no_std)]
#![forbid(unsafe_code)]
#![warn(
// Enable sets of warnings
clippy::all,
clippy::pedantic,
clippy::cargo,
rust_2018_idioms,
future_incompatible,
unused,
// Additional unused warnings (not included in `unused`)
unused_lifetimes,
unused_qualifications,
unused_results,
// Additional misc. warnings
anonymous_parameters,
deprecated_in_future,
elided_lifetimes_in_paths,
explicit_outlives_requirements,
keyword_idents,
macro_use_extern_crate,
// missing_docs,
missing_doc_code_examples,
private_doc_tests,
single_use_lifetimes,
trivial_casts,
trivial_numeric_casts,
unreachable_pub,
unsafe_code,
variant_size_differences
)]
#![cfg_attr(feature = "std", warn(missing_debug_implementations,))]
#![allow(clippy::multiple_crate_versions)]
#![allow(clippy::multiple_crate_versions)]
#![allow(clippy::must_use_candidate)]
mod curve;
mod jacobian;
#[cfg(any(test, feature = "proptest"))]
mod proptest;
mod scalar_field;
mod wnaf;
#[cfg(not(feature = "std"))]
extern crate no_std_compat as std;
pub use curve::Affine;
pub use jacobian::Jacobian;
pub use scalar_field::{Element as ScalarFieldElement, Order};
pub use wnaf::{base_mul, double_base_mul, double_mul, mul, window_table_affine};
use zkp_macros_decl::u256h;
use zkp_primefield::FieldElement;
use zkp_u256::U256;
pub const BETA: FieldElement = FieldElement::from_montgomery_const(u256h!(
"013931651774247fab8a1e002a41f9476725f2237aab9006359ddd67b59a21ca"
));
pub const GENERATOR: Affine = Affine::Point {
x: FieldElement::from_montgomery_const(u256h!(
"033840300bf6cec10429bf5184041c7b51a9bf65d4403deac9019623cf0273dd"
)),
y: FieldElement::from_montgomery_const(u256h!(
"05a0e71610f55329fbd89a97cf4b33ad0939e3442869bbe7569d0da34235308a"
)),
};