* RTLD_LAZY and not RTLD_NOW (NetBSD problem)

* Indent of plugin code
Initial
Stephane Bortzmeyer 20 years ago
parent 7671c535bc
commit 70c4dfb776

@ -192,10 +192,7 @@ main (argc, argv)
}
progname = (char *) argv[0];
poptcon = poptGetContext (NULL, argc,
argv,
options,
0);
poptcon = poptGetContext (NULL, argc, argv, options, 0);
while ((!module_find) && (result = poptGetNextOpt (poptcon)) != -1)
{
@ -431,18 +428,21 @@ main (argc, argv)
leftover = (char **) &argv[argc - remaining];
if (plugin_name)
{
ext = strstr(plugin_name, ".so");
ext = strstr (plugin_name, ".so");
if ((ext == NULL) || (strcmp (ext, ".so") != 0))
sprintf (plugin_name, "%s.so", plugin_name);
plugin = dlopen (plugin_name, RTLD_NOW);
if (!plugin) { /* retries with the absolute name */
complete_plugin_name = (char *) malloc(MAX_LINE);
/* RTLD_NOW makes dlopen fail silently on NetBSD */
plugin = dlopen (plugin_name, RTLD_LAZY);
if (!plugin)
{ /* retries with the absolute name */
complete_plugin_name = (char *) malloc (MAX_LINE);
sprintf (complete_plugin_name, "%s/%s", PLUGINS_DIR, plugin_name);
plugin = dlopen (complete_plugin_name, RTLD_NOW);
plugin = dlopen (complete_plugin_name, RTLD_LAZY);
}
if (!plugin)
{
err_sys ("Cannot load \"%s\" (I tried the short name, then the complete name in \"%s\"): %s",
err_sys
("Cannot load \"%s\" (I tried the short name, then the complete name in \"%s\"): %s",
plugin_name, PLUGINS_DIR, dlerror ());
}
plugin_init = dlsym (plugin, "init");
@ -1386,7 +1386,7 @@ main (argc, argv)
/* Clean */
if (plugin)
plugin_terminate();
plugin_terminate ();
/* It would be nice to clean here for OpenSSL */
#ifdef GNUTLS
if (ssl)

Loading…
Cancel
Save