mirror of
				https://github.com/tmux/tmux.git
				synced 2025-11-04 00:56:10 +00:00 
			
		
		
		
	Use default-shell not _PATH_BSHELL to spawn commands, pointed out by
Dennis G?nnewig and Thomas Adam.
This commit is contained in:
		
							
								
								
									
										17
									
								
								window.c
									
									
									
									
									
								
							
							
						
						
									
										17
									
								
								window.c
									
									
									
									
									
								
							@@ -739,23 +739,24 @@ window_pane_spawn(struct window_pane *wp, const char *cmd, const char *shell,
 | 
			
		||||
		clear_signals(1);
 | 
			
		||||
		log_close();
 | 
			
		||||
 | 
			
		||||
		if (*wp->cmd != '\0') {
 | 
			
		||||
			/* Set SHELL but only if it is currently not useful. */
 | 
			
		||||
			shell = getenv("SHELL");
 | 
			
		||||
			if (checkshell(shell))
 | 
			
		||||
				setenv("SHELL", wp->shell, 1);
 | 
			
		||||
		setenv("SHELL", wp->shell, 1);
 | 
			
		||||
		ptr = strrchr(wp->shell, '/');
 | 
			
		||||
 | 
			
		||||
			execl(_PATH_BSHELL, "sh", "-c", wp->cmd, (char *) NULL);
 | 
			
		||||
		if (*wp->cmd != '\0') {
 | 
			
		||||
			/* Use the command. */
 | 
			
		||||
			if (ptr != NULL && *(ptr + 1) != '\0')
 | 
			
		||||
				xasprintf(&argv0, "%s", ptr + 1);
 | 
			
		||||
			else
 | 
			
		||||
				xasprintf(&argv0, "%s", wp->shell);
 | 
			
		||||
			execl(wp->shell, argv0, "-c", wp->cmd, (char *) NULL);
 | 
			
		||||
			fatal("execl failed");
 | 
			
		||||
		}
 | 
			
		||||
 | 
			
		||||
		/* No command; fork a login shell. */
 | 
			
		||||
		ptr = strrchr(wp->shell, '/');
 | 
			
		||||
		if (ptr != NULL && *(ptr + 1) != '\0')
 | 
			
		||||
			xasprintf(&argv0, "-%s", ptr + 1);
 | 
			
		||||
		else
 | 
			
		||||
			xasprintf(&argv0, "-%s", wp->shell);
 | 
			
		||||
		setenv("SHELL", wp->shell, 1);
 | 
			
		||||
		execl(wp->shell, argv0, (char *) NULL);
 | 
			
		||||
		fatal("execl failed");
 | 
			
		||||
	}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user