* spawn.cc (spawn_guts): YA tweak for dealing with arcane rules of quoting in
"normal" Microsoft programs. * child_info.h: Bump fork magic number. * include/sys/mount.h: Add an entry for mixed mode.
This commit is contained in:
		| @@ -1,3 +1,10 @@ | |||||||
|  | Mon Nov 20 14:26:38 2000  Christopher Faylor <cgf@cygnus.com> | ||||||
|  |  | ||||||
|  | 	* spawn.cc (spawn_guts): YA tweak for dealing with arcane rules of | ||||||
|  | 	quoting in "normal" Microsoft programs. | ||||||
|  | 	* child_info.h: Bump fork magic number. | ||||||
|  | 	* include/sys/mount.h: Add an entry for mixed mode. | ||||||
|  |  | ||||||
| Fri Nov 17 12:28:00 2000  Corinna Vinschen <corinna@vinschen.de> | Fri Nov 17 12:28:00 2000  Corinna Vinschen <corinna@vinschen.de> | ||||||
|  |  | ||||||
| 	* path.cc (normalize_posix_path): Special care for root directory | 	* path.cc (normalize_posix_path): Special care for root directory | ||||||
|   | |||||||
| @@ -12,7 +12,7 @@ details. */ | |||||||
|  |  | ||||||
| enum | enum | ||||||
| { | { | ||||||
|   PROC_MAGIC = 0xaf0af000, |   PROC_MAGIC = 0xaf0bf000, | ||||||
|   PROC_FORK = PROC_MAGIC + 1, |   PROC_FORK = PROC_MAGIC + 1, | ||||||
|   PROC_EXEC = PROC_MAGIC + 2, |   PROC_EXEC = PROC_MAGIC + 2, | ||||||
|   PROC_SPAWN = PROC_MAGIC + 3, |   PROC_SPAWN = PROC_MAGIC + 3, | ||||||
|   | |||||||
| @@ -7,13 +7,14 @@ extern "C" { | |||||||
|  |  | ||||||
| enum | enum | ||||||
| { | { | ||||||
|   MOUNT_SYMLINK = 1,	/* "mount point" is a symlink */ |   MOUNT_SYMLINK =	0x001,	/* "mount point" is a symlink */ | ||||||
|   MOUNT_BINARY =  2,	/* "binary" format read/writes */ |   MOUNT_BINARY =	0x002,	/* "binary" format read/writes */ | ||||||
|   MOUNT_SYSTEM =  8,	/* mount point came from system table */ |   MOUNT_SYSTEM =	0x008,	/* mount point came from system table */ | ||||||
|   MOUNT_EXEC   = 16,	/* Any file in the mounted directory gets 'x' bit */ |   MOUNT_EXEC   =	0x010,	/* Any file in the mounted directory gets 'x' bit */ | ||||||
|   MOUNT_AUTO   = 32,	/* mount point refers to auto device mount */ |   MOUNT_AUTO   =	0x020,	/* mount point refers to auto device mount */ | ||||||
|   MOUNT_CYGWIN_EXEC = 64/* file or directory is or contains a cygwin |   MOUNT_CYGWIN_EXEC =	0x040,	/* file or directory is or contains a cygwin | ||||||
| 			    executable */ | 				   executable */ | ||||||
|  |   MOUNT_MIXED	=	0x080,	/* reads are text, writes are binary */ | ||||||
| }; | }; | ||||||
|  |  | ||||||
| int mount (const char *, const char *, unsigned __flags); | int mount (const char *, const char *, unsigned __flags); | ||||||
|   | |||||||
| @@ -483,7 +483,12 @@ spawn_guts (HANDLE hToken, const char * prog_arg, const char *const *argv, | |||||||
| 	      for (; (p = strpbrk (a, "\"\\")); a = ++p) | 	      for (; (p = strpbrk (a, "\"\\")); a = ++p) | ||||||
| 		{ | 		{ | ||||||
| 		  one_line.add (a, p - a); | 		  one_line.add (a, p - a); | ||||||
| 		  if ((*p == '\\' && p[1] == '"') || *p == '"') | 		  if (*p == '\\' && p[1] == '\\') | ||||||
|  | 		    { | ||||||
|  | 		      one_line.add ("\\\\\\", 3); | ||||||
|  | 		      p++; | ||||||
|  | 		    } | ||||||
|  | 		  else if ((*p == '\\' && p[1] == '"') || *p == '"') | ||||||
| 		    one_line.add ("\\", 1); | 		    one_line.add ("\\", 1); | ||||||
| 		  one_line.add (p, 1); | 		  one_line.add (p, 1); | ||||||
| 		} | 		} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user