INVALID_HANDLE_VALUE.
* uinfo.cc (uinfo_init): Close token handle if needed.
+Mon Jun 4 16:21:00 2001 Corinna Vinschen <corinna@vinschen.de>
+
+ * cygheap.h (cygheap_user::cygheap_user): Initialize token to
+ INVALID_HANDLE_VALUE.
+ * uinfo.cc (uinfo_init): Close token handle if needed.
+
Sun Jun 3 20:52:13 2001 Christopher Faylor <cgf@cygnus.com>
* path.cc (normalize_posix_path): Revert .. check removed by previous
HANDLE token;
BOOL impersonated;
- cygheap_user () : pname (NULL), plogsrv (NULL), pdomain (NULL), psid (NULL) {}
+ cygheap_user () : pname (NULL), plogsrv (NULL), pdomain (NULL),
+ psid (NULL), token (INVALID_HANDLE_VALUE) {}
~cygheap_user ();
void set_name (const char *new_name);
Setting `impersonated' to TRUE seems to be wrong but it
isn't. Impersonated is thought as "Current User and `token'
are coincident". See seteuid() for the mechanism behind that. */
+ if (cygheap->user.token != INVALID_HANDLE_VALUE)
+ CloseHandle (cygheap->user.token);
cygheap->user.token = INVALID_HANDLE_VALUE;
cygheap->user.impersonated = TRUE;