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
31
32
33
34
35
36
37
38
39
40
41
use crate::{Bit, Integer};

impl Integer {

    pub fn pow(&self, e: &Integer) -> Result<Integer, Box<dyn std::error::Error>> {
            
        if self == &Integer::zero() {
            
            Ok(Integer::zero())

        } else if e == &Integer::zero() {
            
            Ok(Integer::one())

        } else if e.0[0] == Bit::One {
            
            Err("Non Integer result for negative exponent!")?

        } else {
            
            Ok(
                e.0
                    .iter()
                    .skip(2)
                    .fold(
                        self.clone(),
                        |acc, x| {
                            let mut result = &acc * &acc;
                            if x == &Bit::One {
                                result *= self
                            }
                            result
                        }
                    )
            )

        }

    }

}