DynaLoader - Automatic Dynamic Loading of Perl Modules
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.
Internal interface summary
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_pathis 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_pathshould also be initialized with any other directories that can be determined from the environment at run-time (such asLD_LIBRARY_PATHfor SunOS). After initialization,@dl_library_pathcan be manipulated by an application using push and unshift before callingdl_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 thatdl_load_file()calls might require an absolute pathname. Thedl_findfile()function and@dl_library_pathcan 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_usingfor 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
errnoin 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_debugis set true. Currently, setting$dl_debugonly affects the Perl side of the DynaLoader. These messages should help an application developer to resolve any DynaLoader usage problems.$dl_debugis 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-DDEBUGGINGflag. This can also be set via thePERL_DL_DEBUGenvironment 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_pathby 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-lnameare 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-Ldirand-lnameis 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 autoloadabledl_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$librefwill typically be$filenameor a pointer to a buffer containing$filename. The application should not examine or alter$librefin any way.) Below are some of the functions that do the real work. Such functions should use the current values of@dl_require_symbolsand@dl_resolve_usingif 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, thendl_find_symbol()should search for function symbols first and then search for other types. The exact manner in which the address is returned in$symrefis not currently defined. The only initial requirement is that$symrefcan 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_nameusing$symrefas a pointer to the function that implements the routine. This is simply a direct call tonewXSUB(). It returns a reference to the installed function. The$filenameparameter is used by Perl to identify the source file for the function if required by die, caller, or the debugger. If$filenameis 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_symbolsto("boot_$module") - Executes an auto/$module/$module.bs file if it exists (typically used to add to
@dl_resolve_usingany 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 bydl_install_xsub()for speed)
- Locates an auto/$module directory by searching