+ allow mp_shrink to shrink initialized, but empty MPI's
This commit is contained in:
parent
eec4e5c546
commit
7d14fd029c
@ -19,12 +19,17 @@
|
|||||||
int mp_shrink (mp_int * a)
|
int mp_shrink (mp_int * a)
|
||||||
{
|
{
|
||||||
mp_digit *tmp;
|
mp_digit *tmp;
|
||||||
if (a->alloc != a->used && a->used > 0) {
|
int used = 1;
|
||||||
if ((tmp = OPT_CAST(mp_digit) XREALLOC (a->dp, sizeof (mp_digit) * a->used)) == NULL) {
|
|
||||||
|
if(a->used > 0)
|
||||||
|
used = a->used;
|
||||||
|
|
||||||
|
if (a->alloc != used) {
|
||||||
|
if ((tmp = OPT_CAST(mp_digit) XREALLOC (a->dp, sizeof (mp_digit) * used)) == NULL) {
|
||||||
return MP_MEM;
|
return MP_MEM;
|
||||||
}
|
}
|
||||||
a->dp = tmp;
|
a->dp = tmp;
|
||||||
a->alloc = a->used;
|
a->alloc = used;
|
||||||
}
|
}
|
||||||
return MP_OKAY;
|
return MP_OKAY;
|
||||||
}
|
}
|
||||||
|
@ -7217,12 +7217,17 @@ int mp_set_int (mp_int * a, unsigned long b)
|
|||||||
int mp_shrink (mp_int * a)
|
int mp_shrink (mp_int * a)
|
||||||
{
|
{
|
||||||
mp_digit *tmp;
|
mp_digit *tmp;
|
||||||
if (a->alloc != a->used && a->used > 0) {
|
int used = 1;
|
||||||
if ((tmp = OPT_CAST(mp_digit) XREALLOC (a->dp, sizeof (mp_digit) * a->used)) == NULL) {
|
|
||||||
|
if(a->used > 0)
|
||||||
|
used = a->used;
|
||||||
|
|
||||||
|
if (a->alloc != used) {
|
||||||
|
if ((tmp = OPT_CAST(mp_digit) XREALLOC (a->dp, sizeof (mp_digit) * used)) == NULL) {
|
||||||
return MP_MEM;
|
return MP_MEM;
|
||||||
}
|
}
|
||||||
a->dp = tmp;
|
a->dp = tmp;
|
||||||
a->alloc = a->used;
|
a->alloc = used;
|
||||||
}
|
}
|
||||||
return MP_OKAY;
|
return MP_OKAY;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user