The interface defined in this section allows the user to load shared
libraries (.so
files on most Unix systems, .dll
files on Windows). This interface is portable to Windows as well as to
Unix machines providing dlopen(2) (Solaris, Linux,
FreeBSD, Irix and many more) or shl_open(2) (HP/UX). It
is advised to use the predicates from section
12.2.3 in your application.
open_shared_object(File, Handle, [])
. See also
open_shared_object/3, load_foreign_library/1
and use_foreign_library/1.
On errors, an exception shared_object(Action, Message)
is raised. Message is the return value from dlerror().
RTLD_NOW
,
RTLD_LAZY
, RTLD_GLOBAL
, RTLD_NODELETE
,
RTLD_NOLOAD
and RTLD_DEEPBIND
on systems where
this predicate is implemented using dlopen() and these flags are
supported. If the flag is not supported on the target OS, the
corresponding option is silently ignored.
lazy
(default) or
now
.local
(default) or global
, making the new symbols available to
all subsequently loaded shared objects.now(true)
is the same as resolve(now)
.
Provided for backward compatibility.global(true)
is the same as visibility(global)
.
Provided for backward compatibility.false
, include RTLD_NODELETE
.false
, include RTLD_NOLOAD
. This returns a
handle to the object if it is already loaded and NULL
otherwise. It causes this predicate to fail silently if the
object is not loaded.true
, include RTLD_DEEPBIND
.Note that these flags may not be supported by your operating system. Check the documentation of dlopen() or equivalent on your operating system. Unsupported flags are silently ignored.