mirror of
				https://github.com/tmux/tmux.git
				synced 2025-11-04 09:26:05 +00:00 
			
		
		
		
	Trying to set FD_CLOEXEC on every fd is a lost cause, just use
closefrom() before exec.
This commit is contained in:
		
							
								
								
									
										4
									
								
								job.c
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								job.c
									
									
									
									
									
								
							@@ -169,6 +169,8 @@ job_run(struct job *job)
 | 
			
		||||
		if (nullfd != STDIN_FILENO && nullfd != STDERR_FILENO)
 | 
			
		||||
			close(nullfd);
 | 
			
		||||
 | 
			
		||||
		closefrom(STDERR_FILENO + 1);
 | 
			
		||||
 | 
			
		||||
		execl(_PATH_BSHELL, "sh", "-c", job->cmd, (char *) NULL);
 | 
			
		||||
		fatal("execl failed");
 | 
			
		||||
	default:	/* parent */
 | 
			
		||||
@@ -179,8 +181,6 @@ job_run(struct job *job)
 | 
			
		||||
			fatal("fcntl failed");
 | 
			
		||||
		if (fcntl(job->fd, F_SETFL, mode|O_NONBLOCK) == -1)
 | 
			
		||||
			fatal("fcntl failed");
 | 
			
		||||
		if (fcntl(job->fd, F_SETFD, FD_CLOEXEC) == -1)
 | 
			
		||||
			fatal("fcntl failed");
 | 
			
		||||
 | 
			
		||||
		if (job->event != NULL)
 | 
			
		||||
			bufferevent_free(job->event);
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user