summaryrefslogtreecommitdiff
path: root/stdlib
diff options
context:
space:
mode:
authorUlrich Drepper <drepper@redhat.com>2002-07-11 16:34:20 +0000
committerUlrich Drepper <drepper@redhat.com>2002-07-11 16:34:20 +0000
commit3e0dd85b103492e6b91e8e3bf60a997b04eb967f (patch)
tree0f46ec1386858194c583a6c680ec6fda2a6e8450 /stdlib
parent1ae915d98db1e07cf332e8a1fc86f3432f5c3614 (diff)
downloadglibc-3e0dd85b103492e6b91e8e3bf60a997b04eb967f.tar
glibc-3e0dd85b103492e6b91e8e3bf60a997b04eb967f.tar.gz
glibc-3e0dd85b103492e6b91e8e3bf60a997b04eb967f.tar.bz2
glibc-3e0dd85b103492e6b91e8e3bf60a997b04eb967f.zip
Update.
2002-07-11 Ulrich Drepper <drepper@redhat.com> * Versions.def (libc): Add GLIBC_2.3. * stdlib/Versions [libc] (GLIBC_2.3): Add realpath. * stdlib/canonicalize.c: Add compatibility version for realpath and make new code available in GLIBC_2.3.
Diffstat (limited to 'stdlib')
-rw-r--r--stdlib/Versions4
-rw-r--r--stdlib/canonicalize.c20
2 files changed, 23 insertions, 1 deletions
diff --git a/stdlib/Versions b/stdlib/Versions
index c2e17e0096..fc1e5a1004 100644
--- a/stdlib/Versions
+++ b/stdlib/Versions
@@ -90,6 +90,10 @@ libc {
# used by new G++ ABI
__cxa_atexit; __cxa_finalize;
}
+ GLIBC_2.3 {
+ # Silent change in SUS.
+ realpath;
+ }
GLIBC_PRIVATE {
# functions which have an additional interface since they are
# are cancelable.
diff --git a/stdlib/canonicalize.c b/stdlib/canonicalize.c
index c859288147..3394048fb3 100644
--- a/stdlib/canonicalize.c
+++ b/stdlib/canonicalize.c
@@ -26,6 +26,8 @@
#include <errno.h>
#include <stddef.h>
+#include <shlib-compat.h>
+
/* Return the canonical absolute name of file NAME. A canonical name
does not contain any `.', `..' components nor any repeated path
separators ('/') or symlinks. All path components must exist. If
@@ -204,7 +206,23 @@ error:
free (rpath);
return NULL;
}
-weak_alias (__realpath, realpath)
+versioned_symbol (libc, __realpath, realpath, GLIBC_2_3);
+
+
+#if SHLIB_COMPAT(libc, GLIBC_2_0, GLIBC_2_3)
+char *
+__old_realpath (const char *name, char *resolved)
+{
+ if (resolved == NULL)
+ {
+ __set_errno (EINVAL);
+ return NULL;
+ }
+
+ return __realpath (name, resolved);
+}
+compat_symbol (libc, __old_realpath, realpath, GLIBC_2_0);
+#endif
char *