1 /****************************************************************
2 *
3 * The author of this software is David M. Gay.
4 *
5 * Copyright (c) 1991, 1996 by Lucent Technologies.
6 *
7 * Permission to use, copy, modify, and distribute this software for any
8 * purpose without fee is hereby granted, provided that this entire notice
9 * is included in all copies of any software which is or includes a copy
10 * or modification of this software and in all copies of the supporting
11 * documentation for such software.
12 *
13 * THIS SOFTWARE IS BEING PROVIDED "AS IS", WITHOUT ANY EXPRESS OR IMPLIED
14 * WARRANTY. IN PARTICULAR, NEITHER THE AUTHOR NOR LUCENT MAKES ANY
15 * REPRESENTATION OR WARRANTY OF ANY KIND CONCERNING THE MERCHANTABILITY
16 * OF THIS SOFTWARE OR ITS FITNESS FOR ANY PARTICULAR PURPOSE.
17 *
18 ***************************************************************/
19
20 /* g_fmt(buf,x) stores the closest decimal approximation to x in buf;
21 * it suffices to declare buf
22 * char buf[32];
23 */
24
25 #include "dmg_fp.h"
26
27 namespace dmg_fp {
28
29 char *
g_fmt(register char * b,double x)30 g_fmt(register char *b, double x)
31 {
32 register int i, k;
33 register char *s;
34 int decpt, j, sign;
35 char *b0, *s0, *se;
36
37 b0 = b;
38 #ifdef IGNORE_ZERO_SIGN
39 if (!x) {
40 *b++ = '0';
41 *b = 0;
42 goto done;
43 }
44 #endif
45 s = s0 = dtoa(x, 0, 0, &decpt, &sign, &se);
46 if (sign)
47 *b++ = '-';
48 if (decpt == 9999) /* Infinity or Nan */ {
49 for(*b = *s++; *b++; *b = *s++) {}
50 goto done0;
51 }
52 if (decpt <= -4 || decpt > se - s + 5) {
53 *b++ = *s++;
54 if (*s) {
55 *b++ = '.';
56 for(*b = *s++; *b; *b = *s++)
57 b++;
58 }
59 *b++ = 'e';
60 /* sprintf(b, "%+.2d", decpt - 1); */
61 if (--decpt < 0) {
62 *b++ = '-';
63 decpt = -decpt;
64 }
65 else
66 *b++ = '+';
67 for(j = 2, k = 10; 10*k <= decpt; j++, k *= 10) {}
68 for(;;) {
69 i = decpt / k;
70 *b++ = (char)i + '0';
71 if (--j <= 0)
72 break;
73 decpt -= i*k;
74 decpt *= 10;
75 }
76 *b = 0;
77 }
78 else if (decpt <= 0) {
79 *b++ = '.';
80 for(; decpt < 0; decpt++)
81 *b++ = '0';
82 for(*b = *s++; *b++; *b = *s++) {}
83 }
84 else {
85 for(*b = *s++; *b; *b = *s++) {
86 b++;
87 if (--decpt == 0 && *s)
88 *b++ = '.';
89 }
90 for(; decpt > 0; decpt--)
91 *b++ = '0';
92 *b = 0;
93 }
94 done0:
95 freedtoa(s0);
96 #ifdef IGNORE_ZERO_SIGN
97 done:
98 #endif
99 return b0;
100 }
101
102 } // namespace dmg_fp
103