(original) (raw)

{-# LANGUAGE Trustworthy #-} {-# LANGUAGE NoImplicitPrelude #-}


-- Maintainer : ffi@haskell.org -- Stability : provisional -- Portability : portable

-- This module is part of the Foreign Function Interface (FFI) and will usually -- be imported via the module "Foreign".


module Foreign.StablePtr ( -- * Stable references to Haskell values StablePtr -- abstract , newStablePtr , deRefStablePtr , freeStablePtr , castStablePtrToPtr , castPtrToStablePtr , -- ** The C-side interface

      -- $cinterface
    ) where

import GHC.Stable

-- $cinterface

-- The following definition is available to C programs inter-operating with -- Haskell code when including the header @HsFFI.h@.

-- > typedef void HsStablePtr; / C representation of a StablePtr */

-- Note that no assumptions may be made about the values representing stable -- pointers. In fact, they need not even be valid memory addresses. The only -- guarantee provided is that if they are passed back to Haskell land, the -- function 'deRefStablePtr' will be able to reconstruct the -- Haskell value referred to by the stable pointer.