X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;f=GHC%2FExts.hs;h=81a9dbb4edb399c29d2fb9fc1e96053332f39572;hb=be2750a0a11b919fb03cc070074e430f88bdfa90;hp=27fecaeaf5baeef22f46dd902e5641cfa36151bb;hpb=4028033c7334eb7fb4aca926fc16685ef89f5d22;p=ghc-base.git diff --git a/GHC/Exts.hs b/GHC/Exts.hs index 27fecae..81a9dbb 100644 --- a/GHC/Exts.hs +++ b/GHC/Exts.hs @@ -1,3 +1,5 @@ +{-# LANGUAGE MagicHash, UnboxedTuples, DeriveDataTypeable #-} + ----------------------------------------------------------------------------- -- | -- Module : GHC.Exts @@ -15,29 +17,39 @@ module GHC.Exts ( -- * Representations of some basic types - Int(..),Word(..),Float(..),Double(..),Integer(..),Char(..), - Ptr(..), FunPtr(..), + Int(..),Word(..),Float(..),Double(..), + Char(..), + Ptr(..), FunPtr(..), + + -- * The maximum tuple size + maxTupleSize, -- * Primitive operations module GHC.Prim, - shiftL#, shiftRL#, iShiftL#, iShiftRA#, iShiftRL#, + shiftL#, shiftRL#, iShiftL#, iShiftRA#, iShiftRL#, uncheckedShiftL64#, uncheckedShiftRL64#, uncheckedIShiftL64#, uncheckedIShiftRA64#, - -- * Fusion - build, augment, + -- * Fusion + build, augment, - -- * Overloaded string literals - IsString(..), + -- * Overloaded string literals + IsString(..), - -- * Debugging - breakpoint, breakpointCond, + -- * Debugging + breakpoint, breakpointCond, - -- * Ids with special behaviour - lazy, inline, + -- * Ids with special behaviour + lazy, inline, -- * Transform comprehensions - Down(..), groupWith, sortWith, the + Down(..), groupWith, sortWith, the, + + -- * Event logging + traceEvent, + + -- * SpecConstr annotations + SpecConstrAnnotation(..) ) where @@ -45,13 +57,19 @@ import Prelude import GHC.Prim import GHC.Base +import GHC.Magic import GHC.Word import GHC.Int -import GHC.Num -import GHC.Float +-- import GHC.Float import GHC.Ptr import Data.String import Data.List +import Foreign.C +import Data.Data + +-- XXX This should really be in Data.Tuple, where the definitions are +maxTupleSize :: Int +maxTupleSize = 62 -- | The 'Down' type allows you to reverse sort order conveniently. A value of type -- @'Down' a@ contains a value of type @a@ (represented as @'Down' a@). @@ -67,7 +85,7 @@ instance Ord a => Ord (Down a) where -- | 'the' ensures that all the elements of the list are identical -- and then returns that unique element the :: Eq a => [a] -> a -the (x:xs) +the (x:xs) | all (x ==) xs = x | otherwise = error "GHC.Exts.the: non-identical elements" the [] = error "GHC.Exts.the: empty list" @@ -85,8 +103,35 @@ groupWith :: Ord b => (a -> b) -> [a] -> [[a]] groupWith f xs = build (\c n -> groupByFB c n (\x y -> f x == f y) (sortWith f xs)) groupByFB :: ([a] -> lst -> lst) -> lst -> (a -> a -> Bool) -> [a] -> lst -groupByFB c n eq xs = groupByFBCore xs +groupByFB c n eq xs0 = groupByFBCore xs0 where groupByFBCore [] = n groupByFBCore (x:xs) = c (x:ys) (groupByFBCore zs) where (ys, zs) = span (eq x) xs + +-- ----------------------------------------------------------------------------- +-- tracing + +traceEvent :: String -> IO () +traceEvent msg = do + withCString msg $ \(Ptr p) -> IO $ \s -> + case traceEvent# p s of s' -> (# s', () #) + + + +{- ********************************************************************** +* * +* SpecConstr annotation * +* * +********************************************************************** -} + +-- Annotating a type with NoSpecConstr will make SpecConstr +-- not specialise for arguments of that type. + +-- This data type is defined here, rather than in the SpecConstr module +-- itself, so that importing it doesn't force stupidly linking the +-- entire ghc package at runtime + +data SpecConstrAnnotation = NoSpecConstr | ForceSpecConstr + deriving( Data, Typeable, Eq ) +