X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2Fcompiler%2FHsVersions.h;h=39285ba3de62e0759acd2abb73df897ad83c4dee;hb=62e403b3e19f37b78164b99c6facf80b53de0fea;hp=f6acb0acb62b7f5c97529b4b206033e988430014;hpb=4e6d0831f8260f6cf1f8b9f118123d2c4fb86ee1;p=ghc-hetmet.git diff --git a/ghc/compiler/HsVersions.h b/ghc/compiler/HsVersions.h index f6acb0a..39285ba 100644 --- a/ghc/compiler/HsVersions.h +++ b/ghc/compiler/HsVersions.h @@ -10,6 +10,12 @@ you will screw up the layout where they are used in case expressions! #endif +#ifdef __GLASGOW_HASKELL__ +#define GLOBAL_VAR(name,value,ty) \ +name = Util.global (value) :: IORef (ty); \ +{-# NOINLINE name #-} +#endif + #define COMMA , #ifdef DEBUG @@ -22,6 +28,15 @@ you will screw up the layout where they are used in case expressions! #define WARN(e,msg) #endif +-- temporary usage assertion control KSW 2000-10 +#ifdef DO_USAGES +#define UASSERT(e) ASSERT(e) +#define UASSERT2(e,msg) ASSERT2(e,msg) +#else +#define UASSERT(e) +#define UASSERT2(e,msg) +#endif + #if __STDC__ #define CAT2(a,b)a##b #else @@ -29,116 +44,14 @@ you will screw up the layout where they are used in case expressions! #endif #if defined(__GLASGOW_HASKELL__) && __GLASGOW_HASKELL__ >= 202 -# define REALLY_HASKELL_1_3 -# define SYN_IE(a) a -# define EXP_MODULE(a) module a -# define IMPORT_DELOOPER(mod) import mod -# define IMPORT_1_3(mod) import mod -# define _Addr Addr -# define _ByteArray GlaExts.ByteArray -# define _MutableByteArray GlaExts.MutableByteArray -# define _MutableArray GlaExts.MutableArray -# define _RealWorld GlaExts.RealWorld -# define _ST GlaExts.ST -# define _ForeignObj Foreign.ForeignObj -# define _runST ST.runST -# define seqStrictlyST seqST -# define thenStrictlyST thenST -# define returnStrictlyST return -# define MkST ST -# if __GLASGOW_HASKELL__ >= 209 -# define STATE_TOK(x) x -# define ST_RET(x,y) STret (y) (x) -# define unsafePerformST(x) runST (x) -# define ST_TO_PrimIO(x) (stToIO (x)) -# else -# define STATE_TOK(x) (S# x) -# define ST_RET(x,y) (x,y) -# define unsafePerformST(x) unsafePerformPrimIO(x) -# define ST_TO_PrimIO(x) x -# endif # define failWith fail # define MkIOError(h,errt,msg) (IOError (Just h) errt msg) -# define CCALL_THEN thenIO_Prim -# define Text Show -# define IMP_FASTSTRING() import FastString -# if __GLASGOW_HASKELL__ >= 209 -# define IMP_Ubiq() import GlaExts ; import Addr(Addr(..)); import FastString -# define CHK_Ubiq() import GlaExts ; import Addr(Addr(..)); import FastString -# else -# define IMP_Ubiq() import GlaExts ; import FastString -# define CHK_Ubiq() import GlaExts ; import FastString -# endif # define minInt (minBound::Int) # define maxInt (maxBound::Int) #else -# define STATE_TOK(x) (S# x) -# define ST_RET(x,y) (x,y) -# define unsafePerformST(x) unsafePerformPrimIO(x) -# define ST_TO_PrimIO(x) x -# define SYN_IE(a) a(..) -# define EXP_MODULE(a) a.. -# define IMPORT_DELOOPER(mod) import mod -# define IMPORT_1_3(mod) {--} -# define IMP_FASTSTRING() import FastString -# define IMP_Ubiq() IMPORT_DELOOPER(Ubiq) ; import FastString -# define CHK_Ubiq() IMPORT_DELOOPER(Ubiq) ; import FastString -# define MkST -# define CCALL_THEN thenPrimIO # define MkIOError(h,errt,msg) (errt msg) #endif -#if defined(__GLASGOW_HASKELL__) - --- Import the beggars -import GlaExts - ( Int(..), Int#, (+#), (-#), (*#), - quotInt#, negateInt#, (==#), (<#), (<=#), (>=#), (>#) - ) - -#define FAST_INT Int# -#define ILIT(x) (x#) -#define IBOX(x) (I# (x)) -#define _ADD_ +# -#define _SUB_ -# -#define _MUL_ *# -#define _QUOT_ `quotInt#` -#define _NEG_ negateInt# -#define _EQ_ ==# -#define _LT_ <# -#define _LE_ <=# -#define _GE_ >=# -#define _GT_ ># - -#define FAST_BOOL Int# -#define _TRUE_ 1# -#define _FALSE_ 0# -#define _IS_TRUE_(x) ((x) _EQ_ 1#) - -#else {- ! __GLASGOW_HASKELL__ -} - -#define FAST_INT Int -#define ILIT(x) (x) -#define IBOX(x) (x) -#define _ADD_ + -#define _SUB_ - -#define _MUL_ * -#define _DIV_ `div` -#define _QUOT_ `quot` -#define _NEG_ - -#define _EQ_ == -#define _LT_ < -#define _LE_ <= -#define _GE_ >= -#define _GT_ > - -#define FAST_BOOL Bool -#define _TRUE_ True -#define _FALSE_ False -#define _IS_TRUE_(x) (x) - -#endif {- ! __GLASGOW_HASKELL__ -} - #if __GLASGOW_HASKELL__ >= 23 -- This #ifndef lets us switch off the "import FastString" @@ -155,13 +68,17 @@ import qualified FastString # define _NIL_ (FastString.mkFastString "") # define _CONS_ FastString.consFS # define _HEAD_ FastString.headFS +# define _HEAD_INT_ FastString.headIntFS # define _TAIL_ FastString.tailFS # define _LENGTH_ FastString.lengthFS # define _PK_ FastString.mkFastString +# define _PK_INT_ FastString.mkFastStringInt # define _UNPK_ FastString.unpackFS +# define _UNPK_INT_ FastString.unpackIntFS # define _APPEND_ `FastString.appendFS` # define _CONCAT_ FastString.concatFS #else +# error I think that FastString is now always used. If not, fix this. # define FAST_STRING String # define SLIT(x) (x) # define _CMP_STRING_ cmpString @@ -179,13 +96,17 @@ import qualified FastString #endif #if __HASKELL1__ > 4 -#define FMAP fmap -#define ISALPHANUM isAlphaNum -#define IOERROR ioError +# define FMAP fmap +# define ISALPHANUM isAlphaNum +# define IOERROR ioError +# define PSEQ seq +# define SAPPLY $! #else -#define FMAP map -#define ISALPHANUM isAlphanum -#define IOERROR fail +# define FMAP map +# define ISALPHANUM isAlphanum +# define IOERROR fail +# define PSEQ (\x y -> y) +# define SAPPLY $ #endif #endif