Accepting request 603129 from devel:libraries:c_c++
- Add mpfr-4.0.1-cummulative-patch.patch. Fixes * A subtraction of two numbers of the same sign or addition of two numbers of different signs can be rounded incorrectly (and the ternary value can be incorrect) when one of the two inputs is reused as the output (destination) and all these MPFR numbers have exactly GMP_NUMB_BITS bits of precision (typically, 32 bits on 32-bit machines, 64 bits on 64-bit machines). * The mpfr_fma and mpfr_fms functions can behave incorrectly in case of internal overflow or underflow. * The result of the mpfr_sqr function can be rounded incorrectly in a rare case near underflow when the destination has exactly GMP_NUMB_BITS bits of precision (typically, 32 bits on 32-bit machines, 64 bits on 64-bit machines) and the input has at most GMP_NUMB_BITS bits of precision. * The behavior and documentation of the mpfr_get_str function are inconsistent concerning the minimum precision (this is related to the change of the minimum precision from 2 to 1 in MPFR 4.0.0). The get_str patch fixes this issue in the following way: the value 1 can now be provided for n (4th argument of mpfr_get_str); if n = 0, then the number of significant digits in the output string can now be 1, as already implied by the documentation (but the code was increasing it to 2). * The mpfr_cmp_q function can behave incorrectly when the rational (mpq_t) number has a null denominator. * The mpfr_inp_str and mpfr_out_str functions might behave incorrectly when the stream is a null pointer: the stream is replaced by stdin and stdout, respectively. This behavior is useless, not documented (thus incorrect in case a null pointer would have a special meaning), and not consistent with other input/output functions. OBS-URL: https://build.opensuse.org/request/show/603129 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/mpfr?expand=0&rev=48
This commit is contained in:
commit
402c7c6824
1974
mpfr-4.0.1-cummulative-patch.patch
Normal file
1974
mpfr-4.0.1-cummulative-patch.patch
Normal file
File diff suppressed because it is too large
Load Diff
34
mpfr.changes
34
mpfr.changes
@ -1,3 +1,37 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Wed May 2 08:48:20 UTC 2018 - rguenther@suse.com
|
||||||
|
|
||||||
|
- Add mpfr-4.0.1-cummulative-patch.patch. Fixes
|
||||||
|
* A subtraction of two numbers of the same sign or addition of two
|
||||||
|
numbers of different signs can be rounded incorrectly (and the
|
||||||
|
ternary value can be incorrect) when one of the two inputs is
|
||||||
|
reused as the output (destination) and all these MPFR numbers
|
||||||
|
have exactly GMP_NUMB_BITS bits of precision (typically, 32 bits
|
||||||
|
on 32-bit machines, 64 bits on 64-bit machines).
|
||||||
|
* The mpfr_fma and mpfr_fms functions can behave incorrectly in case
|
||||||
|
of internal overflow or underflow.
|
||||||
|
* The result of the mpfr_sqr function can be rounded incorrectly
|
||||||
|
in a rare case near underflow when the destination has exactly
|
||||||
|
GMP_NUMB_BITS bits of precision (typically, 32 bits on 32-bit
|
||||||
|
machines, 64 bits on 64-bit machines) and the input has at most
|
||||||
|
GMP_NUMB_BITS bits of precision.
|
||||||
|
* The behavior and documentation of the mpfr_get_str function are
|
||||||
|
inconsistent concerning the minimum precision (this is related to
|
||||||
|
the change of the minimum precision from 2 to 1 in MPFR 4.0.0). The
|
||||||
|
get_str patch fixes this issue in the following way: the value 1
|
||||||
|
can now be provided for n (4th argument of mpfr_get_str); if n = 0,
|
||||||
|
then the number of significant digits in the output string can now
|
||||||
|
be 1, as already implied by the documentation (but the code was
|
||||||
|
increasing it to 2).
|
||||||
|
* The mpfr_cmp_q function can behave incorrectly when the rational
|
||||||
|
(mpq_t) number has a null denominator.
|
||||||
|
* The mpfr_inp_str and mpfr_out_str functions might behave
|
||||||
|
incorrectly when the stream is a null pointer: the stream is
|
||||||
|
replaced by stdin and stdout, respectively. This behavior is
|
||||||
|
useless, not documented (thus incorrect in case a null pointer
|
||||||
|
would have a special meaning), and not consistent with other
|
||||||
|
input/output functions.
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Wed Feb 7 18:50:06 UTC 2018 - astieger@suse.com
|
Wed Feb 7 18:50:06 UTC 2018 - astieger@suse.com
|
||||||
|
|
||||||
|
@ -27,6 +27,7 @@ Source0: http://www.mpfr.org/mpfr-%{version}/mpfr-%{version}.tar.bz2
|
|||||||
Source1: http://www.mpfr.org/mpfr-%{version}/mpfr-%{version}.tar.bz2.asc
|
Source1: http://www.mpfr.org/mpfr-%{version}/mpfr-%{version}.tar.bz2.asc
|
||||||
Source2: %{name}.keyring
|
Source2: %{name}.keyring
|
||||||
Source3: baselibs.conf
|
Source3: baselibs.conf
|
||||||
|
Patch: mpfr-4.0.1-cummulative-patch.patch
|
||||||
BuildRequires: gmp-devel
|
BuildRequires: gmp-devel
|
||||||
BuildRequires: pkgconfig
|
BuildRequires: pkgconfig
|
||||||
|
|
||||||
@ -66,6 +67,7 @@ based on the GMP multiple-precision library.
|
|||||||
|
|
||||||
%prep
|
%prep
|
||||||
%setup -q
|
%setup -q
|
||||||
|
%patch -p1
|
||||||
|
|
||||||
%build
|
%build
|
||||||
%configure \
|
%configure \
|
||||||
|
Loading…
Reference in New Issue
Block a user