* cygheap.cc (cygheap_init): Set umask to a sane default.
* uinfo.cc (cygheap_user::ontherange): Don't use HOMEDRIVE/HOMEPATH to set HOME. Default to /home/USERNAME.
This commit is contained in:
		| @@ -1,3 +1,9 @@ | |||||||
|  | 2009-05-06  Corinna Vinschen  <corinna@vinschen.de> | ||||||
|  |  | ||||||
|  | 	* cygheap.cc (cygheap_init): Set umask to a sane default. | ||||||
|  | 	* uinfo.cc (cygheap_user::ontherange): Don't use HOMEDRIVE/HOMEPATH | ||||||
|  | 	to set HOME.  Default to /home/USERNAME. | ||||||
|  |  | ||||||
| 2009-05-03  Corinna Vinschen  <corinna@vinschen.de> | 2009-05-03  Corinna Vinschen  <corinna@vinschen.de> | ||||||
|  |  | ||||||
| 	* security.cc (set_file_sd): Drop using FILE_OPEN_FOR_RECOVERY flag in | 	* security.cc (set_file_sd): Drop using FILE_OPEN_FOR_RECOVERY flag in | ||||||
|   | |||||||
| @@ -156,6 +156,8 @@ cygheap_init () | |||||||
| 					 _cygheap_mid - _cygheap_start); | 					 _cygheap_mid - _cygheap_start); | ||||||
|       cygheap_max = cygheap; |       cygheap_max = cygheap; | ||||||
|       _csbrk (sizeof (*cygheap)); |       _csbrk (sizeof (*cygheap)); | ||||||
|  |       /* Set umask to a sane default. */ | ||||||
|  |       cygheap->umask = 022; | ||||||
|     } |     } | ||||||
|   if (!cygheap->fdtab) |   if (!cygheap->fdtab) | ||||||
|     cygheap->fdtab.init (); |     cygheap->fdtab.init (); | ||||||
|   | |||||||
| @@ -248,15 +248,6 @@ cygheap_user::ontherange (homebodies what, struct passwd *pw) | |||||||
|   if (what == CH_HOME) |   if (what == CH_HOME) | ||||||
|     { |     { | ||||||
|       char *p; |       char *p; | ||||||
|       if (homedrive) |  | ||||||
| 	newhomedrive = homedrive; |  | ||||||
|       else if ((p = getenv ("HOMEDRIVE"))) |  | ||||||
| 	newhomedrive = p; |  | ||||||
|  |  | ||||||
|       if (homepath) |  | ||||||
| 	newhomepath = homepath; |  | ||||||
|       else if ((p = getenv ("HOMEPATH"))) |  | ||||||
| 	newhomepath = p; |  | ||||||
|  |  | ||||||
|       if ((p = getenv ("HOME"))) |       if ((p = getenv ("HOME"))) | ||||||
| 	debug_printf ("HOME is already in the environment %s", p); | 	debug_printf ("HOME is already in the environment %s", p); | ||||||
| @@ -267,17 +258,12 @@ cygheap_user::ontherange (homebodies what, struct passwd *pw) | |||||||
| 	      debug_printf ("Set HOME (from /etc/passwd) to %s", pw->pw_dir); | 	      debug_printf ("Set HOME (from /etc/passwd) to %s", pw->pw_dir); | ||||||
| 	      setenv ("HOME", pw->pw_dir, 1); | 	      setenv ("HOME", pw->pw_dir, 1); | ||||||
| 	    } | 	    } | ||||||
| 	  else if (!newhomedrive || !newhomepath) |  | ||||||
| 	    setenv ("HOME", "/", 1); |  | ||||||
| 	  else | 	  else | ||||||
| 	    { | 	    { | ||||||
| 	      char *home = tp.c_get (); | 	      char home[strlen (name ()) + 8]; | ||||||
| 	      char *buf = tp.c_get (); |  | ||||||
| 	      strcpy (buf, newhomedrive); | 	      debug_printf ("Set HOME to default /home/USER"); | ||||||
| 	      strcat (buf, newhomepath); | 	      __small_sprintf (home, "/home/%s", name ()); | ||||||
| 	      cygwin_conv_path (CCP_WIN_A_TO_POSIX | CCP_ABSOLUTE, buf, home, |  | ||||||
| 				NT_MAX_PATH); |  | ||||||
| 	      debug_printf ("Set HOME (from HOMEDRIVE/HOMEPATH) to %s", home); |  | ||||||
| 	      setenv ("HOME", home, 1); | 	      setenv ("HOME", home, 1); | ||||||
| 	    } | 	    } | ||||||
| 	} | 	} | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user