1 /* $NetBSD: gdtoa.h,v 1.10 2013/04/18 21:54:10 joerg Exp $ */
2 
3 /****************************************************************
4 
5 The author of this software is David M. Gay.
6 
7 Copyright (C) 1998 by Lucent Technologies
8 All Rights Reserved
9 
10 Permission to use, copy, modify, and distribute this software and
11 its documentation for any purpose and without fee is hereby
12 granted, provided that the above copyright notice appear in all
13 copies and that both that the copyright notice and this
14 permission notice and warranty disclaimer appear in supporting
15 documentation, and that the name of Lucent or any of its entities
16 not be used in advertising or publicity pertaining to
17 distribution of the software without specific, written prior
18 permission.
19 
20 LUCENT DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE,
21 INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS.
22 IN NO EVENT SHALL LUCENT OR ANY OF ITS ENTITIES BE LIABLE FOR ANY
23 SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
24 WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER
25 IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
26 ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF
27 THIS SOFTWARE.
28 
29 ****************************************************************/
30 
31 /* Please send bug reports to David M. Gay (dmg at acm dot org,
32  * with " at " changed at "@" and " dot " changed to ".").	*/
33 
34 #ifndef GDTOA_H_INCLUDED
35 #define GDTOA_H_INCLUDED
36 
37 #include "arith.h"
38 #include <stddef.h> /* for size_t */
39 #include <stdint.h>
40 
41 #ifndef __LOCALE_T_DECLARED
42 typedef struct _locale		*locale_t;
43 #define __LOCALE_T_DECLARED
44 #endif
45 
46 #ifndef Long
47 #define Long int32_t
48 #endif
49 #ifndef ULong
50 #define ULong uint32_t
51 #endif
52 #ifndef UShort
53 #define UShort uint16_t
54 #endif
55 
56 #ifndef ANSI
57 #ifdef KR_headers
58 #define ANSI(x) ()
59 #define Void /*nothing*/
60 #else
61 #define ANSI(x) x
62 #define Void void
63 #endif
64 #endif /* ANSI */
65 
66 #ifndef CONST
67 #ifdef KR_headers
68 #define CONST /* blank */
69 #else
70 #define CONST const
71 #endif
72 #endif /* CONST */
73 
74  enum {	/* return values from strtodg */
75 	STRTOG_Zero	= 0,
76 	STRTOG_Normal	= 1,
77 	STRTOG_Denormal	= 2,
78 	STRTOG_Infinite	= 3,
79 	STRTOG_NaN	= 4,
80 	STRTOG_NaNbits	= 5,
81 	STRTOG_NoNumber	= 6,
82 	STRTOG_Retmask	= 7,
83 
84 	/* The following may be or-ed into one of the above values. */
85 
86 	STRTOG_Neg	= 0x08, /* does not affect STRTOG_Inexlo or STRTOG_Inexhi */
87 	STRTOG_Inexlo	= 0x10,	/* returned result rounded toward zero */
88 	STRTOG_Inexhi	= 0x20, /* returned result rounded away from zero */
89 	STRTOG_Inexact	= 0x30,
90 	STRTOG_Underflow= 0x40,
91 	STRTOG_Overflow	= 0x80,
92 	STRTOG_NoMemory = 0x100
93 	};
94 
95  typedef struct
96 FPI {
97 	int nbits;
98 	int emin;
99 	int emax;
100 	int rounding;
101 	int sudden_underflow;
102 	} FPI;
103 
104 enum {	/* FPI.rounding values: same as FLT_ROUNDS */
105 	FPI_Round_zero = 0,
106 	FPI_Round_near = 1,
107 	FPI_Round_up = 2,
108 	FPI_Round_down = 3
109 	};
110 
111 #ifdef __cplusplus
112 extern "C" {
113 #endif
114 
115 #define	dtoa		__dtoa
116 #define	gdtoa		__gdtoa
117 #define	ldtoa		__ldtoa
118 #define	hldtoa		__hldtoa
119 #define	hdtoa		__hdtoa
120 #define	freedtoa	__freedtoa
121 #define	strtodg		__strtodg_D2A
122 #define	strtopQ		__strtopQ_D2A
123 #define	strtopx		__strtopx_D2A
124 #define	strtopxL	__strtopxL_D2A
125 #define	strtord		__strtord_D2A
126 
127 extern char* dtoa  ANSI((double d, int mode, int ndigits, int *decpt,
128 			int *sign, char **rve));
129 extern char* hdtoa ANSI((double d, const char *xdigs, int ndigits, int *decpt,
130 			int *sign, char **rve));
131 extern char* ldtoa ANSI((long double *ld, int mode, int ndigits, int *decpt,
132 			int *sign, char **rve));
133 extern char* hldtoa ANSI((long double e, const char *xdigs, int ndigits,
134 			int *decpt, int *sign, char **rve));
135 
136 extern char* gdtoa ANSI((FPI *fpi, int be, ULong *bits, int *kindp,
137 			int mode, int ndigits, int *decpt, char **rve));
138 extern void freedtoa ANSI((char*));
139 extern float  strtof ANSI((CONST char *, char **));
140 extern double strtod ANSI((CONST char *, char **));
141 extern int strtodg ANSI((CONST char*, char**, CONST FPI*, Long*, ULong*,
142                          locale_t));
143 
144 extern char*	g_ddfmt  ANSI((char*, double*, int, size_t));
145 extern char*	g_dfmt   ANSI((char*, double*, int, size_t));
146 extern char*	g_ffmt   ANSI((char*, float*,  int, size_t));
147 extern char*	g_Qfmt   ANSI((char*, void*,   int, size_t));
148 extern char*	g_xfmt   ANSI((char*, void*,   int, size_t));
149 extern char*	g_xLfmt  ANSI((char*, void*,   int, size_t));
150 
151 extern int	strtoId  ANSI((CONST char*, char**, double*, double*));
152 extern int	strtoIdd ANSI((CONST char*, char**, double*, double*));
153 extern int	strtoIf  ANSI((CONST char*, char**, float*, float*));
154 extern int	strtoIQ  ANSI((CONST char*, char**, void*, void*));
155 extern int	strtoIx  ANSI((CONST char*, char**, void*, void*));
156 extern int	strtoIxL ANSI((CONST char*, char**, void*, void*));
157 extern int	strtord  ANSI((CONST char*, char**, int, double*, locale_t));
158 extern int	strtordd ANSI((CONST char*, char**, int, double*));
159 extern int	strtorf  ANSI((CONST char*, char**, int, float*));
160 extern int	strtorQ  ANSI((CONST char*, char**, int, void*));
161 extern int	strtorx  ANSI((CONST char*, char**, int, void*));
162 extern int	strtorxL ANSI((CONST char*, char**, int, void*));
163 #if 1
164 extern int	strtodI  ANSI((CONST char*, char**, double*));
165 extern int	strtopd  ANSI((CONST char*, char**, double*));
166 extern int	strtopdd ANSI((CONST char*, char**, double*));
167 extern int	strtopf  ANSI((CONST char*, char**, float*));
168 extern int	strtopQ  ANSI((CONST char*, char**, void*, locale_t));
169 extern int	strtopx  ANSI((CONST char*, char**, void*, locale_t));
170 extern int	strtopxL ANSI((CONST char*, char**, void*, locale_t));
171 #else
172 #define strtopd(s,se,x) strtord(s,se,1,x)
173 #define strtopdd(s,se,x) strtordd(s,se,1,x)
174 #define strtopf(s,se,x) strtorf(s,se,1,x)
175 #define strtopQ(s,se,x) strtorQ(s,se,1,x)
176 #define strtopx(s,se,x) strtorx(s,se,1,x)
177 #define strtopxL(s,se,x) strtorxL(s,se,1,x)
178 #endif
179 
180 #ifdef __cplusplus
181 }
182 #endif
183 #endif /* GDTOA_H_INCLUDED */
184