diff options
author | Christopher Faylor <me@cgf.cx> | 2002-10-31 02:40:26 +0000 |
---|---|---|
committer | Christopher Faylor <me@cgf.cx> | 2002-10-31 02:40:26 +0000 |
commit | cf157504a84b78ae3874028da620bfc4e89ef0d4 (patch) | |
tree | 9c23dc959dfa39990ff275a7b37390d13357142b | |
parent | bfb1f3e04f46187690e29a5ec8d5e19d7fb9fb22 (diff) | |
download | newlib-cf157504a84b78ae3874028da620bfc4e89ef0d4.zip newlib-cf157504a84b78ae3874028da620bfc4e89ef0d4.tar.gz newlib-cf157504a84b78ae3874028da620bfc4e89ef0d4.tar.bz2 |
* cygpath.cc (get_long_path_name_w32impl): Define similarly to GetLongPathName.
(get_long_name): Correctly prototype GetLongPathName.
(get_long_paths): Implement using get_long_name to cut down on code
duplication.
(doit): Do various things to make path output work predictably.
-rw-r--r-- | winsup/utils/ChangeLog | 9 | ||||
-rw-r--r-- | winsup/utils/cygpath.cc | 228 |
2 files changed, 105 insertions, 132 deletions
diff --git a/winsup/utils/ChangeLog b/winsup/utils/ChangeLog index aa975d4..f8ab119 100644 --- a/winsup/utils/ChangeLog +++ b/winsup/utils/ChangeLog @@ -1,3 +1,12 @@ +2002-10-30 Christopher Faylor <cgf@redhat.com> + + * cygpath.cc (get_long_path_name_w32impl): Define similarly to + GetLongPathName. + (get_long_name): Correctly prototype GetLongPathName. + (get_long_paths): Implement using get_long_name to cut down on code + duplication. + (doit): Do various things to make path output work predictably. + 2002-10-19 Christopher Faylor <cgf@redhat.com> * mount.cc (usage): Correctly report default mode. diff --git a/winsup/utils/cygpath.cc b/winsup/utils/cygpath.cc index 93628ff..02c7b21 100644 --- a/winsup/utils/cygpath.cc +++ b/winsup/utils/cygpath.cc @@ -175,14 +175,14 @@ get_short_name (const char *filename) return strcpy (sbuf, buf); } -static DWORD +static DWORD WINAPI get_long_path_name_w32impl (LPCSTR src, LPSTR sbuf, DWORD) { char buf1[MAX_PATH], buf2[MAX_PATH], *ptr; const char *pelem, *next; WIN32_FIND_DATA w32_fd; int len; - + strcpy (buf1, src); *buf2 = 0; pelem = src; @@ -221,97 +221,78 @@ get_long_path_name_w32impl (LPCSTR src, LPSTR sbuf, DWORD) } static char * -get_long_paths (char *path) +get_long_name (const char *filename, DWORD& len) { - char *sbuf; - char *sptr; - char *next; - char *ptr = path; - char *end = strrchr (path, 0); - DWORD acc = 0; - DWORD len; - - HINSTANCE hinst; - DWORD (*GetLongPathNameAPtr) (LPCSTR, LPSTR, DWORD) = 0; - hinst = LoadLibrary ("kernel32"); - if (hinst) - GetLongPathNameAPtr = (DWORD (*) (LPCSTR, LPSTR, DWORD)) - GetProcAddress (hinst, "GetLongPathNameA"); - /* subsequent calls of kernel function with NULL cause SegFault in W2K!! */ - if (1 || !GetLongPathNameAPtr) - GetLongPathNameAPtr = get_long_path_name_w32impl; + char *sbuf, buf[MAX_PATH]; + static HINSTANCE k32 = LoadLibrary ("kernel32.dll"); + static DWORD (WINAPI *GetLongPathName) (LPCSTR, LPSTR, DWORD) = + (DWORD (WINAPI *) (LPCSTR, LPSTR, DWORD)) GetProcAddress (k32, "GetLongPathName"); + if (!GetLongPathName) + GetLongPathName = get_long_path_name_w32impl; - while (ptr != NULL) + len = GetLongPathName (filename, buf, MAX_PATH); + if (len == 0 && GetLastError () == ERROR_INVALID_PARAMETER) { - next = ptr; - ptr = strchr (ptr, ';'); - if (ptr) - *ptr++ = 0; - len = (*GetLongPathNameAPtr) (next, NULL, 0); - if (len == 0 && GetLastError () == ERROR_INVALID_PARAMETER) - { - fprintf (stderr, "%s: cannot create long name of %s\n", prog_name, - next); - exit (2); - } - acc += len + 1; + fprintf (stderr, "%s: cannot create long name of %s\n", prog_name, + filename); + exit (2); } - sptr = sbuf = (char *) malloc (acc + 1); - if (sbuf == NULL) + sbuf = (char *) malloc (len + 1); + if (!sbuf) { fprintf (stderr, "%s: out of memory\n", prog_name); exit (1); } - ptr = path; - for (;;) - { - len = (*GetLongPathNameAPtr) (ptr, sptr, acc); - if (len == 0 && GetLastError () == ERROR_INVALID_PARAMETER) - { - fprintf (stderr, "%s: cannot create long name of %s\n", prog_name, - ptr); - exit (2); - } - - ptr = strrchr (ptr, 0); - sptr = strrchr (sptr, 0); - if (ptr == end) - break; - *ptr = *sptr = ';'; - ++ptr, ++sptr; - acc -= len + 1; - } - return sbuf; + return strcpy (sbuf, buf); } static char * -get_long_name (const char *filename) +get_long_paths (char *path) { - char *sbuf, buf[MAX_PATH]; - DWORD len; - HINSTANCE hinst; - DWORD (*GetLongPathNameAPtr) (LPCSTR, LPSTR, DWORD) = 0; - hinst = LoadLibrary ("kernel32"); - if (hinst) - GetLongPathNameAPtr = (DWORD (*) (LPCSTR, LPSTR, DWORD)) - GetProcAddress (hinst, "GetLongPathNameA"); - if (!GetLongPathNameAPtr) - GetLongPathNameAPtr = get_long_path_name_w32impl; - - len = (*GetLongPathNameAPtr) (filename, buf, MAX_PATH); - if (len == 0 && GetLastError () == ERROR_INVALID_PARAMETER) + char *sbuf; + char *ptr; + int n = 1; + + ptr = path; + while ((ptr = strchr (ptr, ';'))) { - fprintf (stderr, "%s: cannot create long name of %s\n", prog_name, - filename); - exit (2); + ptr++; + n++; } - sbuf = (char *) malloc (++len); + + char *paths[n]; + DWORD acc = 0; + int i; + if (!n) + return strdup (""); + + for (i = 0, ptr = path; ptr; i++) + { + DWORD len; + char *next = ptr; + ptr = strchr (ptr, ';'); + if (ptr) + *ptr++ = 0; + paths[i] = get_long_name (next, len); + acc += len + 1; + } + + sbuf = (char *) malloc (acc + 1); if (sbuf == NULL) { fprintf (stderr, "%s: out of memory\n", prog_name); exit (1); } - return strcpy (sbuf, buf); + + sbuf[0] = '\0'; + for (i = 0; i < n; i++) + { + strcat (strcat (sbuf, paths[i]), ";"); + free (paths[i]); + } + + strchr (sbuf, '\0')[-1] = '\0'; + return sbuf; } static void @@ -348,14 +329,14 @@ dowin (char option) DWORD len = MAX_PATH; WIN32_FIND_DATA w32_fd; LPITEMIDLIST id; - HINSTANCE hinst; + HINSTANCE k32; BOOL (*GetProfilesDirectoryAPtr) (LPSTR, LPDWORD) = 0; - + buf = buf1; switch (option) { case 'D': - SHGetSpecialFolderLocation (NULL, allusers_flag ? + SHGetSpecialFolderLocation (NULL, allusers_flag ? CSIDL_COMMON_DESKTOPDIRECTORY : CSIDL_DESKTOPDIRECTORY, &id); SHGetPathFromIDList (id, buf); /* This if clause is a Fix for Win95 without any "All Users" */ @@ -367,7 +348,7 @@ dowin (char option) break; case 'P': - SHGetSpecialFolderLocation (NULL, allusers_flag ? + SHGetSpecialFolderLocation (NULL, allusers_flag ? CSIDL_COMMON_PROGRAMS : CSIDL_PROGRAMS, &id); SHGetPathFromIDList (id, buf); /* This if clause is a Fix for Win95 without any "All Users" */ @@ -379,10 +360,10 @@ dowin (char option) break; case 'H': - hinst = LoadLibrary ("userenv"); - if (hinst) + k32 = LoadLibrary ("userenv"); + if (k32) GetProfilesDirectoryAPtr = (BOOL (*) (LPSTR, LPDWORD)) - GetProcAddress (hinst, "GetProfilesDirectoryA"); + GetProcAddress (k32, "GetProfilesDirectoryA"); if (GetProfilesDirectoryAPtr) (*GetProfilesDirectoryAPtr) (buf, &len); else @@ -426,44 +407,27 @@ static void doit (char *filename) { char *buf; - size_t len; + DWORD len; int retval; int (*conv_func) (const char *, char *); - if (path_flag) - { - if (cygwin_posix_path_list_p (filename) ? unix_flag : windows_flag) - { - /* The path is already in the right format. */ - puts (filename); - exit (0); - } - } - if (!path_flag) { - len = strlen (filename) + 100; - if (len == 100) + len = strlen (filename); + if (len) + len += 100; + else if (ignore_flag) + exit (0); + else { - if (!ignore_flag) - { - fprintf (stderr, "%s: can't convert empty path\n", prog_name); - exit (1); - } - else - exit (0); + fprintf (stderr, "%s: can't convert empty path\n", prog_name); + exit (1); } } + else if (unix_flag) + len = cygwin_win32_to_posix_path_list_buf_size (filename); else - { - if (unix_flag) - len = cygwin_win32_to_posix_path_list_buf_size (filename); - else - len = cygwin_posix_to_win32_path_list_buf_size (filename); - } - - if (len < PATH_MAX) - len = PATH_MAX; + len = cygwin_posix_to_win32_path_list_buf_size (filename); buf = (char *) malloc (len); if (buf == NULL) @@ -509,7 +473,7 @@ doit (char *filename) if (shortname_flag) buf = get_short_name (buf); if (longname_flag) - buf = get_long_name (buf); + buf = get_long_name (buf, len); } } @@ -578,7 +542,7 @@ main (int argc, char **argv) break; case 'd': - if (windows_flag) + if (windows_flag) usage (stderr, 1); unix_flag = 0; windows_flag = 1; @@ -630,31 +594,31 @@ main (int argc, char **argv) format_type_arg = (*optarg == '=') ? (optarg + 1) : (optarg); if (strcasecmp (format_type_arg, "dos") == 0) - { - if (windows_flag || longname_flag) - usage (stderr, 1); - unix_flag = 0; - windows_flag = 1; - shortname_flag = 1; - } + { + if (windows_flag || longname_flag) + usage (stderr, 1); + unix_flag = 0; + windows_flag = 1; + shortname_flag = 1; + } else if (strcasecmp (format_type_arg, "mixed") == 0) - { - unix_flag = 0; + { + unix_flag = 0; mixed_flag = 1; - } + } else if (strcasecmp (format_type_arg, "unix") == 0) - { - if (windows_flag) - usage (stderr, 1); + { + if (windows_flag) + usage (stderr, 1); unix_flag = 1; - } + } else if (strcasecmp (format_type_arg, "windows") == 0) - { - if (mixed_flag) - usage (stderr, 1); - unix_flag = 0; - windows_flag = 1; - } + { + if (mixed_flag) + usage (stderr, 1); + unix_flag = 0; + windows_flag = 1; + } else usage (stderr, 1); break; |