diff options
author | das <das@FreeBSD.org> | 2005-04-08 01:24:08 +0000 |
---|---|---|
committer | das <das@FreeBSD.org> | 2005-04-08 01:24:08 +0000 |
commit | 15bd306d7ac7202143a052f70402305a2c04968d (patch) | |
tree | 061e2bb48941ddfb39b8e3fd0b0c7710556777cf /lib/msun/src/s_roundl.c | |
parent | 4df744a4717c111c1ef2d75a7215e2a785dfc73c (diff) | |
download | FreeBSD-src-15bd306d7ac7202143a052f70402305a2c04968d.zip FreeBSD-src-15bd306d7ac7202143a052f70402305a2c04968d.tar.gz |
Add roundl(), lroundl(), and llroundl().
Diffstat (limited to 'lib/msun/src/s_roundl.c')
-rw-r--r-- | lib/msun/src/s_roundl.c | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/lib/msun/src/s_roundl.c b/lib/msun/src/s_roundl.c new file mode 100644 index 0000000..0cb688b --- /dev/null +++ b/lib/msun/src/s_roundl.c @@ -0,0 +1,51 @@ +/*- + * Copyright (c) 2003, Steven G. Kargl + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice unmodified, this list of conditions, and the following + * disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR + * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES + * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. + * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, + * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT + * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, + * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY + * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF + * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#include <sys/cdefs.h> +__FBSDID("$FreeBSD$"); + +#include <math.h> + +long double +roundl(long double x) +{ + long double t; + + if (!isfinite(x)) + return (x); + + if (x >= 0.0) { + t = ceill(x); + if (t - x > 0.5) + t -= 1.0; + return (t); + } else { + t = ceill(-x); + if (t + x > 0.5) + t -= 1.0; + return (-t); + } +} |