mirror of
https://sourceware.org/git/glibc.git
synced 2025-01-18 06:30:05 +00:00
Update.
1999-01-17 Ulrich Drepper <drepper@cygnus.com> * stdlib/canonicalize.c (canonicalize): Update write pointer after realloc. Minor optimizations.
This commit is contained in:
parent
6bfdad38b3
commit
2ac51313f0
@ -1,3 +1,8 @@
|
|||||||
|
1999-01-17 Ulrich Drepper <drepper@cygnus.com>
|
||||||
|
|
||||||
|
* stdlib/canonicalize.c (canonicalize): Update write pointer after
|
||||||
|
realloc. Minor optimizations.
|
||||||
|
|
||||||
1999-01-16 Ulrich Drepper <drepper@cygnus.com>
|
1999-01-16 Ulrich Drepper <drepper@cygnus.com>
|
||||||
|
|
||||||
* po/no.po: Update from norwegian translation team.
|
* po/no.po: Update from norwegian translation team.
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
/* Return the canonical absolute name of a given file.
|
/* Return the canonical absolute name of a given file.
|
||||||
Copyright (C) 1996, 1997, 1998 Free Software Foundation, Inc.
|
Copyright (C) 1996, 1997, 1998, 1999 Free Software Foundation, Inc.
|
||||||
This file is part of the GNU C Library.
|
This file is part of the GNU C Library.
|
||||||
|
|
||||||
The GNU C Library is free software; you can redistribute it and/or
|
The GNU C Library is free software; you can redistribute it and/or
|
||||||
@ -92,16 +92,18 @@ canonicalize (const char *name, char *resolved)
|
|||||||
int n;
|
int n;
|
||||||
|
|
||||||
/* Skip sequence of multiple path-separators. */
|
/* Skip sequence of multiple path-separators. */
|
||||||
while (*start == '/') ++start;
|
while (*start == '/')
|
||||||
|
++start;
|
||||||
|
|
||||||
/* Find end of path component. */
|
/* Find end of path component. */
|
||||||
for (end = start; *end && *end != '/'; ++end);
|
for (end = start; *end && *end != '/'; ++end)
|
||||||
|
/* Nothing. */;
|
||||||
|
|
||||||
if (end - start == 0)
|
if (end - start == 0)
|
||||||
break;
|
break;
|
||||||
else if (strncmp (start, ".", end - start) == 0)
|
else if (end - start == 1 && start[0] == '.')
|
||||||
/* nothing */;
|
/* nothing */;
|
||||||
else if (strncmp (start, "..", end - start) == 0)
|
else if (end - start == 2 && start[0] == '.' && start[1] == '.')
|
||||||
{
|
{
|
||||||
/* Back up to previous component, ignore if at root already. */
|
/* Back up to previous component, ignore if at root already. */
|
||||||
if (dest > rpath + 1)
|
if (dest > rpath + 1)
|
||||||
@ -116,6 +118,8 @@ canonicalize (const char *name, char *resolved)
|
|||||||
|
|
||||||
if (dest + (end - start) >= rpath_limit)
|
if (dest + (end - start) >= rpath_limit)
|
||||||
{
|
{
|
||||||
|
ptrdiff_t dest_offset = dest - rpath;
|
||||||
|
|
||||||
if (resolved)
|
if (resolved)
|
||||||
{
|
{
|
||||||
__set_errno (ENAMETOOLONG);
|
__set_errno (ENAMETOOLONG);
|
||||||
@ -128,8 +132,10 @@ canonicalize (const char *name, char *resolved)
|
|||||||
new_size += path_max;
|
new_size += path_max;
|
||||||
rpath = realloc (rpath, new_size);
|
rpath = realloc (rpath, new_size);
|
||||||
rpath_limit = rpath + new_size;
|
rpath_limit = rpath + new_size;
|
||||||
if (!rpath)
|
if (rpath == NULL)
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
dest = rpath + dest_offset;
|
||||||
}
|
}
|
||||||
|
|
||||||
dest = __mempcpy (dest, start, end - start);
|
dest = __mempcpy (dest, start, end - start);
|
||||||
@ -166,8 +172,7 @@ canonicalize (const char *name, char *resolved)
|
|||||||
|
|
||||||
/* Careful here, end may be a pointer into extra_buf... */
|
/* Careful here, end may be a pointer into extra_buf... */
|
||||||
memmove (&extra_buf[n], end, len + 1);
|
memmove (&extra_buf[n], end, len + 1);
|
||||||
memcpy (extra_buf, buf, n);
|
name = end = memcpy (extra_buf, buf, n);
|
||||||
name = end = extra_buf;
|
|
||||||
|
|
||||||
if (buf[0] == '/')
|
if (buf[0] == '/')
|
||||||
dest = rpath + 1; /* It's an absolute symlink */
|
dest = rpath + 1; /* It's an absolute symlink */
|
||||||
@ -182,7 +187,7 @@ canonicalize (const char *name, char *resolved)
|
|||||||
--dest;
|
--dest;
|
||||||
*dest = '\0';
|
*dest = '\0';
|
||||||
|
|
||||||
return resolved ? strcpy (resolved, rpath) : rpath;
|
return resolved ? memcpy (resolved, rpath, dest - rpath + 1) : rpath;
|
||||||
|
|
||||||
error:
|
error:
|
||||||
if (resolved)
|
if (resolved)
|
||||||
|
Loading…
Reference in New Issue
Block a user