logo

live-bootstrap

Mirror of <https://github.com/fosslinux/live-bootstrap>
commit: d50ecd58e8d80541906a3aa8cdbd8bd7ab400984
parent 10d2a72d16b12eca04c760db6eebad5f329a4001
Author: Gábor Stefanik <netrolller.3d@gmail.com>
Date:   Mon,  5 Feb 2024 10:02:34 +0100

Improve pseudo-interactive prompts using the early bash

By wrapping $(cat) in an eval, redirections and other advanced
syntax can now work in the early prompts.
Also, since "set -E" is broken is the early bash, fall back to
using "set -e" and an EXIT trap, until we can upgrade to a bash
version that already has working "set -E", or perhaps backport
it to 2.05b.

Diffstat:

Mseed/script-generator.c5+++--
Msteps/improve/open_console.sh2+-
2 files changed, 4 insertions(+), 3 deletions(-)

diff --git a/seed/script-generator.c b/seed/script-generator.c @@ -451,8 +451,9 @@ FILE *start_script(int id, int bash_build) { if (bash_build != 1) { fputs("set -E\ntrap 'env PS1=\"[TRAP] \\w # \" bash -i' ERR\n", out); } else { - fputs("set -E\ntrap 'bash -c '\"'\"'while true; do printf \"" - "[TRAP - use Ctrl+D] $(pwd) # \"; $(cat); done'\"'\"'' ERR\n", + /* FIXME early bash has buggy ERR trap handling */ + fputs("set -e\ntrap 'bash -c '\"'\"'while true; do printf \"" + "[TRAP - use Ctrl+D] $(pwd) # \"; eval \"$(cat)\"; done'\"'\"'' EXIT\n", out); } } else { diff --git a/steps/improve/open_console.sh b/steps/improve/open_console.sh @@ -7,5 +7,5 @@ if bash --version | grep -q 'GPLv3'; then env - PATH=${PREFIX}/bin PS1="\w # " openvt -- bash -i else - bash -c 'while true; do printf "[early Bash - use Ctrl+D] $(pwd) # "; $(cat /dev/tty2); done' &> /dev/tty2 & + bash -c 'while true; do printf "[early Bash - use Ctrl+D] $(pwd) # "; eval "$(cat /dev/tty2)"; done' &> /dev/tty2 & fi