aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog3
-rw-r--r--dlfcn/dlerror.c22
2 files changed, 16 insertions, 9 deletions
diff --git a/ChangeLog b/ChangeLog
index aae57fa..e41d9a4 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -11,6 +11,9 @@
place pointed to.
* include/dlfcn.h: Adjust _dl_catch_error prototype.
* sysdeps/generic/ldsodefs.h: Adjust _dl_signal_error prototype.
+ * dlfcn/dlerror.c (struct dl_action_result): Add objname member.
+ (dlerror): Add objname to asprintf() parameters.
+ (_dl_error_run): Pass new parameter to _dl_catch_error.
* elf/dl-libc.c (dlerror_run): Pass new parameter to _dl_catch_error.
* elf/dl-open.c (_dl_open): Likewise.
* elf/rtld.c (dl_main): Likewise.
diff --git a/dlfcn/dlerror.c b/dlfcn/dlerror.c
index b4ffde5..972a9ac 100644
--- a/dlfcn/dlerror.c
+++ b/dlfcn/dlerror.c
@@ -1,5 +1,5 @@
/* Return error detail for failing <dlfcn.h> functions.
- Copyright (C) 1995, 1996, 1997, 1998, 1999 Free Software Foundation, Inc.
+ Copyright (C) 1995, 96, 97, 98, 99, 2000 Free Software Foundation, Inc.
This file is part of the GNU C Library.
The GNU C Library is free software; you can redistribute it and/or
@@ -18,6 +18,7 @@
Boston, MA 02111-1307, USA. */
#include <dlfcn.h>
+#include <libintl.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
@@ -28,7 +29,8 @@ struct dl_action_result
{
int errcode;
int returned;
- char *errstring;
+ const char *objname;
+ const char *errstring;
};
static struct dl_action_result last_result;
static struct dl_action_result *static_buf;
@@ -59,20 +61,21 @@ dlerror (void)
/* We can now free the string. */
if (result->errstring != NULL)
{
- free (result->errstring);
+ free ((char *) result->errstring);
result->errstring = NULL;
}
buf = NULL;
}
else
{
- buf = result->errstring;
+ buf = (char *) result->errstring;
if (result->errcode != 0
- && __asprintf (&buf, "%s: %s",
- result->errstring, strerror (result->errcode)) != -1)
+ && __asprintf (&buf, "%s: %s: %s",
+ result->objname, _(result->errstring),
+ strerror (result->errcode)) != -1)
{
/* We don't need the error string anymore. */
- free (result->errstring);
+ free ((char *) result->errstring);
result->errstring = buf;
}
@@ -119,9 +122,10 @@ _dlerror_run (void (*operate) (void *), void *args)
if (result->errstring != NULL)
/* Free the error string from the last failed command. This can
happen if `dlerror' was not run after an error was found. */
- free (result->errstring);
+ free ((char *) result->errstring);
- result->errcode = _dl_catch_error (&result->errstring, operate, args);
+ result->errcode = _dl_catch_error (&result->objname, &result->errstring,
+ operate, args);
/* If no error we mark that no error string is available. */
result->returned = result->errstring == NULL;