Description
This module is part of the Foreign Function Interface (FFI) and will usually be imported via the module Foreign.
Stable references to Haskell valuesA stable pointer is a reference to a Haskell expression that is guaranteed not to be affected by garbage collection, i.e., it will neither be deallocated nor will the value of the stable pointer itself change during garbage collection (ordinary references may be relocated during garbage collection). Consequently, stable pointers can be passed to foreign code, which can treat it as an opaque reference to a Haskell value.
A value of type StablePtr a
is a stable pointer to a Haskell expression of type a
.
castStablePtrToPtr :: StablePtr a -> Ptr ()Source
Coerce a stable pointer to an address. No guarantees are made about the resulting value, except that the original stable pointer can be recovered by castPtrToStablePtr
. In particular, the address may not refer to an accessible memory location and any attempt to pass it to the member functions of the class Storable
leads to undefined behaviour.
The following definition is available to C programs inter-operating with Haskell code when including the header HsFFI.h
.
typedef void *HsStablePtr;
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.
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4