* path.cc (normalize_posix_path): Calculate path name length overruns more
dynamically. (normalize_win32_path): Ditto. * Makefile.in: Avoid scanning the directory twice for *.d files.
This commit is contained in:
		| @@ -1,3 +1,10 @@ | |||||||
|  | Fri Dec 15 17:23:17 2000  Christopher Faylor <cgf@cygnus.com> | ||||||
|  |  | ||||||
|  | 	* path.cc (normalize_posix_path): Calculate path name length overruns | ||||||
|  | 	more dynamically. | ||||||
|  | 	(normalize_win32_path): Ditto. | ||||||
|  | 	* Makefile.in: Avoid scanning the directory twice for *.d files. | ||||||
|  |  | ||||||
| Thu Dec 14 23:37:51 2000  Christopher Faylor <cgf@cygnus.com> | Thu Dec 14 23:37:51 2000  Christopher Faylor <cgf@cygnus.com> | ||||||
|  |  | ||||||
| 	* fhandler.h (fhandler_console): Add additional argument to | 	* fhandler.h (fhandler_console): Add additional argument to | ||||||
|   | |||||||
| @@ -219,6 +219,7 @@ $(DEF_FILE): cygwin.din config.status | |||||||
|  |  | ||||||
| winsup.h: config.h | winsup.h: config.h | ||||||
|  |  | ||||||
| ifneq (,${wildcard *.d}) | deps:=${wildcard *.d} | ||||||
| include *.d | ifneq (,$(deps)) | ||||||
|  | include $(deps) | ||||||
| endif | endif | ||||||
|   | |||||||
| @@ -608,11 +608,6 @@ normalize_posix_path (const char *src, char *dst) | |||||||
|     { |     { | ||||||
|       if (!cygcwd.get (dst)) |       if (!cygcwd.get (dst)) | ||||||
| 	return get_errno (); | 	return get_errno (); | ||||||
|       if (strlen (dst) + 1 + strlen (src) >= MAX_PATH) |  | ||||||
| 	{ |  | ||||||
| 	  debug_printf ("ENAMETOOLONG = normalize_posix_path (%s)", src); |  | ||||||
| 	  return ENAMETOOLONG; |  | ||||||
| 	} |  | ||||||
|       dst = strchr (dst, '\0'); |       dst = strchr (dst, '\0'); | ||||||
|       if (*src == '.') |       if (*src == '.') | ||||||
| 	{ | 	{ | ||||||
| @@ -647,6 +642,8 @@ normalize_posix_path (const char *src, char *dst) | |||||||
|       strcpy (dst, cygheap->root.path ()); |       strcpy (dst, cygheap->root.path ()); | ||||||
|       dst += cygheap->root.length (); |       dst += cygheap->root.length (); | ||||||
|     } |     } | ||||||
|  |   else | ||||||
|  |     *dst = '\0'; | ||||||
|  |  | ||||||
|   while (*src) |   while (*src) | ||||||
|     { |     { | ||||||
| @@ -689,6 +686,11 @@ normalize_posix_path (const char *src, char *dst) | |||||||
|  |  | ||||||
| 	  *dst++ = '/'; | 	  *dst++ = '/'; | ||||||
| 	} | 	} | ||||||
|  | 	if ((dst - dst_start) >= MAX_PATH) | ||||||
|  | 	  { | ||||||
|  | 	    debug_printf ("ENAMETOOLONG = normalize_posix_path (%s)", src); | ||||||
|  | 	    return ENAMETOOLONG; | ||||||
|  | 	  } | ||||||
|     } |     } | ||||||
|  |  | ||||||
| done: | done: | ||||||
| @@ -768,9 +770,7 @@ normalize_win32_path (const char *src, char *dst) | |||||||
|       /* Ignore "./".  */ |       /* Ignore "./".  */ | ||||||
|       else if (src[0] == '.' && SLASH_P (src[1]) |       else if (src[0] == '.' && SLASH_P (src[1]) | ||||||
| 	       && (src == src_start || SLASH_P (src[-1]))) | 	       && (src == src_start || SLASH_P (src[-1]))) | ||||||
| 	{ | 	src += 2; | ||||||
| 	  src += 2; |  | ||||||
| 	} |  | ||||||
|  |  | ||||||
|       /* Backup if "..".  */ |       /* Backup if "..".  */ | ||||||
|       else if (src[0] == '.' && src[1] == '.' |       else if (src[0] == '.' && src[1] == '.' | ||||||
| @@ -797,6 +797,8 @@ normalize_win32_path (const char *src, char *dst) | |||||||
| 	    *dst++ = *src; | 	    *dst++ = *src; | ||||||
| 	  ++src; | 	  ++src; | ||||||
| 	} | 	} | ||||||
|  |       if ((dst - dst_start) >= MAX_PATH) | ||||||
|  | 	return ENAMETOOLONG; | ||||||
|     } |     } | ||||||
|   *dst = 0; |   *dst = 0; | ||||||
|   debug_printf ("%s = normalize_win32_path (%s)", dst_start, src_start); |   debug_printf ("%s = normalize_win32_path (%s)", dst_start, src_start); | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user