* pinfo.h (pinfo::status_exit): Rename from former static function in pinfo.cc.
(pinfo::operator == (char *)): Remove unused operator. * pinfo.cc (pinfo::status_exit): Move this function info pinfo class. Use progname from the pinfo rather than myself. Be defensive when inspecting procinfo.
This commit is contained in:
		| @@ -1,3 +1,12 @@ | ||||
| 2013-03-29  Christopher Faylor  <me.cygwin2013@cgf.cx> | ||||
|  | ||||
| 	* pinfo.h (pinfo::status_exit): Rename from former static function in | ||||
| 	pinfo.cc. | ||||
| 	(pinfo::operator == (char *)): Remove unused operator. | ||||
| 	* pinfo.cc (pinfo::status_exit): Move this function info pinfo class. | ||||
| 	Use progname from the pinfo rather than myself.  Be defensive when | ||||
| 	inspecting procinfo. | ||||
|  | ||||
| 2013-03-29  Christopher Faylor  <me.cygwin2013@cgf.cx> | ||||
|  | ||||
| 	* sigproc.cc (wait_sig): Avoid uninitialized use of nb when retrying. | ||||
|   | ||||
| @@ -110,17 +110,23 @@ pinfo_init (char **envp, int envc) | ||||
|   debug_printf ("pid %d, pgid %d", myself->pid, myself->pgid); | ||||
| } | ||||
|  | ||||
| static DWORD | ||||
| status_exit (DWORD x) | ||||
| DWORD | ||||
| pinfo::status_exit (DWORD x) | ||||
| { | ||||
|   switch (x) | ||||
|     { | ||||
|     case STATUS_DLL_NOT_FOUND: | ||||
|       { | ||||
| 	char posix_prog[NT_MAX_PATH]; | ||||
| 	path_conv pc; | ||||
| 	if (!procinfo) | ||||
| 	  pc.check ("/dev/null"); | ||||
| 	else | ||||
| 	  { | ||||
| 	    UNICODE_STRING uc; | ||||
| 	RtlInitUnicodeString(&uc, myself->progname); | ||||
| 	path_conv pc (&uc, PC_NOWARN); | ||||
| 	    RtlInitUnicodeString(&uc, procinfo->progname); | ||||
| 	    pc.check (&uc, PC_NOWARN); | ||||
| 	  } | ||||
| 	mount_table->conv_to_posix_path (pc.get_win32 (), posix_prog, 1); | ||||
| 	small_printf ("%s: error while loading shared libraries: %s: cannot open shared object file: No such file or directory\n", | ||||
| 		      posix_prog, find_first_notloaded_dll (pc)); | ||||
|   | ||||
| @@ -179,7 +179,6 @@ public: | ||||
|   int operator == (_pinfo *x) const {return x == procinfo;} | ||||
|   int operator == (void *x) const {return procinfo == x;} | ||||
|   int operator == (int x) const {return (int) procinfo == (int) x;} | ||||
|   int operator == (char *x) const {return (char *) procinfo == x;} | ||||
|   _pinfo *operator * () const {return procinfo;} | ||||
|   operator _pinfo * () const {return procinfo;} | ||||
|   void preserve () { destroy = false; } | ||||
| @@ -206,6 +205,8 @@ public: | ||||
|   void set_acl (); | ||||
|   friend class _pinfo; | ||||
|   friend class winpids; | ||||
| private: | ||||
|   DWORD status_exit (DWORD); | ||||
| }; | ||||
|  | ||||
| #define ISSTATE(p, f)	(!!((p)->process_state & f)) | ||||
|   | ||||
| @@ -60,3 +60,6 @@ Bug fixes: | ||||
|  | ||||
| - Fix some bugs in CTRL-S/CTRL-Q handling in ptys. | ||||
|   See: http://cygwin.com/ml/cygwin/2012-10/msg00089.html | ||||
|  | ||||
| - Fix "error while loading shared libraries:" message to properly | ||||
|   display the shared library name in more cases. | ||||
|   | ||||
		Reference in New Issue
	
	Block a user