* path.cc (symlink_info::check): Remove extra arguments, move functionality
back to path_conv::check. Clear symlink bit from pflags argument before detecting if this is a symlink. (path_conv::check): Convert posix path here instead of symlink_info::check. Only grab volflags when using ntsec. (symlink_info::check_case): Just replace appropriate part of input path.
This commit is contained in:
parent
f5c1d23103
commit
2b5803d4b7
@ -1,3 +1,13 @@
|
|||||||
|
Sun Apr 29 21:41:25 2001 Christopher Faylor <cgf@cygnus.com>
|
||||||
|
|
||||||
|
* path.cc (symlink_info::check): Remove extra arguments, move
|
||||||
|
functionality back to path_conv::check. Clear symlink bit from pflags
|
||||||
|
argument before detecting if this is a symlink.
|
||||||
|
(path_conv::check): Convert posix path here instead of
|
||||||
|
symlink_info::check. Only grab volflags when using ntsec.
|
||||||
|
(symlink_info::check_case): Just replace appropriate part of input
|
||||||
|
path.
|
||||||
|
|
||||||
Sat Apr 28 19:36:13 2001 Christopher Faylor <cgf@cygnus.com>
|
Sat Apr 28 19:36:13 2001 Christopher Faylor <cgf@cygnus.com>
|
||||||
|
|
||||||
Throughout, change 'tty_attached' to 'real_tty_attached', for clarity.
|
Throughout, change 'tty_attached' to 'real_tty_attached', for clarity.
|
||||||
|
@ -102,10 +102,8 @@ struct symlink_info
|
|||||||
bool ext_tacked_on;
|
bool ext_tacked_on;
|
||||||
int error;
|
int error;
|
||||||
BOOL case_clash;
|
BOOL case_clash;
|
||||||
int check (const char *path, const suffix_info *suffixes,
|
int check (char *path, const suffix_info *suffixes, unsigned opt);
|
||||||
char *orig_path, unsigned opt,
|
BOOL case_check (char *path);
|
||||||
DWORD& devn, int& unit, unsigned& path_flags);
|
|
||||||
BOOL case_check (const char *path, char *orig_path);
|
|
||||||
};
|
};
|
||||||
|
|
||||||
int pcheck_case = PCHECK_RELAXED; /* Determines the case check behaviour. */
|
int pcheck_case = PCHECK_RELAXED; /* Determines the case check behaviour. */
|
||||||
@ -407,8 +405,34 @@ path_conv::check (const char *src, unsigned opt,
|
|||||||
full_path = this->path;
|
full_path = this->path;
|
||||||
}
|
}
|
||||||
|
|
||||||
int len = sym.check (path_copy, suff, full_path, opt,
|
error = mount_table->conv_to_win32_path (path_copy, NULL, full_path, devn,
|
||||||
devn, unit, path_flags);
|
unit, &path_flags);
|
||||||
|
|
||||||
|
if (devn != FH_BAD)
|
||||||
|
{
|
||||||
|
fileattr = 0;
|
||||||
|
goto out; /* Found a device. Stop parsing. */
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Eat trailing slashes */
|
||||||
|
char *dostail = strchr (full_path, '\0');
|
||||||
|
|
||||||
|
/* If path is only a drivename, Windows interprets it as the current working
|
||||||
|
directory on this drive instead of the root dir which is what we want. So
|
||||||
|
we need the trailing backslash in this case. */
|
||||||
|
while (dostail > full_path + 3 && (*--dostail == '\\'))
|
||||||
|
*tail = '\0';
|
||||||
|
|
||||||
|
if (full_path[0] && full_path[1] == ':' && full_path[2] == '\0')
|
||||||
|
strcat (full_path, "\\");
|
||||||
|
|
||||||
|
if ((opt & PC_SYM_IGNORE) && pcheck_case == PCHECK_RELAXED)
|
||||||
|
{
|
||||||
|
fileattr = GetFileAttributesA (full_path);
|
||||||
|
goto out;
|
||||||
|
}
|
||||||
|
|
||||||
|
int len = sym.check (full_path, suff, opt);
|
||||||
|
|
||||||
if (sym.case_clash)
|
if (sym.case_clash)
|
||||||
{
|
{
|
||||||
@ -563,9 +587,9 @@ out:
|
|||||||
char fs_name[16];
|
char fs_name[16];
|
||||||
|
|
||||||
strcpy (tmp_buf, this->path);
|
strcpy (tmp_buf, this->path);
|
||||||
if (!rootdir (tmp_buf) ||
|
if (allow_ntsec && (!rootdir (tmp_buf) ||
|
||||||
!GetVolumeInformation (tmp_buf, NULL, 0, &serial, NULL,
|
!GetVolumeInformation (tmp_buf, NULL, 0, &serial, NULL,
|
||||||
&volflags, fs_name, 16))
|
&volflags, fs_name, 16)))
|
||||||
{
|
{
|
||||||
debug_printf ("GetVolumeInformation(%s) = ERR, this->path(%s), set_has_acls(FALSE)",
|
debug_printf ("GetVolumeInformation(%s) = ERR, this->path(%s), set_has_acls(FALSE)",
|
||||||
tmp_buf, this->path, GetLastError ());
|
tmp_buf, this->path, GetLastError ());
|
||||||
@ -2620,46 +2644,18 @@ suffix_scan::next ()
|
|||||||
stored into BUF if PATH is a symlink. */
|
stored into BUF if PATH is a symlink. */
|
||||||
|
|
||||||
int
|
int
|
||||||
symlink_info::check (const char *path, const suffix_info *suffixes,
|
symlink_info::check (char *path, const suffix_info *suffixes, unsigned opt)
|
||||||
char *full_path, unsigned opt,
|
|
||||||
DWORD& devn, int& unit, unsigned& path_flags)
|
|
||||||
{
|
{
|
||||||
HANDLE h;
|
HANDLE h;
|
||||||
int res = 0;
|
int res = 0;
|
||||||
suffix_scan suffix;
|
suffix_scan suffix;
|
||||||
contents[0] = '\0';
|
contents[0] = '\0';
|
||||||
char *tail;
|
|
||||||
|
|
||||||
error = mount_table->conv_to_win32_path (path, NULL, full_path, devn,
|
|
||||||
unit, &path_flags);
|
|
||||||
|
|
||||||
if (devn != FH_BAD)
|
|
||||||
{
|
|
||||||
fileattr = 0;
|
|
||||||
goto out; /* Found a device. Stop parsing. */
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Eat trailing slashes */
|
|
||||||
tail = strchr (full_path, '\0');
|
|
||||||
|
|
||||||
/* If path is only a drivename, Windows interprets it as the current working
|
|
||||||
directory on this drive instead of the root dir which is what we want. So
|
|
||||||
we need the trailing backslash in this case. */
|
|
||||||
while (tail > full_path + 3 && (*--tail == '\\'))
|
|
||||||
*tail = '\0';
|
|
||||||
|
|
||||||
if (full_path[0] && full_path[1] == ':' && full_path[2] == '\0')
|
|
||||||
strcat (full_path, "\\");
|
|
||||||
|
|
||||||
if ((opt & PC_SYM_IGNORE) && pcheck_case == PCHECK_RELAXED)
|
|
||||||
{
|
|
||||||
fileattr = GetFileAttributesA (path);
|
|
||||||
goto out;
|
|
||||||
}
|
|
||||||
|
|
||||||
is_symlink = TRUE;
|
is_symlink = TRUE;
|
||||||
ext_here = suffix.has (full_path, suffixes);
|
ext_here = suffix.has (path, suffixes);
|
||||||
extn = ext_here - full_path;
|
extn = ext_here - path;
|
||||||
|
|
||||||
|
pflags &= ~PATH_SYMLINK;
|
||||||
|
|
||||||
ext_tacked_on = !*ext_here;
|
ext_tacked_on = !*ext_here;
|
||||||
|
|
||||||
@ -2679,7 +2675,7 @@ symlink_info::check (const char *path, const suffix_info *suffixes,
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pcheck_case != PCHECK_RELAXED && !case_check (path, full_path)
|
if (pcheck_case != PCHECK_RELAXED && !case_check (path)
|
||||||
|| (opt & PC_SYM_IGNORE))
|
|| (opt & PC_SYM_IGNORE))
|
||||||
goto file_not_symlink;
|
goto file_not_symlink;
|
||||||
|
|
||||||
@ -2753,11 +2749,11 @@ out:
|
|||||||
*/
|
*/
|
||||||
|
|
||||||
BOOL
|
BOOL
|
||||||
symlink_info::case_check (const char *path, char *orig_path)
|
symlink_info::case_check (char *path)
|
||||||
{
|
{
|
||||||
WIN32_FIND_DATA data;
|
WIN32_FIND_DATA data;
|
||||||
HANDLE h;
|
HANDLE h;
|
||||||
const char *c;
|
char *c;
|
||||||
|
|
||||||
/* Set a pointer to the beginning of the last component. */
|
/* Set a pointer to the beginning of the last component. */
|
||||||
if (!(c = strrchr (path, '\\')))
|
if (!(c = strrchr (path, '\\')))
|
||||||
@ -2782,8 +2778,7 @@ symlink_info::case_check (const char *path, char *orig_path)
|
|||||||
|
|
||||||
/* PCHECK_ADJUST adjusts the case in the incoming
|
/* PCHECK_ADJUST adjusts the case in the incoming
|
||||||
path which points to the path in *this. */
|
path which points to the path in *this. */
|
||||||
strncpy (orig_path + (c - path), data.cFileName,
|
strcpy (c, data.cFileName);
|
||||||
strlen (data.cFileName));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return TRUE;
|
return TRUE;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user