From 7c256e7e5163d6ed4037c29f9229ff567c5b3f28 Mon Sep 17 00:00:00 2001 From: ridiculousfish Date: Tue, 29 Jan 2019 00:40:55 -0800 Subject: [PATCH] Allow posix_spawn more often Now that we no longer open files after fork, we can correctly report errors for failed file opens. So allow posix_spawn even if there's redirections. --- src/exec.cpp | 28 +++------------------------- 1 file changed, 3 insertions(+), 25 deletions(-) diff --git a/src/exec.cpp b/src/exec.cpp index bf978345f..78444b8b8 100644 --- a/src/exec.cpp +++ b/src/exec.cpp @@ -115,18 +115,6 @@ static bool redirection_is_to_real_file(const io_data_t *io) { return result; } -static bool chain_contains_redirection_to_real_file(const io_chain_t &io_chain) { - bool result = false; - for (size_t idx = 0; idx < io_chain.size(); idx++) { - const io_data_t *io = io_chain.at(idx).get(); - if (redirection_is_to_real_file(io)) { - result = true; - break; - } - } - return result; -} - /// Returns the interpreter for the specified script. Returns NULL if file is not a script with a /// shebang. char *get_interpreter(const char *command, char *interpreter, size_t buff_size) { @@ -330,11 +318,9 @@ void internal_exec_helper(parser_t &parser, parsed_source_ref_t parsed_source, t job_reap(false); } -// Returns whether we can use posix spawn for a given process in a given job. Per -// https://github.com/fish-shell/fish-shell/issues/364 , error handling for file redirections is too -// difficult with posix_spawn, so in that case we use fork/exec. +// Returns whether we can use posix spawn for a given process in a given job. // -// Furthermore, to avoid the race between the caller calling tcsetpgrp() and the client checking the +// To avoid the race between the caller calling tcsetpgrp() and the client checking the // foreground process group, we don't use posix_spawn if we're going to foreground the process. (If // we use fork(), we can call tcsetpgrp after the fork, before the exec, and avoid the race). static bool can_use_posix_spawn_for_job(const std::shared_ptr &job, @@ -348,15 +334,7 @@ static bool can_use_posix_spawn_for_job(const std::shared_ptr &job, return false; } } - - // Now see if we have a redirection involving a file. The only one we allow is /dev/null, which - // we assume will not fail. - bool result = true; - if (chain_contains_redirection_to_real_file(job->block_io_chain()) || - chain_contains_redirection_to_real_file(process->io_chain())) { - result = false; - } - return result; + return true; } void internal_exec(env_stack_t &vars, job_t *j, const io_chain_t &all_ios) {