* cygheap.h (cygheap_user::cygheap_user): Initialize token to

INVALID_HANDLE_VALUE.
        * uinfo.cc (uinfo_init): Close token handle if needed.
This commit is contained in:
Corinna Vinschen 2001-06-04 14:29:54 +00:00
parent ac5561f2ed
commit f7fa593d6b
3 changed files with 10 additions and 1 deletions

View File

@ -1,3 +1,9 @@
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

View File

@ -107,7 +107,8 @@ public:
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);

View File

@ -161,6 +161,8 @@ uinfo_init ()
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;