Mercurial > emacs
changeset 93142:e1c95382ef7e
(readdir): If FindFirstFile/FindNextFile return in cFileName a file name that
includes `?' characters, use the 8+3 alias in cAlternateFileName instead.
author | Eli Zaretskii <eliz@gnu.org> |
---|---|
date | Sat, 22 Mar 2008 11:52:28 +0000 |
parents | dda2c82177dc |
children | c62113d8fa41 |
files | src/w32.c |
diffstat | 1 files changed, 15 insertions(+), 4 deletions(-) [+] |
line wrap: on
line diff
--- a/src/w32.c Sat Mar 22 05:55:11 2008 +0000 +++ b/src/w32.c Sat Mar 22 11:52:28 2008 +0000 @@ -1889,6 +1889,8 @@ struct direct * readdir (DIR *dirp) { + int downcase = !NILP (Vw32_downcase_file_names); + if (wnet_enum_handle != INVALID_HANDLE_VALUE) { if (!read_unc_volume (wnet_enum_handle, @@ -1923,14 +1925,23 @@ value returned by stat(). */ dir_static.d_ino = 1; + strcpy (dir_static.d_name, dir_find_data.cFileName); + + /* If the file name in cFileName[] includes `?' characters, it means + the original file name used characters that cannot be represented + by the current ANSI codepage. To avoid total lossage, retrieve + the short 8+3 alias of the long file name. */ + if (_mbspbrk (dir_static.d_name, "?")) + { + strcpy (dir_static.d_name, dir_find_data.cAlternateFileName); + downcase = 1; /* 8+3 aliases are returned in all caps */ + } + dir_static.d_namlen = strlen (dir_static.d_name); dir_static.d_reclen = sizeof (struct direct) - MAXNAMLEN + 3 + dir_static.d_namlen - dir_static.d_namlen % 4; - - dir_static.d_namlen = strlen (dir_find_data.cFileName); - strcpy (dir_static.d_name, dir_find_data.cFileName); if (dir_is_fat) _strlwr (dir_static.d_name); - else if (!NILP (Vw32_downcase_file_names)) + else if (downcase) { register char *p; for (p = dir_static.d_name; *p; p++)