summaryrefslogtreecommitdiffstats
path: root/private/crt32/h/fltintrn.h
diff options
context:
space:
mode:
Diffstat (limited to 'private/crt32/h/fltintrn.h')
-rw-r--r--private/crt32/h/fltintrn.h192
1 files changed, 192 insertions, 0 deletions
diff --git a/private/crt32/h/fltintrn.h b/private/crt32/h/fltintrn.h
new file mode 100644
index 000000000..5f6cc4d19
--- /dev/null
+++ b/private/crt32/h/fltintrn.h
@@ -0,0 +1,192 @@
+/***
+*fltintrn.h - contains declarations of internal floating point types,
+* routines and variables
+*
+* Copyright (c) 1985-1993, Microsoft Corporation. All rights reserved.
+*
+*Purpose:
+* Declares floating point types, routines and variables used
+* internally by the C run-time.
+* [Internal]
+*
+*Revision History:
+* 10-20-88 JCR Changed 'DOUBLE' to 'double' for 386
+* 08-15-89 GJF Fixed copyright, indents
+* 10-30-89 GJF Fixed copyright (again)
+* 03-02-90 GJF Added #ifndef _INC_STRUCT stuff. Also, cleaned up
+* the formatting a bit.
+* 03-05-90 GJF Fixed up the arg types in protoypes. Also, added
+* #include <cruntime.h>
+* 03-22-90 GJF Made _fltin(), _fltin2(), _fltout() and _fltout2()
+* _CALLTYPE2 (for now) and added a prototype for
+* _fptostr().
+* 08-01-90 SBM Moved _cftoe() and _cftof() here from internal.h
+* and _cfltcvt_tab from input.c and output.c,
+* added typedefs for _cfltcvt_tab entries,
+* renamed module from <struct.h> to <fltintrn.h> and
+* adjusted #ifndef stuff to #ifndef _INC_FLTINTRN
+* 08-29-90 SBM Changed type of _cfltcvt_tab[] to agree with
+* definition in cmiscdat.c
+* 04-26-91 SRW Removed level 3 warnings
+* 08-26-91 JCR Changed MIPS to _MIPS_, ANSI naming
+* 08-06-92 GJF Function calling type and variable type macros. Revised
+* use of target processor macros.
+* 11-09-92 GJF Fixed preprocessing conditionals for MIPS.
+* 01-09-93 SRW Remove usage of MIPS and ALPHA to conform to ANSI
+* Use _MIPS_ and _ALPHA_ instead.
+* 01-21-93 GJF Removed support for C6-386's _cdecl.
+* 03-31-93 CFW Added #pragma warning to suppress "long double" warnings.
+*
+****/
+
+#ifndef _INC_FLTINTRN
+
+#ifdef __cplusplus
+extern "C" {
+#endif
+
+#include <cruntime.h>
+
+/*
+ * Conditional macro definition for function calling type and variable type
+ * qualifiers.
+ */
+#if ( (_MSC_VER >= 800) && (_M_IX86 >= 300) )
+
+/*
+ * Definitions for MS C8-32 (386/486) compiler
+ */
+#define _CRTAPI1 __cdecl
+#define _CRTAPI2 __cdecl
+
+#else
+
+/*
+ * Other compilers (e.g., MIPS)
+ */
+#define _CRTAPI1
+#define _CRTAPI2
+#define _CRTVAR1
+
+#endif
+
+// C4069: "long double != double"
+#pragma warning(disable:4069) // disable C4069 warning
+// #pragma warning(default:4069) // use this to reenable, if desired
+
+/*
+ * structs used to fool the compiler into not generating floating point
+ * instructions when copying and pushing [long] double values
+ */
+
+#ifndef DOUBLE
+
+typedef struct {
+ double x;
+} DOUBLE;
+
+#endif
+
+#ifndef LONGDOUBLE
+
+typedef struct {
+#if defined(_M_MRX000) || defined(_M_ALPHA) || defined(_M_PPC)
+ /*
+ * No long double type for MIPS, ALPHA, or PPC
+ */
+ double x;
+#else
+ /*
+ * Assume there is a long double type
+ */
+ long double x;
+#endif
+} LONGDOUBLE;
+
+#endif
+
+/*
+ * typedef for _fltout
+ */
+
+typedef struct _strflt
+{
+ int sign; /* zero if positive otherwise negative */
+ int decpt; /* exponent of floating point number */
+ int flag; /* zero if okay otherwise IEEE overflow */
+ char *mantissa; /* pointer to mantissa in string form */
+}
+ *STRFLT;
+
+
+/*
+ * typedef for _fltin
+ */
+
+typedef struct _flt
+{
+ int flags;
+ int nbytes; /* number of characters read */
+ long lval;
+ double dval; /* the returned floating point number */
+}
+ *FLT;
+
+
+/* floating point conversion routines, keep in sync with mrt32\include\convert.h */
+
+char *_cftoe(double *, char *, int, int);
+char *_cftof(double *, char *, int);
+void _CRTAPI1 _fptostr(char *, int, STRFLT);
+
+#ifdef MTHREAD
+
+STRFLT _CRTAPI2 _fltout2( double, STRFLT, char * );
+FLT _CRTAPI2 _fltin2( FLT , const char *, int, int, int );
+
+#else
+
+STRFLT _CRTAPI2 _fltout( double );
+FLT _CRTAPI2 _fltin( const char *, int, int, int );
+
+#endif
+
+
+/*
+ * table of pointers to floating point helper routines
+ *
+ * We can't specify the prototypes for the entries of the table accurately,
+ * since different functions in the table have different arglists.
+ * So we declare the functions to take and return void (which is the
+ * correct prototype for _fptrap(), which is what the entries are all
+ * initialized to if no floating point is loaded) and cast appropriately
+ * on every usage.
+ */
+
+typedef void (* PFV)(void);
+extern PFV _cfltcvt_tab[6];
+
+typedef void (* PF0)(DOUBLE*, char*, int, int, int);
+#define _cfltcvt(a,b,c,d,e) (*((PF0)_cfltcvt_tab[0]))(a,b,c,d,e)
+
+typedef void (* PF1)(char*);
+#define _cropzeros(a) (*((PF1)_cfltcvt_tab[1]))(a)
+
+typedef void (* PF2)(int, char*, char*);
+#define _fassign(a,b,c) (*((PF2)_cfltcvt_tab[2]))(a,b,c)
+
+typedef void (* PF3)(char*);
+#define _forcdecpt(a) (*((PF3)_cfltcvt_tab[3]))(a)
+
+typedef int (* PF4)(DOUBLE*);
+#define _positive(a) (*((PF4)_cfltcvt_tab[4]))(a)
+
+typedef void (* PF5)(LONGDOUBLE*, char*, int, int, int);
+#define _cldcvt(a,b,c,d,e) (*((PF5)_cfltcvt_tab[5]))(a,b,c,d,e)
+
+#ifdef __cplusplus
+}
+#endif
+
+#define _INC_FLTINTRN
+#endif /* _INC_FLTINTRN */