/******************************************** ; File: SANE.h ; ; ; Copyright Apple Computer, Inc.1986-90 ; All Rights Reserved ; ********************************************/ #ifndef __TYPES__ #include <TYPES.h> #endif #ifndef __SANE__ #define __SANE__ /* Decimal Representation Constants */ #define SIGDIGLEN 0x001C #define DECSTROUTLEN 0x0050 /* IEEE defualt environment constant */ #define IEEEDEFAULTENV 0x0000 /* Decimal formatting styles */ #define FLOATDECIMAL 0x0000 #define FIXEDDECIMAL 0x0001 /* Exceptions */ #define INVALID 0x0001 #define UNDERFLOW 0x0002 #define OVERFLOW 0x0004 #define DIVBYZERO 0x0008 #define INEXACT 0x0010 /* Ordering relations */ #define GREATERTHAN 0 #define LESSTHAN 1 #define EQUALTO 2 #define UNORDERED 3 typedef short relop ; /* Inquiry classes */ #define SNAN 0 #define QNAN 1 #define INFINITE 2 #define ZERONUM 3 #define NORMALNUM 4 #define DENORMALNUM 5 typedef short numclass ; /* Environmental control */ /* Rounding directions */ #define TONEAREST 0 #define UPWARD 1 #define DOWNWARD 2 #define TOWARDZERO 3 typedef short rounddir ; /* Rounding precisions */ #define EXTPRECISION 0 #define DBLPRECISION 1 #define FLOATPRECISION 2 typedef short roundpre ; typedef short exception; typedef short environment; typedef struct decimal { short sgn; /* sign 0 for +, 1 for - */ short exp; /* decimal exponent */ struct { unsigned char length, text[SIGDIGLEN], unused; } sig; /* significant digits */ } decimal, Decimal; struct decform { short style; /* FLOATDECIMAL or FIXEDDECIMAL */ short digits; } ; typedef struct decform decform; typedef struct decform DecForm; typedef void (*haltvector)(void); Extended fabs (Extended x) ; /* Conversions between binary and decimal */ void num2dec (DecForm *f,extended x,Decimal *d) ; /* d <-- x according to format f */ Extended dec2num (Decimal *d) ; /* Dec2Num <-- d as Extended */ /* Conversions between decimal formats */ void str2dec (char *s,short *index,Decimal *d,short *validPrefix) ; /* On input Index is starting index into s. On output Index is one greater than index of last character of longest numeric substring. d <-- Decimal rep of longest numeric substring; validPrefix <-- s, beginning at Index, contains valid numeric string or valid prefix of some numeric string */ void dec2str (DecForm *f,Decimal *d,char *s) ; /* s <-- d according to format f */ /* Arithmetic, auxiliary and elementary functions */ Extended remainder (Extended x,Extended y,short *quo) ; /* Remainder <-- x rem y; */ /* quo <-- 7 low-order bits of integer quotient x/y */ /* where -127 < quo < 127 */ Extended sqrt (Extended x) ; /* square root */ Extended rint (Extended x) ; /* round to integral value */ Extended scalb (short n,Extended x) ; /* scale binary; scalb <-- x * 2^n */ Extended logb (Extended x) ; /* binary log: binary exponent of normalized x */ Extended copysign (Extended x,Extended y) ; /* CopySign <-- y with sign of x */ Extended nextfloat (Extended x,Extended y) ; /* next float rep after (float) x in direction of (float) y */ Extended nextdouble (Extended x,Extended y) ; /* next Double rep after (Double) x in direction of (Double) y */ Extended nextextended (Extended x,Extended y) ; /* next extended representation after x in direction of y */ Extended log2 (Extended x) ; /* base-2 logarithm */ Extended log (Extended x) ; /* base-e logarithm */ Extended log1 (Extended x) ; /* log(1 + x) */ Extended exp2 (Extended x) ; /* base-2 exponential */ Extended exp (Extended x) ; /* base-e exponential */ Extended exp1 (Extended x) ; /* exp(x) - 1 */ Extended power (Extended x,Extended y) ; /* general exponential: x ^ y */ Extended ipower (Extended x,short i) ; /* integer exponential: x ^ i */ Extended compound (Extended r,Extended n) ; /* compound: (1 + r) ^ n */ Extended annuity (Extended r,Extended n) ; /* Annuity <-- (1 - (1+r)^(-n)) / r */ Extended tan (Extended x) ; /* tangent */ Extended sin (Extended x) ; /* Sine */ Extended cos (Extended x) ; /* Cosine */ Extended atan (Extended x) ; /* Arctangent */ Extended randomx (Extended *x) ; /* returns next random number; updates x; */ /* x must be integral, 1 <= x <= 2^31 - 2 */ /* Inquiry Routines */ numclass classfloat (Extended x) ; /* class of (float) x */ numclass classdouble (Extended x) ; /* class of (Double) x */ numclass classcomp (Extended x) ; /* class of (Comp) x */ numclass classextended (Extended x) ; /* class of x */ LongWord signnum (Extended x) ; /* 0 if sign bit clear, 1 if sign bit set */ /* Environment access routines */ void setexception (exception e,long b) ; /* clears e flags if b is 0, sets e flags otherwise; may cause halt */ long testexception (exception e) ; /* return true if any e flag is set, return false otherwise */ void sethalt (exception e,long b) ; /* set e halt enables if b is true, clear e halt enables otherwise */ long testhalt (exception e) ; /* return true if any e halt is enabled, return false otherwise */ void setround (rounddir r) ; /* set rounding direction to r */ rounddir getround (void) ; /* return rounding direction */ void setprecision (roundpre p) ; /* sets rnd'n precision to p */ roundpre getprecision (void) ; void setenvironment (environment e) ; /* sets SANE environment to e */ void getenvironment (environment *e) ; /* e <-- SANE environment */ void procentry (environment *e) ; /* e <-- environment; environment <-- IEEE default env */ void procexit (environment e) ; /* temp <-- current exceptions; */ /* SANE environment <-- e; */ /* signals exceptions in temp */ haltvector gethaltvector (void) ; /* return SANE halt vector */ void sethaltvector (haltvector v) ; /* halt vector <-- v */ /* Comparison routine */ relop relation (Extended x,Extended y) ; /* return Relation such that "x Relation y" is true */ /* NaNs and Special Constants */ extended nan( unsigned char c ); /* returns NaN with code c */ Extended inf (void) ; /* returns infinity */ Extended pi (void) ; /* returns pi */ extern pascal void SANEBootInit() inline(0x010A,dispatcher); extern pascal void SANEStartUp() inline(0x020A,dispatcher); extern pascal void SANEShutDown() inline(0x030A,dispatcher); extern pascal Word SANEVersion() inline(0x040A,dispatcher); extern pascal void SANEReset() inline(0x050A,dispatcher); extern pascal Word SANEStatus() inline(0x060A,dispatcher); extern pascal void SANEFP816() inline(0x090A,dispatcher); extern pascal void SANEDecStr816() inline(0x0A0A,dispatcher); extern pascal void SANEElems816() inline(0x0B0A,dispatcher); #endif