As a followup to the discussion earlier this week, I'd like to suggest the patch 
below. This
causes ltdl to _always_ set handler->info.name to a canonicalized library name, 
instead of
only doing it for libtool-created modules. The only disadvantage that I can see to 
doing this
is that when lt_dlsym is called for a non-libtool module, a spurious lookup for
"modulename_LTX_symbol" will be done, when it wasn't before. I can't see how this would
cause an actual problem for anyone, though, since it's not likely they'd have symbols 
named
that way if they're not using libtool to create their libraries.

With this change, lt_dlsym()-ing a symbol from a preloaded library works properly on 
my system;
it searches for the symbol with the *_LTX_ prefix, which means I don't have to 
forcibly add
that prefix in my code.

--- ltdl.dist   Wed Oct 15 07:11:08 2003
+++ ltdl.c      Wed Oct 15 07:37:39 2003
@@ -3092,8 +3092,34 @@

assert (base_name && *base_name);

-  /* Check whether we are opening a libtool module (.la extension).  */
   ext = strrchr (base_name, '.');
+
+  /* extract the module name from the file name */
+  name = LT_EMALLOC (char, ext - base_name + 1);
+  if (!name)
+    {
+      ++errors;
+      goto cleanup;
+    }
+
+  /* canonicalize the module name */
+  {
+    size_t i;
+    for (i = 0; i < ext - base_name; ++i)
+      {
+       if (isalnum ((int)(base_name[i])))
+         {
+           name[i] = base_name[i];
+         }
+       else
+         {
+           name[i] = '_';
+         }
+      }
+    name[ext - base_name] = LT_EOS_CHAR;
+  }
+
+  /* Check whether we are opening a libtool module (.la extension).  */
   if (ext && strcmp (ext, archive_ext) == 0)
     {
       /* this seems to be a libtool module */
@@ -3110,31 +3136,6 @@
         of libtool */
       int      installed = 1;

-      /* extract the module name from the file name */
-      name = LT_EMALLOC (char, ext - base_name + 1);
-      if (!name)
-       {
-         ++errors;
-         goto cleanup;
-       }
-
-      /* canonicalize the module name */
-      {
-        size_t i;
-        for (i = 0; i < ext - base_name; ++i)
-         {
-           if (isalnum ((int)(base_name[i])))
-             {
-               name[i] = base_name[i];
-             }
-           else
-             {
-               name[i] = '_';
-             }
-         }
-        name[ext - base_name] = LT_EOS_CHAR;
-      }
-
       /* Now try to open the .la file.  If there is no directory name
          component, try to find it first in user_search_path and then other
          prescribed paths.  Otherwise (or in any case if the module was not
        



_______________________________________________
Libtool mailing list
[EMAIL PROTECTED]
http://mail.gnu.org/mailman/listinfo/libtool

Reply via email to