diff options
Diffstat (limited to 'testsuite/tests/ffi')
-rw-r--r-- | testsuite/tests/ffi/should_compile/cc004.hs | 37 | ||||
-rw-r--r-- | testsuite/tests/ffi/should_compile/cc005.hs | 2 | ||||
-rw-r--r-- | testsuite/tests/ffi/should_compile/cc008.hs | 2 | ||||
-rw-r--r-- | testsuite/tests/ffi/should_compile/cc010.hs | 2 |
4 files changed, 22 insertions, 21 deletions
diff --git a/testsuite/tests/ffi/should_compile/cc004.hs b/testsuite/tests/ffi/should_compile/cc004.hs index fb754223b2..89c2aa8319 100644 --- a/testsuite/tests/ffi/should_compile/cc004.hs +++ b/testsuite/tests/ffi/should_compile/cc004.hs @@ -26,10 +26,10 @@ foreign import stdcall "m2" m16 :: IO Int16 foreign import stdcall "m3" m32 :: IO Int32 foreign import stdcall "m4" m64 :: IO Int64 -foreign import stdcall "dynamic" d8 :: Ptr a -> IO Int8 -foreign import stdcall "dynamic" d16 :: Ptr a -> IO Int16 -foreign import stdcall "dynamic" d32 :: Ptr a -> IO Int32 -foreign import stdcall "dynamic" d64 :: Ptr a -> IO Int64 +foreign import stdcall "dynamic" d8 :: FunPtr (IO Int8) -> IO Int8 +foreign import stdcall "dynamic" d16 :: FunPtr (IO Int16) -> IO Int16 +foreign import stdcall "dynamic" d32 :: FunPtr (IO Int32) -> IO Int32 +foreign import stdcall "dynamic" d64 :: FunPtr (IO Int64) -> IO Int64 foreign import ccall unsafe "kitchen" sink :: Ptr a @@ -49,19 +49,20 @@ foreign import ccall unsafe "kitchen" -> IO () +type Sink2 b = Ptr b + -> ByteArray# + -> MutableByteArray# RealWorld + -> Int + -> Int8 + -> Int16 + -> Int32 + -> Word8 + -> Word16 + -> Word32 + -> Float + -> Double + -> IO () + foreign import ccall unsafe "dynamic" - sink2 :: Ptr a - -> (Ptr b - -> ByteArray# - -> MutableByteArray# RealWorld - -> Int - -> Int8 - -> Int16 - -> Int32 - -> Word8 - -> Word16 - -> Word32 - -> Float - -> Double - -> IO ()) + sink2 :: Ptr (Sink2 b) -> Sink2 b diff --git a/testsuite/tests/ffi/should_compile/cc005.hs b/testsuite/tests/ffi/should_compile/cc005.hs index e057cfd233..7086480bfe 100644 --- a/testsuite/tests/ffi/should_compile/cc005.hs +++ b/testsuite/tests/ffi/should_compile/cc005.hs @@ -5,7 +5,7 @@ import Foreign.Ptr --import Foreign --import GlaExts --import Int --import Word -type Addr = Ptr () +type Addr = FunPtr (Int -> IO ()) foreign import ccall "wrapper" d8 :: (Int -> IO ()) -> IO Addr -- exporting functions diff --git a/testsuite/tests/ffi/should_compile/cc008.hs b/testsuite/tests/ffi/should_compile/cc008.hs index 2dd0bc99eb..b1581dd20d 100644 --- a/testsuite/tests/ffi/should_compile/cc008.hs +++ b/testsuite/tests/ffi/should_compile/cc008.hs @@ -2,7 +2,7 @@ module ShouldCompile where import Foreign -type Addr = Ptr () +type Addr = FunPtr (IO ()) newtype NPtr a = NPtr Addr foreign import ccall "wrapper" mkFoo :: IO () -> IO (NPtr Int) diff --git a/testsuite/tests/ffi/should_compile/cc010.hs b/testsuite/tests/ffi/should_compile/cc010.hs index dd34730d42..abdf0fc76f 100644 --- a/testsuite/tests/ffi/should_compile/cc010.hs +++ b/testsuite/tests/ffi/should_compile/cc010.hs @@ -1,5 +1,5 @@ module ShouldCompile where import Foreign -foreign import ccall "dynamic" imp :: Ptr () -> Int +foreign import ccall "dynamic" imp :: FunPtr Int -> Int f1 a = imp a + 1 f2 a = imp a + 2 |