* fhandler_fifo.cc (fhandler_fifo::open): Avoid resetting errno after it has
been explicitly set. * include/cygwin/version.h: Bump DLL minor version number to 2.
This commit is contained in:
		| @@ -1,3 +1,10 @@ | |||||||
|  | 2009-12-09  Christopher Faylor  <me+cygwin@cgf.cx> | ||||||
|  |  | ||||||
|  | 	* fhandler_fifo.cc (fhandler_fifo::open): Avoid resetting errno after | ||||||
|  | 	it has been explicitly set. | ||||||
|  |  | ||||||
|  | 	* include/cygwin/version.h: Bump DLL minor version number to 2. | ||||||
|  |  | ||||||
| 2009-12-06  Corinna Vinschen  <corinna@vinschen.de> | 2009-12-06  Corinna Vinschen  <corinna@vinschen.de> | ||||||
|  |  | ||||||
| 	* include/cygwin/version.h: Bump DLL minor version number to 1. | 	* include/cygwin/version.h: Bump DLL minor version number to 1. | ||||||
|   | |||||||
| @@ -1,6 +1,6 @@ | |||||||
| /* fhandler_fifo.cc - See fhandler.h for a description of the fhandler classes. | /* fhandler_fifo.cc - See fhandler.h for a description of the fhandler classes. | ||||||
|  |  | ||||||
|    Copyright 2002, 2003, 2004, 2005, 2006, 2007, 2008 Red Hat, Inc. |    Copyright 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009 Red Hat, Inc. | ||||||
|  |  | ||||||
|    This file is part of Cygwin. |    This file is part of Cygwin. | ||||||
|  |  | ||||||
| @@ -95,6 +95,7 @@ fhandler_fifo::open (int flags, mode_t) | |||||||
|       char char_sa_buf[1024]; |       char char_sa_buf[1024]; | ||||||
|       LPSECURITY_ATTRIBUTES sa_buf = |       LPSECURITY_ATTRIBUTES sa_buf = | ||||||
| 	sec_user ((PSECURITY_ATTRIBUTES) char_sa_buf, cygheap->user.sid()); | 	sec_user ((PSECURITY_ATTRIBUTES) char_sa_buf, cygheap->user.sid()); | ||||||
|  |       bool do_seterrno = true; | ||||||
|  |  | ||||||
|       HANDLE h; |       HANDLE h; | ||||||
|       bool nonblocking_write = !!((flags & (O_WRONLY | O_NONBLOCK)) == (O_WRONLY | O_NONBLOCK)); |       bool nonblocking_write = !!((flags & (O_WRONLY | O_NONBLOCK)) == (O_WRONLY | O_NONBLOCK)); | ||||||
| @@ -110,7 +111,10 @@ fhandler_fifo::open (int flags, mode_t) | |||||||
| 	  if (h != INVALID_HANDLE_VALUE) | 	  if (h != INVALID_HANDLE_VALUE) | ||||||
| 	    wait_state = fifo_ok; | 	    wait_state = fifo_ok; | ||||||
| 	  else if (nonblocking_write) | 	  else if (nonblocking_write) | ||||||
|  | 	    { | ||||||
| 	      set_errno (ENXIO); | 	      set_errno (ENXIO); | ||||||
|  | 	      do_seterrno = false; | ||||||
|  | 	    } | ||||||
| 	  else if ((h = cnp (PIPE_ACCESS_DUPLEX, 1)) != INVALID_HANDLE_VALUE) | 	  else if ((h = cnp (PIPE_ACCESS_DUPLEX, 1)) != INVALID_HANDLE_VALUE) | ||||||
| 	    { | 	    { | ||||||
| 	      if ((dummy_client = open_nonserver (npname, low_flags, sa_buf)) | 	      if ((dummy_client = open_nonserver (npname, low_flags, sa_buf)) | ||||||
| @@ -130,6 +134,7 @@ fhandler_fifo::open (int flags, mode_t) | |||||||
| 	} | 	} | ||||||
|       if (h == INVALID_HANDLE_VALUE) |       if (h == INVALID_HANDLE_VALUE) | ||||||
| 	{ | 	{ | ||||||
|  | 	  if (do_seterrno) | ||||||
| 	    __seterrno (); | 	    __seterrno (); | ||||||
| 	  res = 0; | 	  res = 0; | ||||||
| 	} | 	} | ||||||
|   | |||||||
| @@ -43,7 +43,7 @@ details. */ | |||||||
| 	 changes to the DLL and is mainly informative in nature. */ | 	 changes to the DLL and is mainly informative in nature. */ | ||||||
|  |  | ||||||
| #define CYGWIN_VERSION_DLL_MAJOR 1007 | #define CYGWIN_VERSION_DLL_MAJOR 1007 | ||||||
| #define CYGWIN_VERSION_DLL_MINOR 1 | #define CYGWIN_VERSION_DLL_MINOR 2 | ||||||
|  |  | ||||||
|       /* Major numbers before CYGWIN_VERSION_DLL_EPOCH are |       /* Major numbers before CYGWIN_VERSION_DLL_EPOCH are | ||||||
| 	 incompatible. */ | 	 incompatible. */ | ||||||
|   | |||||||
| @@ -1,7 +1,7 @@ | |||||||
| /* pipe.cc: pipe for Cygwin. | /* pipe.cc: pipe for Cygwin. | ||||||
|  |  | ||||||
|    Copyright 1996, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, |    Copyright 1996, 1998, 1999, 2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, | ||||||
|    2008 Hat, Inc. |    2008, 2009 Hat, Inc. | ||||||
|  |  | ||||||
| This file is part of Cygwin. | This file is part of Cygwin. | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user