{
mpd_ssize_t size;
+ assert(!mpd_isspecial(a));
assert(n >= 0);
if (mpd_iszerocoeff(a) || n == 0) {
_mpd_baseshiftl(result->data, a->data, size, a->len, n);
mpd_copy_flags(result, a);
- result->len = size;
result->exp = a->exp;
result->digits = a->digits+n;
+ result->len = size;
return 1;
}
}
/*
- * Same as mpd_qshiftr(), but 'result' is a static array. It is the
- * caller's responsibility to make sure that the array is big enough.
- * The function cannot fail.
+ * Same as mpd_qshiftr(), but 'result' is an mpd_t with a static coefficient.
+ * It is the caller's responsibility to ensure that the coefficient is big
+ * enough. The function cannot fail.
*/
mpd_uint_t
mpd_qsshiftr(mpd_t *result, const mpd_t *a, mpd_ssize_t n)
mpd_uint_t rnd;
mpd_ssize_t size;
+ assert(!mpd_isspecial(a));
assert(n >= 0);
if (mpd_iszerocoeff(a) || n == 0) {
if (n >= a->digits) {
rnd = _mpd_get_rnd(a->data, a->len, (n==a->digits));
mpd_zerocoeff(result);
- result->digits = 1;
- size = 1;
}
else {
result->digits = a->digits-n;
size = mpd_digits_to_size(result->digits);
rnd = _mpd_baseshiftr(result->data, a->data, a->len, n);
+ result->len = size;
}
mpd_copy_flags(result, a);
result->exp = a->exp;
- result->len = size;
return rnd;
}
mpd_uint_t rnd;
mpd_ssize_t size;
+ assert(!mpd_isspecial(result));
assert(n >= 0);
if (mpd_iszerocoeff(result) || n == 0) {
if (n >= result->digits) {
rnd = _mpd_get_rnd(result->data, result->len, (n==result->digits));
mpd_zerocoeff(result);
- result->digits = 1;
- size = 1;
}
else {
rnd = _mpd_baseshiftr(result->data, result->data, result->len, n);
size = mpd_digits_to_size(result->digits);
/* reducing the size cannot fail */
mpd_qresize(result, size, &dummy);
+ result->len = size;
}
- result->len = size;
-
return rnd;
}
mpd_uint_t rnd;
mpd_ssize_t size;
+ assert(!mpd_isspecial(a));
assert(n >= 0);
if (mpd_iszerocoeff(a) || n == 0) {
if (n >= a->digits) {
rnd = _mpd_get_rnd(a->data, a->len, (n==a->digits));
mpd_zerocoeff(result);
- result->digits = 1;
- size = 1;
}
else {
result->digits = a->digits-n;
}
rnd = _mpd_baseshiftr(result->data, a->data, a->len, n);
}
+ result->len = size;
}
mpd_copy_flags(result, a);
result->exp = a->exp;
- result->len = size;
return rnd;
}
newsize = _mpd_real_size(q->data, newsize);
/* resize to smaller cannot fail */
mpd_qresize(q, newsize, status);
+ mpd_set_flags(q, sign_a^sign_b);
q->len = newsize;
mpd_setdigits(q);
exp += shift;
}
- mpd_set_flags(q, sign_a^sign_b);
q->exp = exp;