X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=ghc%2Fcompiler%2FHsVersions.h;h=b90e474525bd22ab675d8885fc49afa13182d962;hb=c837a7f2f12d3f340454b9525be188f3ec27c8cf;hp=2a2b376b0d40829db30531652b58a3682a2265eb;hpb=1fb1ab5d53a09607e7f6d2450806760688396387;p=ghc-hetmet.git diff --git a/ghc/compiler/HsVersions.h b/ghc/compiler/HsVersions.h index 2a2b376..b90e474 100644 --- a/ghc/compiler/HsVersions.h +++ b/ghc/compiler/HsVersions.h @@ -14,8 +14,12 @@ you will screw up the layout where they are used in case expressions! #ifdef DEBUG #define ASSERT(e) if (not (e)) then (assertPanic __FILE__ __LINE__) else +#define ASSERT2(e,msg) if (not (e)) then (assertPprPanic __FILE__ __LINE__ (msg)) else +#define WARN( e, msg ) (warnPprTrace (e) __FILE__ __LINE__ (msg)) #else #define ASSERT(e) +#define ASSERT2(e,msg) +#define WARN(e,msg) #endif #if __STDC__ @@ -24,24 +28,54 @@ you will screw up the layout where they are used in case expressions! #define CAT2(a,b)a/**/b #endif -#if defined(__GLASGOW_HASKELL__) && __GLASGOW_HASKELL__ >= 200 +#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 CAT2(mod,_1_3) +# define IMPORT_DELOOPER(mod) import mod # define IMPORT_1_3(mod) import mod -# define _tagCmp compare -# define _LT LT -# define _EQ EQ -# define _GT GT -# define _Addr GHCbase.Addr +# 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() -# define IMP_Ubiq() IMPORT_DELOOPER(Ubiq); import qualified GHCbase -# define CHK_Ubiq() IMPORT_DELOOPER(Ubiq); import qualified GHCbase +# 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 @@ -49,38 +83,37 @@ you will screw up the layout where they are used in case expressions! # 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 __GLASGOW_HASKELL__ >= 26 && __GLASGOW_HASKELL__ < 200 -#define trace _trace -#endif +#if defined(__GLASGOW_HASKELL__) -#define TAG_ Int# -#define LT_ -1# -#define EQ_ 0# -#define GT_ 1# -#define GT__ _ +-- Import the beggars +import GlaExts + ( Int(..), Int#, (+#), (-#), (*#), + quotInt#, negateInt#, (==#), (<#), (<=#), (>=#), (>#) + ) -#if defined(__GLASGOW_HASKELL__) #define FAST_INT Int# #define ILIT(x) (x#) #define IBOX(x) (I# (x)) -#define _ADD_ `plusInt#` -#define _SUB_ `minusInt#` -#define _MUL_ `timesInt#` -#define _DIV_ `divInt#` +#define _ADD_ +# +#define _SUB_ -# +#define _MUL_ *# #define _QUOT_ `quotInt#` #define _NEG_ negateInt# -#define _EQ_ `eqInt#` -#define _LT_ `ltInt#` -#define _LE_ `leInt#` -#define _GE_ `geInt#` -#define _GT_ `gtInt#` +#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) `eqInt#` 1#) +#define _IS_TRUE_(x) ((x) _EQ_ 1#) #else {- ! __GLASGOW_HASKELL__ -} @@ -107,39 +140,27 @@ you will screw up the layout where they are used in case expressions! #endif {- ! __GLASGOW_HASKELL__ -} #if __GLASGOW_HASKELL__ >= 23 + +-- This #ifndef lets us switch off the "import FastString" +-- when compiling FastString itself +#ifndef COMPILING_FAST_STRING +-- +import qualified FastString +#endif + # define USE_FAST_STRINGS 1 -# if __GLASGOW_HASKELL__ < 200 -# define FAST_STRING FastString {-_PackedString -} -# define SLIT(x) (mkFastCharString (A# (x#))) {- (_packCString (A# x#)) -} -# define _CMP_STRING_ cmpPString - /* cmpPString defined in utils/Util.lhs */ -# define _NULL_ nullFastString {-_nullPS-} -# define _NIL_ (mkFastString "") {-_nilPS -} -# define _CONS_ consFS {-_consPS-} -# define _HEAD_ headFS {-_headPS-} -# define _TAIL_ tailFS {-_tailPS-} -# define _LENGTH_ lengthFS {-_lengthPS-} -# define _PK_ mkFastString {-_packString-} -# define _UNPK_ unpackFS {-_unpackPS-} - /* # define _SUBSTR_ _substrPS */ -# define _APPEND_ `appendFS` {-`_appendPS`-} -# define _CONCAT_ concatFS {-_concatPS-} -# else -# define FAST_STRING GHCbase.PackedString -# define SLIT(x) (packCString (GHCbase.A# x#)) -# define _CMP_STRING_ cmpPString -# define _NULL_ nullPS -# define _NIL_ nilPS -# define _CONS_ consPS -# define _HEAD_ headPS -# define _TAIL_ tailPS -# define _LENGTH_ lengthPS -# define _PK_ packString -# define _UNPK_ unpackPS -# define _SUBSTR_ substrPS -# define _APPEND_ `appendPS` -# define _CONCAT_ concatPS -# endif +# define FAST_STRING FastString.FastString +# define SLIT(x) (FastString.mkFastCharString# (x#)) +# define _NULL_ FastString.nullFastString +# define _NIL_ (FastString.mkFastString "") +# define _CONS_ FastString.consFS +# define _HEAD_ FastString.headFS +# define _TAIL_ FastString.tailFS +# define _LENGTH_ FastString.lengthFS +# define _PK_ FastString.mkFastString +# define _UNPK_ FastString.unpackFS +# define _APPEND_ `FastString.appendFS` +# define _CONCAT_ FastString.concatFS #else # define FAST_STRING String # define SLIT(x) (x) @@ -157,4 +178,18 @@ you will screw up the layout where they are used in case expressions! # define _CONCAT_ concat #endif +#if __HASKELL1__ > 4 +# 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 PSEQ (\x y -> y) +# define SAPPLY $ +#endif + #endif