summaryrefslogtreecommitdiffstats
path: root/winsup/cygwin/math/llroundl.c
blob: fc600e77dd957d125fbf9bd0c9349c974e2ea0e8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
/**
 * This file has no copyright assigned and is placed in the Public Domain.
 * This file is part of the mingw-w64 runtime package.
 * No warranty is given; refer to the file DISCLAIMER.PD within this package.
 */
#include <math.h>
#include <limits.h>
#include <errno.h>

long long
llroundl (long double x)
{
  long double res;

  if (x >= 0.0L)
    {
      res = ceill (x);
      if (res - x > 0.5L)
        res -= 1.0L;
    }
  else
    {
      res = ceill (-x);
      if (res + x > 0.5L)
        res -= 1.0L;
      res = -res;
    }
  if (!isfinite (res)
      || res > (double) LLONG_MAX
      || res < (double) LLONG_MIN)
    {
      errno = ERANGE;
      /* Undefined behaviour, so we could return anything.  */
      /* return res > 0.0 ? LLONG_MAX : LLONG_MIN;  */
    }
  return (long long) res;
}