2023-08-17 07:36:55 +00:00
|
|
|
/* $OpenBSD: modf_test.c,v 1.2 2023/08/13 06:57:04 miod Exp $ */
|
2023-04-30 01:15:27 +00:00
|
|
|
|
2023-08-17 07:36:55 +00:00
|
|
|
#include <assert.h>
|
2023-04-30 01:15:27 +00:00
|
|
|
#include <math.h>
|
|
|
|
|
2023-08-17 07:36:55 +00:00
|
|
|
/* Test for bug introduced in 4.4BSD modf() on sparc */
|
|
|
|
/* Public domain, 2014, Tobias Ulmer <tobiasu@tmux.org> */
|
|
|
|
|
2023-04-30 01:15:27 +00:00
|
|
|
#define BIGFLOAT (5e15) /* Number large enough to trigger the "big" case */
|
|
|
|
|
2023-08-17 07:36:55 +00:00
|
|
|
void
|
|
|
|
modf_sparc(void)
|
2023-04-30 01:15:27 +00:00
|
|
|
{
|
|
|
|
double f, i;
|
|
|
|
|
|
|
|
f = modf(BIGFLOAT, &i);
|
2023-08-17 07:36:55 +00:00
|
|
|
assert(i == BIGFLOAT);
|
|
|
|
assert(f == 0.0);
|
2023-04-30 01:15:27 +00:00
|
|
|
|
|
|
|
/* Repeat, maybe we were lucky */
|
|
|
|
f = modf(BIGFLOAT, &i);
|
2023-08-17 07:36:55 +00:00
|
|
|
assert(i == BIGFLOAT);
|
|
|
|
assert(f == 0.0);
|
2023-04-30 01:15:27 +00:00
|
|
|
|
|
|
|
/* With negative number, for good measure */
|
|
|
|
f = modf(-BIGFLOAT, &i);
|
2023-08-17 07:36:55 +00:00
|
|
|
assert(i == -BIGFLOAT);
|
|
|
|
assert(f == 0.0);
|
|
|
|
}
|
2023-04-30 01:15:27 +00:00
|
|
|
|
2023-08-17 07:36:55 +00:00
|
|
|
/* Test for modf() behaviour on Inf and Nan */
|
|
|
|
/* Written by Willemijn Coene. Public domain */
|
|
|
|
|
|
|
|
void
|
|
|
|
modf_infnan(void)
|
|
|
|
{
|
|
|
|
double f, i;
|
|
|
|
|
|
|
|
f = modf(__builtin_inf(), &i);
|
|
|
|
assert(isinf(i));
|
|
|
|
assert(signbit(i) == 0);
|
|
|
|
assert(f == 0.0);
|
|
|
|
|
|
|
|
f = modf(-__builtin_inf(), &i);
|
|
|
|
assert(isinf(i));
|
|
|
|
assert(signbit(i) != 0);
|
|
|
|
assert(f == -0.0);
|
|
|
|
|
|
|
|
f = modf(NAN, &i);
|
|
|
|
assert(isnan(i));
|
|
|
|
assert(signbit(i) == 0);
|
|
|
|
assert(isnan(f));
|
|
|
|
assert(signbit(f) == 0);
|
|
|
|
|
|
|
|
f = modf(-NAN, &i);
|
|
|
|
assert(isnan(i));
|
|
|
|
assert(signbit(i) != 0);
|
|
|
|
assert(isnan(f));
|
|
|
|
assert(signbit(f) != 0);
|
|
|
|
}
|
|
|
|
|
|
|
|
int
|
|
|
|
main(void)
|
|
|
|
{
|
|
|
|
modf_sparc();
|
|
|
|
modf_infnan();
|
2023-04-30 01:15:27 +00:00
|
|
|
}
|