summaryrefslogtreecommitdiffstats
path: root/vendor/primeorder/src/lib.rs
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/primeorder/src/lib.rs')
-rw-r--r--vendor/primeorder/src/lib.rs46
1 files changed, 46 insertions, 0 deletions
diff --git a/vendor/primeorder/src/lib.rs b/vendor/primeorder/src/lib.rs
new file mode 100644
index 000000000..0847a995a
--- /dev/null
+++ b/vendor/primeorder/src/lib.rs
@@ -0,0 +1,46 @@
+#![no_std]
+#![cfg_attr(docsrs, feature(doc_auto_cfg))]
+#![doc(
+ html_logo_url = "https://raw.githubusercontent.com/RustCrypto/meta/master/logo.svg",
+ html_favicon_url = "https://raw.githubusercontent.com/RustCrypto/meta/master/logo.svg"
+)]
+#![forbid(unsafe_code)]
+#![warn(missing_docs, rust_2018_idioms, unused_qualifications)]
+#![doc = include_str!("../README.md")]
+
+#[cfg(feature = "dev")]
+pub mod dev;
+pub mod point_arithmetic;
+
+mod affine;
+mod field;
+mod projective;
+
+pub use crate::{affine::AffinePoint, projective::ProjectivePoint};
+pub use elliptic_curve::{self, point::Double, Field, FieldBytes, PrimeCurve, PrimeField};
+
+use elliptic_curve::CurveArithmetic;
+
+/// Parameters for elliptic curves of prime order which can be described by the
+/// short Weierstrass equation.
+pub trait PrimeCurveParams:
+ PrimeCurve
+ + CurveArithmetic
+ + CurveArithmetic<AffinePoint = AffinePoint<Self>>
+ + CurveArithmetic<ProjectivePoint = ProjectivePoint<Self>>
+{
+ /// Base field element type.
+ type FieldElement: PrimeField<Repr = FieldBytes<Self>>;
+
+ /// [Point arithmetic](point_arithmetic) implementation, might be optimized for this specific curve
+ type PointArithmetic: point_arithmetic::PointArithmetic<Self>;
+
+ /// Coefficient `a` in the curve equation.
+ const EQUATION_A: Self::FieldElement;
+
+ /// Coefficient `b` in the curve equation.
+ const EQUATION_B: Self::FieldElement;
+
+ /// Generator point's affine coordinates: (x, y).
+ const GENERATOR: (Self::FieldElement, Self::FieldElement);
+}