Flip the switch to stop draining threads before exec (!)

This commit is contained in:
ridiculousfish 2012-03-09 11:28:24 -08:00
parent d173bb6e0a
commit 14a35e7c21
3 changed files with 3 additions and 4 deletions

View file

@ -1255,7 +1255,7 @@ void exec( parser_t &parser, job_t *j )
if (g_log_forks) { if (g_log_forks) {
printf("forking for '%s' in '%ls'\n", actual_cmd, reader_current_filename()); printf("forking for '%s' in '%ls'\n", actual_cmd, reader_current_filename());
} }
pid = execute_fork(true /* must drain threads */); pid = execute_fork(false);
if( pid == 0 ) if( pid == 0 )
{ {
/* /*

4
io.h
View file

@ -17,7 +17,7 @@ enum io_mode
class io_data_t class io_data_t
{ {
private: private:
/** buffer to save output in for IO_BUFFER. Note that in the original fish, the buffer was a pointer to a buffer_t stored in the param2 union down below, and when an io_data_t was duplicated the pointer was copied so that two io_data_ts referenced the same buffer. It's not clear to me how this was ever cleaned up correctly. But it's important that they share the same buffer for reasons I don't yet understand either. But we can get correct sharing and cleanup with shared_ptr. */ /** buffer to save output in for IO_BUFFER. Note that in the original fish, the buffer was a pointer to a buffer_t stored in the param2 union down below, and when an io_data_t was duplicated the pointer was copied so that two io_data_ts referenced the same buffer. It's not clear to me how this was ever cleaned up correctly. But it's important that they share the same buffer for reasons I don't yet understand either. We can get correct sharing and cleanup with shared_ptr. */
shared_ptr<std::vector<char> > out_buffer; shared_ptr<std::vector<char> > out_buffer;
/* No assignment allowed */ /* No assignment allowed */
@ -36,7 +36,7 @@ public:
{ {
/** Fds for IO_PIPE and for IO_BUFFER */ /** Fds for IO_PIPE and for IO_BUFFER */
int pipe_fd[2]; int pipe_fd[2];
/** fd to redirect specified fd to, for IO_FD*/ /** fd to redirect specified fd to, for IO_FD */
int old_fd; int old_fd;
} param1; } param1;

View file

@ -68,7 +68,6 @@ int set_child_group( job_t *j, process_t *p, int print_errors )
format_long_safe(getpgid_buff, getpgid( p->pid)); format_long_safe(getpgid_buff, getpgid( p->pid));
format_long_safe(job_pgid_buff, j->pgid); format_long_safe(job_pgid_buff, j->pgid);
// PCA FIXME This is sketchy to do in a forked child because it may allocate memory. This needs to call only safe functions.
debug_safe( 1, debug_safe( 1,
"Could not send process %s, '%s' in job %s, '%s' from group %s to group %s", "Could not send process %s, '%s' in job %s, '%s' from group %s to group %s",
pid_buff, pid_buff,