1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
#[macro_export]
macro_rules! ext_field_operation {
    ($extension_field:ident, $sub_field:ident, $limbs_length:ident) => {
        use zero_crypto::behave::*;
        use zero_crypto::common::*;

        ext_field_ring_operation!($extension_field, $sub_field, $limbs_length);

        impl Field for $extension_field {}

        impl Div for $extension_field {
            type Output = $extension_field;

            #[inline]
            fn div(self, rhs: $extension_field) -> $extension_field {
                let inv = rhs.invert().unwrap();
                self * inv
            }
        }

        impl DivAssign for $extension_field {
            fn div_assign(&mut self, rhs: $extension_field) {
                let inv = rhs.invert().unwrap();
                *self *= inv
            }
        }
    };
}

pub use ext_field_operation;