Copyright | (C) 2012-2016 Edward Kmett (C) 2017 Ryan Scott |
---|---|
License | BSD-style (see the file LICENSE) |
Maintainer | Edward Kmett <ekmett@gmail.com> |
Stability | experimental |
Portability | non-portable |
Safe Haskell | Safe-Inferred |
Language | Haskell2010 |
In Control.Lens.Wrapped , we need to muck around with the internals of the newtypes in Foreign.C.Types . Unfortunately, the exact types used varies wildly from platform to platform, so trying to manage the imports necessary to bring these types in scope can be unwieldy.
To make things easier, we use this module as a way to import everything
carte blanche that might be used internally in
Foreign.C.Types
. For
now, this consists of all the exports from the
Data.Int
and
Data.Word
modules, as well as the
Ptr
type.
Documentation
module Data.Int
A value of type
represents a pointer to an object, or an
array of objects, which may be marshalled to or from Haskell values
of type
Ptr
a
a
.
The type
a
will often be an instance of class
Storable
which provides the marshalling operations.
However this is not essential, and you can provide your own operations
to access the pointer. For example you might write small foreign
functions to get or set the fields of a C
struct
.
Instances
NFData1 Ptr |
Since: deepseq-1.4.3.0 |
Defined in Control.DeepSeq |
|
IArray UArray ( Ptr a) | |
Defined in Data.Array.Base bounds :: Ix i => UArray i ( Ptr a) -> (i, i) Source # numElements :: Ix i => UArray i ( Ptr a) -> Int unsafeArray :: Ix i => (i, i) -> [( Int , Ptr a)] -> UArray i ( Ptr a) unsafeAt :: Ix i => UArray i ( Ptr a) -> Int -> Ptr a unsafeReplace :: Ix i => UArray i ( Ptr a) -> [( Int , Ptr a)] -> UArray i ( Ptr a) unsafeAccum :: Ix i => ( Ptr a -> e' -> Ptr a) -> UArray i ( Ptr a) -> [( Int , e')] -> UArray i ( Ptr a) unsafeAccumArray :: Ix i => ( Ptr a -> e' -> Ptr a) -> Ptr a -> (i, i) -> [( Int , e')] -> UArray i ( Ptr a) |
|
Generic1 ( URec ( Ptr ()) :: k -> Type ) |
Since: base-4.9.0.0 |
Eq ( Ptr a) |
Since: base-2.1 |
Data a => Data ( Ptr a) |
Since: base-4.8.0.0 |
Defined in Data.Data gfoldl :: ( forall d b. Data d => c (d -> b) -> d -> c b) -> ( forall g. g -> c g) -> Ptr a -> c ( Ptr a) Source # gunfold :: ( forall b r. Data b => c (b -> r) -> c r) -> ( forall r. r -> c r) -> Constr -> c ( Ptr a) Source # toConstr :: Ptr a -> Constr Source # dataTypeOf :: Ptr a -> DataType Source # dataCast1 :: Typeable t => ( forall d. Data d => c (t d)) -> Maybe (c ( Ptr a)) Source # dataCast2 :: Typeable t => ( forall d e. ( Data d, Data e) => c (t d e)) -> Maybe (c ( Ptr a)) Source # gmapT :: ( forall b. Data b => b -> b) -> Ptr a -> Ptr a Source # gmapQl :: (r -> r' -> r) -> r -> ( forall d. Data d => d -> r') -> Ptr a -> r Source # gmapQr :: forall r r'. (r' -> r -> r) -> r -> ( forall d. Data d => d -> r') -> Ptr a -> r Source # gmapQ :: ( forall d. Data d => d -> u) -> Ptr a -> [u] Source # gmapQi :: Int -> ( forall d. Data d => d -> u) -> Ptr a -> u Source # gmapM :: Monad m => ( forall d. Data d => d -> m d) -> Ptr a -> m ( Ptr a) Source # gmapMp :: MonadPlus m => ( forall d. Data d => d -> m d) -> Ptr a -> m ( Ptr a) Source # gmapMo :: MonadPlus m => ( forall d. Data d => d -> m d) -> Ptr a -> m ( Ptr a) Source # |
|
Ord ( Ptr a) |
Since: base-2.1 |
Defined in GHC.Ptr |
|
Show ( Ptr a) |
Since: base-2.1 |
Foldable ( UAddr :: Type -> Type ) |
Since: base-4.9.0.0 |
Defined in Data.Foldable fold :: Monoid m => UAddr m -> m Source # foldMap :: Monoid m => (a -> m) -> UAddr a -> m Source # foldMap' :: Monoid m => (a -> m) -> UAddr a -> m Source # foldr :: (a -> b -> b) -> b -> UAddr a -> b Source # foldr' :: (a -> b -> b) -> b -> UAddr a -> b Source # foldl :: (b -> a -> b) -> b -> UAddr a -> b Source # foldl' :: (b -> a -> b) -> b -> UAddr a -> b Source # foldr1 :: (a -> a -> a) -> UAddr a -> a Source # foldl1 :: (a -> a -> a) -> UAddr a -> a Source # toList :: UAddr a -> [a] Source # null :: UAddr a -> Bool Source # length :: UAddr a -> Int Source # elem :: Eq a => a -> UAddr a -> Bool Source # maximum :: Ord a => UAddr a -> a Source # minimum :: Ord a => UAddr a -> a Source # |
|
Traversable ( UAddr :: Type -> Type ) |
Since: base-4.9.0.0 |
Storable ( Ptr a) |
Since: base-2.1 |
Defined in Foreign.Storable sizeOf :: Ptr a -> Int Source # alignment :: Ptr a -> Int Source # peekElemOff :: Ptr ( Ptr a) -> Int -> IO ( Ptr a) Source # pokeElemOff :: Ptr ( Ptr a) -> Int -> Ptr a -> IO () Source # peekByteOff :: Ptr b -> Int -> IO ( Ptr a) Source # pokeByteOff :: Ptr b -> Int -> Ptr a -> IO () Source # |
|
NFData ( Ptr a) |
Since: deepseq-1.4.2.0 |
Defined in Control.DeepSeq |
|
Hashable ( Ptr a) | |
Prim ( Ptr a) | |
Defined in Data.Primitive.Types sizeOf# :: Ptr a -> Int# Source # alignment# :: Ptr a -> Int# Source # indexByteArray# :: ByteArray# -> Int# -> Ptr a Source # readByteArray# :: MutableByteArray# s -> Int# -> State# s -> (# State# s, Ptr a #) Source # writeByteArray# :: MutableByteArray# s -> Int# -> Ptr a -> State# s -> State# s Source # setByteArray# :: MutableByteArray# s -> Int# -> Int# -> Ptr a -> State# s -> State# s Source # indexOffAddr# :: Addr# -> Int# -> Ptr a Source # readOffAddr# :: Addr# -> Int# -> State# s -> (# State# s, Ptr a #) Source # writeOffAddr# :: Addr# -> Int# -> Ptr a -> State# s -> State# s Source # setOffAddr# :: Addr# -> Int# -> Int# -> Ptr a -> State# s -> State# s Source # |
|
MArray ( STUArray s) ( Ptr a) ( ST s) | |
Defined in Data.Array.Base getBounds :: Ix i => STUArray s i ( Ptr a) -> ST s (i, i) Source # getNumElements :: Ix i => STUArray s i ( Ptr a) -> ST s Int newArray :: Ix i => (i, i) -> Ptr a -> ST s ( STUArray s i ( Ptr a)) Source # newArray_ :: Ix i => (i, i) -> ST s ( STUArray s i ( Ptr a)) Source # unsafeNewArray_ :: Ix i => (i, i) -> ST s ( STUArray s i ( Ptr a)) unsafeRead :: Ix i => STUArray s i ( Ptr a) -> Int -> ST s ( Ptr a) unsafeWrite :: Ix i => STUArray s i ( Ptr a) -> Int -> Ptr a -> ST s () |
|
Functor ( URec ( Ptr ()) :: Type -> Type ) |
Since: base-4.9.0.0 |
Eq ( URec ( Ptr ()) p) |
Since: base-4.9.0.0 |
Ord ( URec ( Ptr ()) p) |
Since: base-4.9.0.0 |
Defined in GHC.Generics compare :: URec ( Ptr ()) p -> URec ( Ptr ()) p -> Ordering Source # (<) :: URec ( Ptr ()) p -> URec ( Ptr ()) p -> Bool Source # (<=) :: URec ( Ptr ()) p -> URec ( Ptr ()) p -> Bool Source # (>) :: URec ( Ptr ()) p -> URec ( Ptr ()) p -> Bool Source # (>=) :: URec ( Ptr ()) p -> URec ( Ptr ()) p -> Bool Source # max :: URec ( Ptr ()) p -> URec ( Ptr ()) p -> URec ( Ptr ()) p Source # min :: URec ( Ptr ()) p -> URec ( Ptr ()) p -> URec ( Ptr ()) p Source # |
|
Generic ( URec ( Ptr ()) p) |
Since: base-4.9.0.0 |
data URec ( Ptr ()) (p :: k) |
Used for marking occurrences of
Since: base-4.9.0.0 |
type Rep1 ( URec ( Ptr ()) :: k -> Type ) | |
Defined in GHC.Generics |
|
type Rep ( URec ( Ptr ()) p) | |
Defined in GHC.Generics |
module Data.Word