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:
parent
c8daf9983b
commit
9f9231b314
@ -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
|
||||||
|
@ -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
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user