Clean up use_posix_spawn

Switch from a global variable to a real function. Make the value atomic.
Clean up handle_fish_use_posix_spawn_change().
This commit is contained in:
ridiculousfish 2021-05-31 12:34:43 -07:00
parent 50e63d4c04
commit 50c851d10e
3 changed files with 16 additions and 10 deletions

View file

@ -309,7 +309,7 @@ class env_stack_t final : public environment_t {
static env_stack_t &globals(); static env_stack_t &globals();
}; };
extern bool g_use_posix_spawn; bool get_use_posix_spawn();
extern bool term_has_xn; // does the terminal have the "eat_newline_glitch" extern bool term_has_xn; // does the terminal have the "eat_newline_glitch"

View file

@ -260,11 +260,18 @@ static void handle_curses_change(const environment_t &vars) {
init_curses(vars); init_curses(vars);
} }
/// Whether to use posix_spawn when possible.
static relaxed_atomic_bool_t g_use_posix_spawn{false};
bool get_use_posix_spawn() { return g_use_posix_spawn; }
static void handle_fish_use_posix_spawn_change(const environment_t &vars) { static void handle_fish_use_posix_spawn_change(const environment_t &vars) {
// note this defaults to true // Note if the variable is missing or empty, we default to true.
auto use_posix_spawn = vars.get(L"fish_use_posix_spawn"); if (auto var = vars.get(L"fish_use_posix_spawn")) {
g_use_posix_spawn = g_use_posix_spawn = var->empty() || bool_from_string(var->as_string());
use_posix_spawn.missing_or_empty() ? true : bool_from_string(use_posix_spawn->as_string()); } else {
g_use_posix_spawn = true;
}
} }
/// Allow the user to override the limit on how much data the `read` command will process. /// Allow the user to override the limit on how much data the `read` command will process.
@ -570,9 +577,6 @@ static void init_locale(const environment_t &vars) {
/// Returns true if we think the terminal supports setting its title. /// Returns true if we think the terminal supports setting its title.
bool term_supports_setting_title() { return can_set_term_title; } bool term_supports_setting_title() { return can_set_term_title; }
/// Miscellaneous variables.
bool g_use_posix_spawn = false;
// Limit `read` to 100 MiB (bytes not wide chars) by default. This can be overridden by the // Limit `read` to 100 MiB (bytes not wide chars) by default. This can be overridden by the
// fish_read_limit variable. // fish_read_limit variable.
size_t read_byte_limit = 100 * 1024 * 1024; size_t read_byte_limit = 100 * 1024 * 1024;

View file

@ -207,6 +207,9 @@ bool is_thompson_shell_script(const char *path) {
// we use fork(), we can call tcsetpgrp after the fork, before the exec, and avoid the race). // 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_t> &job, static bool can_use_posix_spawn_for_job(const std::shared_ptr<job_t> &job,
const dup2_list_t &dup2s) { const dup2_list_t &dup2s) {
// Is it globally disabled?
if (!get_use_posix_spawn()) return false;
// Hack - do not use posix_spawn if there are self-fd redirections. // Hack - do not use posix_spawn if there are self-fd redirections.
// For example if you were to write: // For example if you were to write:
// cmd 6< /dev/null // cmd 6< /dev/null
@ -545,8 +548,7 @@ static launch_result_t exec_external_command(parser_t &parser, const std::shared
#if FISH_USE_POSIX_SPAWN #if FISH_USE_POSIX_SPAWN
// Prefer to use posix_spawn, since it's faster on some systems like OS X. // Prefer to use posix_spawn, since it's faster on some systems like OS X.
bool use_posix_spawn = g_use_posix_spawn && can_use_posix_spawn_for_job(j, dup2s); if (can_use_posix_spawn_for_job(j, dup2s)) {
if (use_posix_spawn) {
s_fork_count++; // spawn counts as a fork+exec s_fork_count++; // spawn counts as a fork+exec
posix_spawner_t spawner(j.get(), dup2s); posix_spawner_t spawner(j.get(), dup2s);