From 71dc33401089ffd6f8640d0439d3d1b272286ba9 Mon Sep 17 00:00:00 2001 From: Fabian Boehm Date: Thu, 2 Mar 2023 16:51:24 +0100 Subject: [PATCH] Disable bracketed paste for read It's not of much use (read will only read a single line anyway) and breaks things Fixes #8285 (cherry picked from commit af49b4d0f8edc49da0ec0871e1fb665ef2332d48) --- share/functions/__fish_config_interactive.fish | 10 +++++++--- 1 file changed, 7 insertions(+), 3 deletions(-) diff --git a/share/functions/__fish_config_interactive.fish b/share/functions/__fish_config_interactive.fish index 7b8b130bd..97557a6a8 100644 --- a/share/functions/__fish_config_interactive.fish +++ b/share/functions/__fish_config_interactive.fish @@ -193,8 +193,10 @@ end" >$__fish_config_dir/config.fish # the sequences to bind.expect if not set -q FISH_UNIT_TESTS_RUNNING # Enable bracketed paste before every prompt (see __fish_shared_bindings for the bindings). - # Enable bracketed paste when the read builtin is used. - function __fish_enable_bracketed_paste --on-event fish_prompt --on-event fish_read + # We used to do this for read, but that would break non-interactive use and + # compound commandlines like `read; cat`, because + # it won't disable it after the read. + function __fish_enable_bracketed_paste --on-event fish_prompt printf "\e[?2004h" end @@ -205,7 +207,9 @@ end" >$__fish_config_dir/config.fish # Tell the terminal we support BP. Since we are in __f_c_i, the first fish_prompt # has already fired. - __fish_enable_bracketed_paste + # But only if we're interactive, in case we are in `read` + status is-interactive + and __fish_enable_bracketed_paste end # Similarly, enable TMUX's focus reporting when in tmux.