4
0
mirror of git://sourceware.org/git/newlib-cygwin.git synced 2025-01-19 12:59:21 +08:00

* path.cc (is_unc_share): Rename from slash_unc_prefix_p throughout.

* path.cc (normalize_posix_path): Process all Posix paths and map three or more
initial slashes to a single one.  Simplify processing following two initial
slashes.
(normalize_win32_path): Make last argument non-optional and do not check for
NULL value.
This commit is contained in:
Christopher Faylor 2004-04-20 18:45:16 +00:00
parent c8daf9983b
commit 9f9231b314
2 changed files with 37 additions and 40 deletions

View File

@ -1,3 +1,15 @@
2004-04-20 Christopher Faylor <cgf@alum.bu.edu>
* path.cc (is_unc_share): Rename from slash_unc_prefix_p throughout.
2004-04-20 Pierre Humblet <pierre.humblet@ieee.org>
* path.cc (normalize_posix_path): Process all Posix paths and map three
or more initial slashes to a single one. Simplify processing following
two initial slashes.
(normalize_win32_path): Make last argument non-optional and do not
check for NULL value.
2004-04-20 Pierre Humblet <pierre.humblet@ieee.org> 2004-04-20 Pierre Humblet <pierre.humblet@ieee.org>
* fhandler_disk_file.cc (fhandler_base::open_fs): Change * fhandler_disk_file.cc (fhandler_base::open_fs): Change

View File

@ -75,7 +75,7 @@ details. */
#include "cygtls.h" #include "cygtls.h"
#include <assert.h> #include <assert.h>
static int normalize_win32_path (const char *src, char *dst, char ** tail = 0); static int normalize_win32_path (const char *src, char *dst, char ** tail);
static void slashify (const char *src, char *dst, int trailing_slash_p); static void slashify (const char *src, char *dst, int trailing_slash_p);
static void backslashify (const char *src, char *dst, int trailing_slash_p); static void backslashify (const char *src, char *dst, int trailing_slash_p);
@ -202,7 +202,7 @@ normalize_posix_path (const char *src, char *dst, char **tail)
const char *in_src = src; const char *in_src = src;
char *in_dst = dst; char *in_dst = dst;
if (isdrive (src) || slash_unc_prefix_p (src)) if (isdrive (src) || *src == '\\')
goto win32_path; goto win32_path;
if (!isslash (src[0])) if (!isslash (src[0]))
@ -220,26 +220,12 @@ normalize_posix_path (const char *src, char *dst, char **tail)
*dst++ = '/'; *dst++ = '/';
} }
/* Two leading /'s? If so, preserve them. */ /* Two leading /'s? If so, preserve them. */
else if (isslash (src[1])) else if (isslash (src[1]) && !isslash (src[2]))
{ {
*dst++ = '/'; *dst++ = '/';
*dst++ = '/'; *dst++ = '/';
src += 2; src += 2;
if (isslash (*src))
{ /* Starts with three or more slashes - reset. */
dst = dst_start;
*dst++ = '/';
src = src_start + 1;
} }
else if (src[0] == '.' && isslash (src[1]))
{
*dst++ = '.';
*dst++ = '/';
src += 2;
}
}
else
*dst = '\0';
while (*src) while (*src)
{ {
@ -917,6 +903,21 @@ win32_device_name (const char *src_path, char *win32_path, device& dev)
return true; return true;
} }
/* is_unc_share: Return non-zero if PATH begins with //UNC/SHARE */
static bool __stdcall
is_unc_share (const char *path)
{
char *p = NULL;
int ret = (isdirsep (path[0])
&& isdirsep (path[1])
&& (isalnum (path[2]) || path[2] == '.')
&& ((p = strpbrk (path + 3, "\\/")) != NULL));
if (!ret || p == NULL)
return false;
return ret && isalnum (p[1]);
}
/* Normalize a Win32 path. /* Normalize a Win32 path.
/'s are converted to \'s in the process. /'s are converted to \'s in the process.
All duplicate \'s, except for 2 leading \'s, are deleted. All duplicate \'s, except for 2 leading \'s, are deleted.
@ -950,7 +951,7 @@ normalize_win32_path (const char *src, char *dst, char **tail)
{ {
if (dst[1] == ':') if (dst[1] == ':')
dst[2] = '\0'; dst[2] = '\0';
else if (slash_unc_prefix_p (dst)) else if (is_unc_share (dst))
{ {
char *p = strpbrk (dst + 2, "\\/"); char *p = strpbrk (dst + 2, "\\/");
if (p && (p = strpbrk (p + 1, "\\/"))) if (p && (p = strpbrk (p + 1, "\\/")))
@ -1005,8 +1006,7 @@ normalize_win32_path (const char *src, char *dst, char **tail)
if ((dst - dst_start) >= CYG_MAX_PATH) if ((dst - dst_start) >= CYG_MAX_PATH)
return ENAMETOOLONG; return ENAMETOOLONG;
} }
*dst = 0; *dst = '\0';
if (tail)
*tail = dst; *tail = dst;
debug_printf ("%s = normalize_win32_path (%s)", dst_start, src_start); debug_printf ("%s = normalize_win32_path (%s)", dst_start, src_start);
return 0; return 0;
@ -1075,21 +1075,6 @@ nofinalslash (const char *src, char *dst)
dst[len] = '\0'; dst[len] = '\0';
} }
/* slash_unc_prefix_p: Return non-zero if PATH begins with //UNC/SHARE */
int __stdcall
slash_unc_prefix_p (const char *path)
{
char *p = NULL;
int ret = (isdirsep (path[0])
&& isdirsep (path[1])
&& (isalnum (path[2]) || path[2] == '.')
&& ((p = strpbrk (path + 3, "\\/")) != NULL));
if (!ret || p == NULL)
return ret;
return ret && isalnum (p[1]);
}
/* conv_path_list: Convert a list of path names to/from Win32/POSIX. */ /* conv_path_list: Convert a list of path names to/from Win32/POSIX. */
static int static int
@ -1492,7 +1477,7 @@ mount_info::conv_to_win32_path (const char *src_path, char *dst, device& dev,
} }
else else
{ {
if (strchr (src_path, ':') == NULL && !slash_unc_prefix_p (src_path)) if (strchr (src_path, ':') == NULL && !is_unc_share (src_path))
set_flags (flags, PATH_BINARY); set_flags (flags, PATH_BINARY);
backslashify (src_path, dst, 0); backslashify (src_path, dst, 0);
} }
@ -2155,7 +2140,7 @@ mount_info::add_item (const char *native, const char *posix, unsigned mountflags
if ((native == NULL) || (*native == 0) || if ((native == NULL) || (*native == 0) ||
(posix == NULL) || (*posix == 0) || (posix == NULL) || (*posix == 0) ||
!isabspath (native) || !isabspath (posix) || !isabspath (native) || !isabspath (posix) ||
slash_unc_prefix_p (posix) || isdrive (posix)) is_unc_share (posix) || isdrive (posix))
{ {
set_errno (EINVAL); set_errno (EINVAL);
return -1; return -1;
@ -2232,7 +2217,7 @@ mount_info::del_item (const char *path, unsigned flags, int reg_p)
return -1; return -1;
} }
if (slash_unc_prefix_p (path) || strpbrk (path, ":\\")) if (is_unc_share (path) || strpbrk (path, ":\\"))
backslashify (path, pathtmp, 0); backslashify (path, pathtmp, 0);
else else
{ {