diff options
author | Justus Winter <justus@gnupg.org> | 2016-10-09 00:13:46 +0200 |
---|---|---|
committer | Justus Winter <justus@gnupg.org> | 2017-09-12 10:41:35 +0200 |
commit | 074f0ea9799b2fa5297eb120d68e0a97cf1b40ac (patch) | |
tree | 232d67a67fe1ec02978d174a3f4dc12a68df49c3 /libnetfs | |
parent | 5fef1b7f22ec0ee3730b80bbf972dbf9a8995091 (diff) | |
download | hurd-074f0ea9799b2fa5297eb120d68e0a97cf1b40ac.tar.gz hurd-074f0ea9799b2fa5297eb120d68e0a97cf1b40ac.tar.bz2 hurd-074f0ea9799b2fa5297eb120d68e0a97cf1b40ac.zip |
Normalize path of translators.
* libdiskfs/dir-lookup.c (diskfs_S_dir_lookup): Strip trailing
slashes.
* libnetfs/dir-lookup.c (netfs_S_dir_lookup): Likewise.
Diffstat (limited to 'libnetfs')
-rw-r--r-- | libnetfs/dir-lookup.c | 8 |
1 files changed, 7 insertions, 1 deletions
diff --git a/libnetfs/dir-lookup.c b/libnetfs/dir-lookup.c index 321ee6e1..bfac2acd 100644 --- a/libnetfs/dir-lookup.c +++ b/libnetfs/dir-lookup.c @@ -277,6 +277,7 @@ netfs_S_dir_lookup (struct protid *dircred, { char *translator_path = strdupa (relpath); + char *end; char *complete_path; if (nextname != NULL) { @@ -284,12 +285,17 @@ netfs_S_dir_lookup (struct protid *dircred, NEXTNAME points to the next component, locate the end of the current component and use it to trim TRANSLATOR_PATH. */ - char *end = nextname; + end = nextname; while (*end != 0) end--; translator_path[end - filename_start] = '\0'; } + /* Trim trailing slashes. */ + end = &translator_path[strlen (translator_path) - 1]; + while (*end == '/' && end >= translator_path) + *end = '\0', end--; + if (dircred->po->path == NULL || !strcmp (dircred->po->path,".")) /* dircred is the root directory. */ |