aboutsummaryrefslogtreecommitdiff
path: root/src/libtommath/mp_complement.c
blob: c16e25f9dae02dbc8b396aa766eee8fa9e477443 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
#include "tommath_private.h"
#ifdef MP_COMPLEMENT_C
/* LibTomMath, multiple-precision integer library -- Tom St Denis */
/* SPDX-License-Identifier: Unlicense */

/* b = ~a */
mp_err mp_complement(const mp_int *a, mp_int *b)
{
   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