#include "gr_poly.h"
#include "gr_vec.h"
int
gr_poly_submul_scalar(gr_poly_t res, const gr_poly_t poly, gr_srcptr c, gr_ctx_t ctx)
{
int status;
slong len = poly->length;
slong sz = ctx->sizeof_elem;
if (len == 0 || gr_is_zero(c, ctx) == T_TRUE) {
return GR_SUCCESS;
}
status = GR_SUCCESS;
if (res != poly) {
gr_poly_fit_length(res, len, ctx);
if (poly->length > res->length) {
status |= _gr_vec_zero(GR_ENTRY(res->coeffs, res->length, sz),
poly->length - res->length, ctx);
}
}
status |= _gr_vec_submul_scalar(res->coeffs, poly->coeffs, len, c, ctx);
_gr_poly_set_length(res, FLINT_MAX(res->length, poly->length), ctx);
_gr_poly_normalise(res, ctx);
return status;
}