cdiv_qr.c revision 1.1 1 1.1 mrg /* mpz_cdiv_qr -- Division rounding the quotient towards +infinity. The
2 1.1 mrg remainder gets the opposite sign as the denominator.
3 1.1 mrg
4 1.1 mrg Copyright 1994, 1995, 1996, 2000, 2001, 2005 Free Software Foundation, Inc.
5 1.1 mrg
6 1.1 mrg This file is part of the GNU MP Library.
7 1.1 mrg
8 1.1 mrg The GNU MP Library is free software; you can redistribute it and/or modify
9 1.1 mrg it under the terms of the GNU Lesser General Public License as published by
10 1.1 mrg the Free Software Foundation; either version 3 of the License, or (at your
11 1.1 mrg option) any later version.
12 1.1 mrg
13 1.1 mrg The GNU MP Library is distributed in the hope that it will be useful, but
14 1.1 mrg WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
15 1.1 mrg or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
16 1.1 mrg License for more details.
17 1.1 mrg
18 1.1 mrg You should have received a copy of the GNU Lesser General Public License
19 1.1 mrg along with the GNU MP Library. If not, see http://www.gnu.org/licenses/. */
20 1.1 mrg
21 1.1 mrg #include "gmp.h"
22 1.1 mrg #include "gmp-impl.h"
23 1.1 mrg
24 1.1 mrg void
25 1.1 mrg mpz_cdiv_qr (mpz_ptr quot, mpz_ptr rem, mpz_srcptr dividend, mpz_srcptr divisor)
26 1.1 mrg {
27 1.1 mrg mp_size_t divisor_size = divisor->_mp_size;
28 1.1 mrg mp_size_t xsize;
29 1.1 mrg mpz_t temp_divisor; /* N.B.: lives until function returns! */
30 1.1 mrg TMP_DECL;
31 1.1 mrg
32 1.1 mrg TMP_MARK;
33 1.1 mrg
34 1.1 mrg /* We need the original value of the divisor after the quotient and
35 1.1 mrg remainder have been preliminary calculated. We have to copy it to
36 1.1 mrg temporary space if it's the same variable as either QUOT or REM. */
37 1.1 mrg if (quot == divisor || rem == divisor)
38 1.1 mrg {
39 1.1 mrg MPZ_TMP_INIT (temp_divisor, ABS (divisor_size));
40 1.1 mrg mpz_set (temp_divisor, divisor);
41 1.1 mrg divisor = temp_divisor;
42 1.1 mrg }
43 1.1 mrg
44 1.1 mrg xsize = dividend->_mp_size ^ divisor_size;;
45 1.1 mrg mpz_tdiv_qr (quot, rem, dividend, divisor);
46 1.1 mrg
47 1.1 mrg if (xsize >= 0 && rem->_mp_size != 0)
48 1.1 mrg {
49 1.1 mrg mpz_add_ui (quot, quot, 1L);
50 1.1 mrg mpz_sub (rem, rem, divisor);
51 1.1 mrg }
52 1.1 mrg
53 1.1 mrg TMP_FREE;
54 1.1 mrg }
55