#include "fmpz.h"
#include "fq_zech_mpoly_factor.h"
void fq_zech_mpoly_factor_realloc(fq_zech_mpoly_factor_t f, slong alloc,
const fq_zech_mpoly_ctx_t ctx)
{
slong i;
if (alloc <= 0)
{
fq_zech_mpoly_factor_clear(f, ctx);
fq_zech_mpoly_factor_init(f, ctx);
return;
}
if (f->alloc > 0)
{
if (f->alloc > alloc)
{
for (i = alloc; i < f->alloc; i++)
{
fq_zech_mpoly_clear(f->poly + i, ctx);
fmpz_clear(f->exp + i);
}
f->exp = (fmpz *) flint_realloc(f->exp, alloc * sizeof(fmpz));
f->poly = (fq_zech_mpoly_struct *) flint_realloc(f->poly,
alloc * sizeof(fq_zech_mpoly_struct));
}
else if (f->alloc < alloc)
{
f->exp = (fmpz *) flint_realloc(f->exp, alloc * sizeof(fmpz));
f->poly = (fq_zech_mpoly_struct *) flint_realloc(f->poly,
alloc * sizeof(fq_zech_mpoly_struct));
for (i = f->alloc; i < alloc; i++)
{
fq_zech_mpoly_init(f->poly + i, ctx);
fmpz_init(f->exp + i);
}
}
}
else
{
f->exp = (fmpz *) flint_calloc(alloc, sizeof(fmpz));
f->poly = (fq_zech_mpoly_struct *) flint_malloc(alloc *
sizeof(fq_zech_mpoly_struct));
for (i = 0; i < alloc; i++)
fq_zech_mpoly_init(f->poly + i, ctx);
}
f->alloc = alloc;
}