mirror of
git://git.savannah.gnu.org/libtool.git
synced 2024-11-27 06:09:57 +08:00
ec703fac9e
* AUTHORS, HACKING, Makefile.am, bootstrap.conf, build-aux/edit-readme-alpha, build-aux/no-bogus-m4-defines, cfg.mk, configure.ac, libltdl/configure.ac, libltdl/libltdl/lt__alloc.h, libltdl/libltdl/lt__argz_.h, libltdl/libltdl/lt__dirent.h, libltdl/libltdl/lt__glibc.h, libltdl/libltdl/lt__private.h, libltdl/libltdl/lt__strl.h, libltdl/libltdl/lt_dlloader.h, libltdl/libltdl/lt_error.h, libltdl/libltdl/lt_system.h, libltdl/libltdl/slist.h, libltdl/loaders/dld_link.c, libltdl/loaders/dlopen.c, libltdl/loaders/dyld.c, libltdl/loaders/load_add_on.c, libltdl/loaders/loadlibrary.c, libltdl/loaders/preopen.c, libltdl/loaders/shl_load.c, libltdl/lt__alloc.c, libltdl/lt__argz.c, libltdl/lt__dirent.c, libltdl/lt__strl.c, libltdl/lt_dlloader.c, libltdl/lt_error.c, libltdl/ltdl.c, libltdl/ltdl.h, libltdl/ltdl.mk, libltdl/slist.c, tests/am-subdir.at, tests/archive-in-archive.at, tests/bindir.at, tests/bug_62343.at, tests/cdemo.at, tests/cmdline_wrap.at, tests/configure-funcs.at, tests/configure-iface.at, tests/convenience.at, tests/ctor.at, tests/cwrapper.at, tests/darwin.at, tests/demo.at, tests/depdemo.at, tests/deplib-in-subdir.at, tests/deplibs-ident.at, tests/deplibs-mingw.at, tests/destdir.at, tests/dlloader-api.at, tests/dumpbin-symbols.at, tests/duplicate_conv.at, tests/duplicate_deps.at, tests/duplicate_members.at, tests/early-libtool.at, tests/exceptions.at, tests/execute-mode.at, tests/exeext.at, tests/export-def.at, tests/export.at, tests/f77demo.at, tests/fail.at, tests/fcdemo.at, tests/flags.at, tests/help.at, tests/indirect_deps.at, tests/infer-tag.at, tests/inherited_flags.at, tests/install.at, tests/lalib-syntax.at, tests/libtool.at, tests/libtoolize.at, tests/link-order.at, tests/link-order2.at, tests/loadlibrary.at, tests/localization.at, tests/lt_dladvise.at, tests/lt_dlexit.at, tests/lt_dlopen.at, tests/lt_dlopen_a.at, tests/lt_dlopenext.at, tests/ltdl-api.at, tests/ltdl-libdir.at, tests/mdemo.at, tests/need_lib_prefix.at, tests/no-executables.at, tests/nocase.at, tests/nonrecursive.at, tests/old-m4-iface.at, tests/pic_flag.at, tests/recursive.at, tests/resident.at, tests/runpath-in-lalib.at, tests/search-path.at, tests/shlibpath.at, tests/slist.at, tests/standalone.at, tests/static.at, tests/stresstest.at, tests/subproject.at, tests/sysroot.at, tests/tagdemo.at, tests/template.at, tests/testsuite.at, tests/versioning.at, tests/with-pic.at: Replace FSF address in each file's license block with a URL that points to licenses online hosted by GNU.
159 lines
5.4 KiB
C
159 lines
5.4 KiB
C
/* ltdl.h -- generic dlopen functions
|
|
|
|
Copyright (C) 1998-2000, 2004-2005, 2007-2008, 2011-2019, 2021-2024
|
|
Free Software Foundation, Inc.
|
|
Written by Thomas Tanner, 1998
|
|
|
|
NOTE: The canonical source of this file is maintained with the
|
|
GNU Libtool package. Report bugs to bug-libtool@gnu.org.
|
|
|
|
GNU Libltdl is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public
|
|
License as published by the Free Software Foundation; either
|
|
version 2 of the License, or (at your option) any later version.
|
|
|
|
As a special exception to the GNU Lesser General Public License,
|
|
if you distribute this file as part of a program or library that
|
|
is built using GNU Libtool, you may include this file under the
|
|
same distribution terms that you use for the rest of that program.
|
|
|
|
GNU Libltdl is distributed in the hope that it will be useful,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
GNU Lesser General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
License along with GNU Libltdl. If not, see <https://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
/* Only include this header file once. */
|
|
#if !defined LTDL_H
|
|
#define LTDL_H 1
|
|
|
|
#include <libltdl/lt_system.h>
|
|
#include <libltdl/lt_error.h>
|
|
#include <libltdl/lt_dlloader.h>
|
|
|
|
LT_BEGIN_C_DECLS
|
|
|
|
|
|
/* LT_STRLEN can be used safely on NULL pointers. */
|
|
#define LT_STRLEN(s) (((s) && (s)[0]) ? strlen (s) : 0)
|
|
|
|
/* --- DYNAMIC MODULE LOADING API --- */
|
|
|
|
|
|
typedef struct lt__handle *lt_dlhandle; /* A loaded module. */
|
|
|
|
/* Initialisation and finalisation functions for libltdl. */
|
|
LT_SCOPE int lt_dlinit (void);
|
|
LT_SCOPE int lt_dlexit (void);
|
|
|
|
/* Module search path manipulation. */
|
|
LT_SCOPE int lt_dladdsearchdir (const char *search_dir);
|
|
LT_SCOPE int lt_dlinsertsearchdir (const char *before,
|
|
const char *search_dir);
|
|
LT_SCOPE int lt_dlsetsearchpath (const char *search_path);
|
|
LT_SCOPE const char *lt_dlgetsearchpath (void);
|
|
LT_SCOPE int lt_dlforeachfile (
|
|
const char *search_path,
|
|
int (*func) (const char *filename, void *data),
|
|
void *data);
|
|
|
|
/* User module loading advisors. */
|
|
LT_SCOPE int lt_dladvise_init (lt_dladvise *advise);
|
|
LT_SCOPE int lt_dladvise_destroy (lt_dladvise *advise);
|
|
LT_SCOPE int lt_dladvise_ext (lt_dladvise *advise);
|
|
LT_SCOPE int lt_dladvise_resident (lt_dladvise *advise);
|
|
LT_SCOPE int lt_dladvise_local (lt_dladvise *advise);
|
|
LT_SCOPE int lt_dladvise_global (lt_dladvise *advise);
|
|
LT_SCOPE int lt_dladvise_preload (lt_dladvise *advise);
|
|
|
|
/* Portable libltdl versions of the system dlopen() API. */
|
|
LT_SCOPE lt_dlhandle lt_dlopen (const char *filename);
|
|
LT_SCOPE lt_dlhandle lt_dlopenext (const char *filename);
|
|
LT_SCOPE lt_dlhandle lt_dlopenadvise (const char *filename,
|
|
lt_dladvise advise);
|
|
LT_SCOPE void * lt_dlsym (lt_dlhandle handle, const char *name);
|
|
LT_SCOPE const char *lt_dlerror (void);
|
|
LT_SCOPE int lt_dlclose (lt_dlhandle handle);
|
|
|
|
|
|
|
|
/* --- PRELOADED MODULE SUPPORT --- */
|
|
|
|
|
|
/* A preopened symbol. Arrays of this type comprise the exported
|
|
symbols for a dlpreopened module. */
|
|
typedef struct {
|
|
const char *name;
|
|
void *address;
|
|
} lt_dlsymlist;
|
|
|
|
typedef int lt_dlpreload_callback_func (lt_dlhandle handle);
|
|
|
|
LT_SCOPE int lt_dlpreload (const lt_dlsymlist *preloaded);
|
|
LT_SCOPE int lt_dlpreload_default (const lt_dlsymlist *preloaded);
|
|
LT_SCOPE int lt_dlpreload_open (const char *originator,
|
|
lt_dlpreload_callback_func *func);
|
|
|
|
#define lt_preloaded_symbols lt__PROGRAM__LTX_preloaded_symbols
|
|
/* Ensure C linkage. */
|
|
extern LT_DLSYM_CONST lt_dlsymlist lt__PROGRAM__LTX_preloaded_symbols[];
|
|
|
|
#define LTDL_SET_PRELOADED_SYMBOLS() \
|
|
lt_dlpreload_default(lt_preloaded_symbols)
|
|
|
|
|
|
|
|
/* --- MODULE INFORMATION --- */
|
|
|
|
|
|
/* Associating user data with loaded modules. */
|
|
typedef void * lt_dlinterface_id;
|
|
typedef int lt_dlhandle_interface (lt_dlhandle handle, const char *id_string);
|
|
|
|
LT_SCOPE lt_dlinterface_id lt_dlinterface_register (const char *id_string,
|
|
lt_dlhandle_interface *iface);
|
|
LT_SCOPE void lt_dlinterface_free (lt_dlinterface_id key);
|
|
LT_SCOPE void * lt_dlcaller_set_data (lt_dlinterface_id key,
|
|
lt_dlhandle handle, void *data);
|
|
LT_SCOPE void * lt_dlcaller_get_data (lt_dlinterface_id key,
|
|
lt_dlhandle handle);
|
|
|
|
|
|
/* Read only information pertaining to a loaded module. */
|
|
typedef struct {
|
|
char * filename; /* file name */
|
|
char * name; /* module name */
|
|
int ref_count; /* number of times lt_dlopened minus
|
|
number of times lt_dlclosed. */
|
|
unsigned int is_resident:1; /* module can't be unloaded. */
|
|
unsigned int is_symglobal:1; /* module symbols can satisfy
|
|
subsequently loaded modules. */
|
|
unsigned int is_symlocal:1; /* module symbols are only available
|
|
locally. */
|
|
} lt_dlinfo;
|
|
|
|
LT_SCOPE const lt_dlinfo *lt_dlgetinfo (lt_dlhandle handle);
|
|
|
|
LT_SCOPE lt_dlhandle lt_dlhandle_iterate (lt_dlinterface_id iface,
|
|
lt_dlhandle place);
|
|
LT_SCOPE lt_dlhandle lt_dlhandle_fetch (lt_dlinterface_id iface,
|
|
const char *module_name);
|
|
LT_SCOPE int lt_dlhandle_map (lt_dlinterface_id iface,
|
|
int (*func) (lt_dlhandle handle, void *data),
|
|
void *data);
|
|
|
|
|
|
|
|
/* Deprecated module residency management API. */
|
|
LT_SCOPE int lt_dlmakeresident (lt_dlhandle handle);
|
|
LT_SCOPE int lt_dlisresident (lt_dlhandle handle);
|
|
|
|
#define lt_ptr void *
|
|
|
|
LT_END_C_DECLS
|
|
|
|
#endif /*!defined LTDL_H*/
|