|
package YourModule;
require DynaLoader;
@ISA = qw(... DynaLoader ...);
bootstrap YourModule; This module defines the standard Perl interface to the dynamic linking
mechanisms available on many platforms. A common theme throughout the
module system is that using a module should be easy, even if the
module itself (or the installation of the module) is more complicated as
a result. This applies particularly to the DynaLoader. To use it in
your own module, all you need are the incantations listed above in the
synopsis. This will work whether YourModule is statically or
dynamically linked into Perl. (This is a Configure option for each
module.) The bootstrap() method will either
call YourModule's bootstrap routine directly if YourModule is statically
linked into Perl, or if not, YourModule will inherit the bootstrap() method from DynaLoader, which will do everything necessary to load in your module, and then call YourModule's bootstrap() method for you, as
if it were there all the time and you called it yourself. Piece of cake,
of the have-it-and-eat-it-too variety. The rest of this description talks about the DynaLoader from the
viewpoint of someone who wants to extend the DynaLoader module to a new
architecture. The Configure process selects which kind of dynamic
loading to use by choosing to link in one of several C implementations,
which must be linked into perl statically. (This is unlike other
C extensions, which provide a single implementation, which may be linked
in either statically or dynamically.) The DynaLoader is designed to be a very simple, high-level interface that
is sufficiently general to cover the requirements of SunOS, HP-UX,
NeXT, Linux, VMS, Win-32, and other platforms. By itself, though,
DynaLoader is practically useless for accessing non-Perl libraries
because it provides almost no Perl-to-C "glue". There is, for example,
no mechanism for calling a C library function or supplying its arguments
in any sort of portable form. This job is delegated to the other
extension modules that you may load in by using DynaLoader. Variables:
@dl_library_path
@dl_resolve_using
@dl_require_symbols
$dl_debug
Subroutines:
bootstrap($modulename);
@filepaths = dl_findfile(@names);
$filepath = dl_expandspec($spec);
$libref = dl_load_file($filename);
$symref = dl_find_symbol($libref, $symbol);
@symbols = dl_undef_symbols();
dl_install_xsub($name, $symref [, $filename]);
$message = dl_error; The bootstrap() and dl_findfile() routines
are standard across all platforms, and so are defined in
DynaLoader.pm. The rest of the functions are supplied by
the particular .xs file that supplies the implementation
for the platform. (You can examine the existing implementations in the
ext/DynaLoader/*.xs files in the Perl
source directory. You should also read DynaLoader.pm, of
course.) These implementations may also tweak the default values of the
variables listed below. @dl_library_path The default list of directories in which dl_findfile() will
search for libraries. Directories are searched in the order they are
given in this array variable, beginning with subscript 0.
@dl_library_path is initialized to hold the list of "normal"
directories (/usr/lib and so on) determined by the Perl installation
script, Configure, and given by
$Config{'libpth'} . This
is to ensure portability across a wide range of platforms.
@dl_library_path should also be initialized with any other directories
that can be determined from the environment at run-time (such as
LD_LIBRARY_PATH for SunOS).
After initialization, @dl_library_path can be manipulated by an
application using push and unshift before calling
dl_findfile() .
unshift can be used to add directories to the front of the search order
either to save search time or to override standard libraries with the same
name.
The load function that dl_load_file() calls might require an absolute
pathname. The dl_findfile() function and @dl_library_path
can be used to search for and return the absolute pathname for the
library/object that you wish to load. @dl_resolve_using A list of additional libraries or other shared objects that can be
used to resolve any undefined symbols that might be generated by a
later call to dl_load_file() .
This is only required on some platforms that do not handle dependent
libraries automatically. For example, the Socket extension shared library
(auto/Socket/Socket.so) contains references to many socket functions
that need to be resolved when it's loaded. Most platforms will
automatically know where to find the "dependent" library (for example,
/usr/lib/libsocket.so). A few platforms
need to be told the location
of the dependent library explicitly. Use @dl_resolve_using for this.
Example: @dl_resolve_using = dl_findfile('-lsocket'); @dl_require_symbols A list of one or more symbol names that are in the library/object file
to be dynamically loaded. This is only required on some platforms. dl_error $message = dl_error(); Error message text from the last failed DynaLoader function. Note that, similar
to errno in UNIX, a successful function call does not reset
this message. Implementations should detect the error as soon as it occurs in
any of the other functions and save the corresponding message for later
retrieval. This will avoid problems on some platforms (such as SunOS) where the
error message is very temporary (see, for example, dlerror(3)). $dl_debug Internal debugging messages are enabled when $dl_debug is set
true. Currently, setting $dl_debug only affects the Perl side
of the DynaLoader. These messages should help an application
developer to resolve any DynaLoader usage problems.
$dl_debug is set to $ENV{'PERL_DL_DEBUG'} if defined.
For the DynaLoader developer and porter there is a similar debugging
variable added to the C code (see dlutils.c) and enabled if Perl was
built with the -DDEBUGGING flag. This can also be set via the
PERL_DL_DEBUG environment variable. Set to 1 for minimal information or
higher for more. dl_findfile @filepaths = dl_findfile(@names) Determines the full paths (including file suffix) of one or more loadable files,
given their generic names and optionally one or more directories. Searches
directories in @dl_library_path by default and returns an
empty list if no files were found. Names can be specified in a variety of
platform-independent forms. Any names in the form -lname are
converted into libname.*, where .* is an appropriate suffix
for the platform. If a name does not already have a suitable prefix or suffix,
then the corresponding file will be sought by trying prefix and suffix
combinations appropriate to the platform: $name.o,
lib$name.* and $name. If any
directories are included in @names , they are searched before
@dl_library_path . Directories may be specified as
-Ldir . Any other names are treated as filenames to be
searched for.
Using arguments of the form -Ldir and
-lname is recommended. Example: @dl_resolve_using = dl_findfile(qw(-L/usr/5lib -lposix)); dl_expandspec $filepath = dl_expandspec($spec) Some unusual systems such as VMS require special filename handling in order to
deal with symbolic names for files (that is, VMS's Logical Names). To support
these systems a dl_expandspec() function can be implemented
either in the dl_*.xs file or code can
be added to the autoloadable dl_expandspec() function in
DynaLoader.pm. dl_load_file $libref = dl_load_file($filename) Dynamically load $filename , which must be the path to a shared object
or library. An opaque "library reference" is returned as a handle for
the loaded object. dl_load_file() returns the undefined value on error.
(On systems that provide a handle for the loaded object such as SunOS
and HP-UX, the returned handle will be $libref . On other systems
$libref will typically be $filename or a pointer to a
buffer containing $filename .
The application should not examine or alter $libref in any way.)
Below are some of the functions that do the real work. Such functions
should use the current values of @dl_require_symbols and
@dl_resolve_using if required. SunOS: dlopen($filename)
HP-UX: shl_load($filename)
Linux: dld_create_reference(@dl_require_symbols); dld_link($filename)
NeXT: rld_load($filename, @dl_resolve_using)
VMS: lib$find_image_symbol($filename, $dl_require_symbols[0]) dl_find_symbol $symref = dl_find_symbol($libref, $symbol) Returns the address of the symbol $symbol , or the undefined value
if not found. If the
target system has separate functions to search for symbols of different
types, then dl_find_symbol() should search for function symbols first
and then search for other types.
The exact manner in which the address is returned in $symref is not
currently defined. The only initial requirement is that $symref can
be passed to, and understood by, dl_install_xsub() . Here are some
current implementations: SunOS: dlsym($libref, $symbol)
HP-UX: shl_findsym($libref, $symbol)
Linux: dld_get_func($symbol) and/or dld_get_symbol($symbol)
NeXT: rld_lookup("_$symbol")
VMS: lib$find_image_symbol($libref, $symbol) dl_undef_symbols @symbols = dl_undef_symbols() Returns a list of symbol names which remain undefined after
dl_load_file() . It returns () if these
names are not known. Don't worry if your platform does not provide a mechanism
for this. Most platforms do not need it and hence do not provide it; they just
return an empty list. dl_install_xsub dl_install_xsub($perl_name, $symref [, $filename]) Creates a new Perl external subroutine named $perl_name using
$symref as a pointer to the function that implements the routine.
This is simply a direct call to newXSUB() . It returns a reference to
the installed function.
The $filename parameter is used by Perl to identify the source file for
the function if required by die, caller, or the debugger. If
$filename is not defined, then DynaLoader will be used. bootstrap() bootstrap($module); This is the normal entry point for automatic dynamic loading in Perl. It performs the following actions: Locates an auto/$module directory by searching @INC Uses dl_findfile() to determine the filename to load Sets @dl_require_symbols to ("boot_$module") Executes an auto/$module/$module.bs file if it exists
(typically used to add to @dl_resolve_using any files that
are required to load the module on the current platform) Calls dl_load_file() to load the file Calls dl_undef_symbols() and warns if any symbols are undefined Calls dl_find_symbol() for "boot_$module" Calls dl_install_xsub() to install it as ${module}::bootstrap Calls &{"${module}::bootstrap"} to bootstrap the module (actually
it uses the function reference returned by dl_install_xsub() for speed)
|