Cygwin: symlinks: Allow traversing WSL symlinks
Unfortunately Windows doesn't understand WSL symlinks, despite being a really easy job. NT functions trying to access paths traversing WSL symlinks return the status code STATUS_IO_REPARSE_TAG_NOT_HANDLED. Handle this status code same as STATUS_OBJECT_PATH_NOT_FOUND in symlink_info::check to align behaviour to traversing paths with other non-NTFS type symlinks. Signed-off-by: Corinna Vinschen <corinna@vinschen.de>
This commit is contained in:
		@@ -3115,6 +3115,11 @@ restart:
 | 
			
		||||
	  /* One of the inner path components is invalid, or the path contains
 | 
			
		||||
	     invalid characters.  Bail out with ENOENT.
 | 
			
		||||
 | 
			
		||||
	     STATUS_IO_REPARSE_TAG_NOT_HANDLED is returned when trying to
 | 
			
		||||
	     traversing a WSL symlink.  For all practical purposes it's
 | 
			
		||||
	     equivalent to traversing SYSTEM- or LNK-type symlink returning
 | 
			
		||||
	     STATUS_OBJECT_PATH_NOT_FOUND.
 | 
			
		||||
 | 
			
		||||
	     Note that additional STATUS_OBJECT_PATH_INVALID and
 | 
			
		||||
	     STATUS_OBJECT_PATH_SYNTAX_BAD status codes exist.  The first one
 | 
			
		||||
	     is seemingly not generated by NtQueryInformationFile, the latter
 | 
			
		||||
@@ -3123,6 +3128,7 @@ restart:
 | 
			
		||||
	     error in get_nt_native_path.  Both status codes are deliberately
 | 
			
		||||
	     not tested here unless proved necessary. */
 | 
			
		||||
	  if (status == STATUS_OBJECT_PATH_NOT_FOUND
 | 
			
		||||
	      || status == STATUS_IO_REPARSE_TAG_NOT_HANDLED
 | 
			
		||||
	      || status == STATUS_OBJECT_NAME_INVALID
 | 
			
		||||
	      || status == STATUS_BAD_NETWORK_PATH
 | 
			
		||||
	      || status == STATUS_BAD_NETWORK_NAME
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user