mirror of
git://git.savannah.gnu.org/libtool.git
synced 2025-01-12 14:06:37 +08:00
2c769d10a2
* libltdl/m4/ltdl.m4 (LTDL_INIT): Check for a libltdl that provides lt_dladvise_preopen when deciding if installed libltdl is 'new enough'. * libltdl/libltdl/lt__private.h (lt__advise): Add a new is_preload flag. * libltdl/ltdl.c (lt_dladvise_preload): New api call to set it. (try_dlopen): If it is set, and the search of preloaded modules didn't return a match, don't bother searching the filesystem. * libltdl/ltdl.h (lt_dladvise_preload): Declare it. * doc/libtool.texi (Libltdl Interface): Document it. * tests/lt_dladvise.at: Test it (and incidentally add some test coverage for `libtool -dlpreopen'). * NEWS: Announce it.
163 lines
5.6 KiB
C
163 lines
5.6 KiB
C
/* ltdl.h -- generic dlopen functions
|
||
|
||
Copyright (C) 1998-2000, 2004, 2005,
|
||
2007, 2008 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; see the file COPYING.LIB. If not, a
|
||
copy can be downloaded from http://www.gnu.org/licenses/lgpl.html,
|
||
or obtained by writing to the Free Software Foundation, Inc.,
|
||
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
||
*/
|
||
|
||
/* 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
|
||
#define LTDL_SET_PRELOADED_SYMBOLS() LT_STMT_START{ \
|
||
extern const lt_dlsymlist lt_preloaded_symbols[]; \
|
||
lt_dlpreload_default(lt_preloaded_symbols); \
|
||
}LT_STMT_END
|
||
|
||
|
||
|
||
|
||
/* --- 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)*/
|