External code can be loaded into a running Scheme 48 process
and C object-file bindings can be dereferenced at runtime and
their values called
(although not all versions of Unix support all of this).
The required Scheme functions are in the structure dynamic-externals
.
Dynamic-load
loads the named file into the current
process, raising an exception if the file cannot be found or if dynamic
loading is not supported by the operating system.
The file must have been compiled and linked appropriately.
For Linux, the following commands compile foo.c
into a
file foo.so
that can be loaded dynamically.
% gcc -c -o foo.o foo.c % ld -shared -o foo.so foo.o
(get-external string) -> external
(external? x) -> boolean
(external-name external) -> string
(external-value external) -> byte-vector
Get-external
returns an external object that contains the
value of name
, raising an exception if there is no such
value in the current process.
External?
is the predicate for externals, and
external-name
and external-value
return the name and
value of an external.
The value is returned as byte vector of length four (on 32-bit
architectures).
The value is that which was extant when get-external
was
called.
The following two functions can be used to update the values of
externals.
Lookup-external
updates the value of external
by looking up its
name in the current process, returning #t
if the name is bound
and #f
if it is not.
Lookup-all-externals
calls lookup-external
on all extant
externals, returning #f
any are unbound.
An external whose value is a C procedure can be called using
call-external
.
See
the section on calling C functions from Scheme
for more information.
In some versions of Unix retrieving a value from the current process may require a non-trivial amount of computation. We recommend that a dynamically-loaded file contain a single initialization procedure that creates shared bindings for the values exported by the file.
Previous: Dynamic loading | Next: Dynamic loading