Commit 3b710fbd7e4d67e4326670019936805c10caadf3

Daniel Mendler 2019-11-03T11:00:33

simplify mp_complement

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
diff --git a/mp_complement.c b/mp_complement.c
index ad6bed3..c16e25f 100644
--- a/mp_complement.c
+++ b/mp_complement.c
@@ -6,7 +6,8 @@
 /* b = ~a */
 mp_err mp_complement(const mp_int *a, mp_int *b)
 {
-   mp_err err = mp_neg(a, b);
-   return (err == MP_OKAY) ? mp_sub_d(b, 1uL, b) : err;
+   mp_int a_ = *a;
+   a_.sign = ((a_.sign == MP_ZPOS) && !mp_iszero(a)) ? MP_NEG : MP_ZPOS;
+   return mp_sub_d(&a_, 1uL, b);
 }
 #endif