summaryrefslogtreecommitdiff
path: root/libc/stdlib/__adjust.c
diff options
context:
space:
mode:
authorMarcus Huderle <huderlem@gmail.com>2017-12-27 16:22:00 -0600
committerGitHub <noreply@github.com>2017-12-27 16:22:00 -0600
commit6b611a3046a694d3972f2aa4df90d3ef78801217 (patch)
tree05f295c00cbbc1d5987a05da37e746fb841d4d83 /libc/stdlib/__adjust.c
parent58c860d6c48324eba66dd19540db5584d832cf58 (diff)
parentd88495e3f4061a411e654c7307aa94ac8a98c94b (diff)
Merge pull request #13 from ProjectRevoTPP/libc
add libc building to agbcc.
Diffstat (limited to 'libc/stdlib/__adjust.c')
-rw-r--r--libc/stdlib/__adjust.c44
1 files changed, 44 insertions, 0 deletions
diff --git a/libc/stdlib/__adjust.c b/libc/stdlib/__adjust.c
new file mode 100644
index 0000000..d5c7075
--- /dev/null
+++ b/libc/stdlib/__adjust.c
@@ -0,0 +1,44 @@
+/*
+ * return (*acc) scaled by 10**dexp.
+ */
+
+#include <_ansi.h>
+#include <reent.h>
+#include "std.h"
+
+#define abs(x) (((x) < 0) ? -(x) : (x))
+
+double
+_DEFUN (__adjust, (ptr, acc, dexp, sign),
+ struct _reent *ptr _AND
+ double *acc _AND
+ int dexp _AND
+ int sign)
+ /* *acc the 64 bit accumulator */
+ /* dexp decimal exponent */
+ /* sign sign flag */
+{
+ double r;
+
+ if (dexp > MAXE)
+ {
+ ptr->_errno = ERANGE;
+ return (sign) ? -HUGE_VAL : HUGE_VAL;
+ }
+ else if (dexp < MINE)
+ {
+ ptr->_errno = ERANGE;
+ return 0.0;
+ }
+
+ r = *acc;
+ if (sign)
+ r = -r;
+ if (dexp == 0)
+ return r;
+
+ if (dexp < 0)
+ return r / __exp10 (abs (dexp));
+ else
+ return r * __exp10 (dexp);
+}