diff options
Diffstat (limited to 'compiler')
-rw-r--r-- | compiler/hsSyn/HsExpr.hs-boot | 12 | ||||
-rw-r--r-- | compiler/hsSyn/HsPat.hs-boot | 8 | ||||
-rw-r--r-- | compiler/utils/Fingerprint.hsc | 39 | ||||
-rw-r--r-- | compiler/utils/Serialized.hs | 10 |
4 files changed, 1 insertions, 68 deletions
diff --git a/compiler/hsSyn/HsExpr.hs-boot b/compiler/hsSyn/HsExpr.hs-boot index 4b9f968ebf..eb9d23a9ed 100644 --- a/compiler/hsSyn/HsExpr.hs-boot +++ b/compiler/hsSyn/HsExpr.hs-boot @@ -3,9 +3,7 @@ {-# LANGUAGE UndecidableInstances #-} -- Note [Pass sensitive types] -- in module PlaceHolder {-# LANGUAGE ConstraintKinds #-} -#if __GLASGOW_HASKELL__ > 706 {-# LANGUAGE RoleAnnotations #-} -#endif module HsExpr where @@ -15,31 +13,21 @@ import {-# SOURCE #-} HsPat ( LPat ) import PlaceHolder ( DataId ) import Data.Data hiding ( Fixity ) -#if __GLASGOW_HASKELL__ > 706 type role HsExpr nominal type role HsCmd nominal type role MatchGroup nominal representational type role GRHSs nominal representational type role HsSplice nominal -#endif data HsExpr (i :: *) data HsCmd (i :: *) data HsSplice (i :: *) data MatchGroup (a :: *) (body :: *) data GRHSs (a :: *) (body :: *) -#if __GLASGOW_HASKELL__ > 706 instance Typeable HsSplice instance Typeable HsExpr instance Typeable MatchGroup instance Typeable GRHSs -#else -instance Typeable1 HsSplice -instance Typeable1 HsExpr -instance Typeable1 HsCmd -instance Typeable2 MatchGroup -instance Typeable2 GRHSs -#endif instance (DataId id) => Data (HsSplice id) instance (DataId id) => Data (HsExpr id) diff --git a/compiler/hsSyn/HsPat.hs-boot b/compiler/hsSyn/HsPat.hs-boot index 114425b526..c6ab5a5b35 100644 --- a/compiler/hsSyn/HsPat.hs-boot +++ b/compiler/hsSyn/HsPat.hs-boot @@ -3,9 +3,7 @@ {-# LANGUAGE UndecidableInstances #-} -- Note [Pass sensitive types] -- in module PlaceHolder {-# LANGUAGE ConstraintKinds #-} -#if __GLASGOW_HASKELL__ > 706 {-# LANGUAGE RoleAnnotations #-} -#endif module HsPat where import SrcLoc( Located ) @@ -14,17 +12,11 @@ import Data.Data hiding (Fixity) import Outputable import PlaceHolder ( DataId ) -#if __GLASGOW_HASKELL__ > 706 type role Pat nominal -#endif data Pat (i :: *) type LPat i = Located (Pat i) -#if __GLASGOW_HASKELL__ > 706 instance Typeable Pat -#else -instance Typeable1 Pat -#endif instance (DataId id) => Data (Pat id) instance (OutputableBndr name) => Outputable (Pat name) diff --git a/compiler/utils/Fingerprint.hsc b/compiler/utils/Fingerprint.hsc index 464337b7a9..ed4cd6fff7 100644 --- a/compiler/utils/Fingerprint.hsc +++ b/compiler/utils/Fingerprint.hsc @@ -15,7 +15,7 @@ module Fingerprint ( readHexFingerprint, fingerprintData, fingerprintString, - -- Re-exported from GHC.Fingerprint for GHC >= 7.7, local otherwise + -- Re-exported from GHC.Fingerprint getFileHash ) where @@ -23,13 +23,6 @@ module Fingerprint ( ##include "HsVersions.h" import Numeric ( readHex ) -#if __GLASGOW_HASKELL__ < 707 --- Only needed for getFileHash below. -import Foreign -import Panic -import System.IO -import Control.Monad ( when ) -#endif import GHC.Fingerprint @@ -39,33 +32,3 @@ readHexFingerprint s = Fingerprint w1 w2 where (s1,s2) = splitAt 16 s [(w1,"")] = readHex s1 [(w2,"")] = readHex (take 16 s2) - - -#if __GLASGOW_HASKELL__ < 707 --- Only use this if we're smaller than GHC 7.7, otherwise --- GHC.Fingerprint exports a better version of this function. - --- | Computes the hash of a given file. --- It loads the full file into memory an does not work with files bigger than --- MAXINT. -getFileHash :: FilePath -> IO Fingerprint -getFileHash path = withBinaryFile path ReadMode $ \h -> do - - fileSize <- toIntFileSize `fmap` hFileSize h - - allocaBytes fileSize $ \bufPtr -> do - n <- hGetBuf h bufPtr fileSize - when (n /= fileSize) readFailedError - fingerprintData bufPtr fileSize - - where - toIntFileSize :: Integer -> Int - toIntFileSize size - | size > fromIntegral (maxBound :: Int) = throwGhcException $ - Sorry $ "Fingerprint.getFileHash: Tried to calculate hash of file " - ++ path ++ " with size > maxBound :: Int. This is not supported." - | otherwise = fromIntegral size - - readFailedError = throwGhcException $ - Panic $ "Fingerprint.getFileHash: hGetBuf failed on interface file" -#endif diff --git a/compiler/utils/Serialized.hs b/compiler/utils/Serialized.hs index d4e0048467..01fa071cab 100644 --- a/compiler/utils/Serialized.hs +++ b/compiler/utils/Serialized.hs @@ -96,26 +96,16 @@ deserializeConstr bytes k = deserializeWord8 bytes $ \constr_ix bytes -> x -> error $ "deserializeConstr: unrecognised serialized constructor type " ++ show x ++ " in context " ++ show bytes -#if __GLASGOW_HASKELL__ < 707 -serializeFixedWidthNum :: forall a. (Num a, Integral a, Bits a) => a -> [Word8] -> [Word8] -serializeFixedWidthNum what = go (bitSize what) what -#else serializeFixedWidthNum :: forall a. (Integral a, FiniteBits a) => a -> [Word8] -> [Word8] serializeFixedWidthNum what = go (finiteBitSize what) what -#endif where go :: Int -> a -> [Word8] -> [Word8] go size current rest | size <= 0 = rest | otherwise = fromIntegral (current .&. 255) : go (size - 8) (current `shiftR` 8) rest -#if __GLASGOW_HASKELL__ < 707 -deserializeFixedWidthNum :: forall a b. (Num a, Integral a, Bits a) => [Word8] -> (a -> [Word8] -> b) -> b -deserializeFixedWidthNum bytes k = go (bitSize (undefined :: a)) bytes k -#else deserializeFixedWidthNum :: forall a b. (Integral a, FiniteBits a) => [Word8] -> (a -> [Word8] -> b) -> b deserializeFixedWidthNum bytes k = go (finiteBitSize (undefined :: a)) bytes k -#endif where go :: Int -> [Word8] -> (a -> [Word8] -> b) -> b go size bytes k |