From 570ffdcb5bec87248a6387559ed54ee81dc3f1d7 Mon Sep 17 00:00:00 2001 From: Bolun Thompson Date: Mon, 18 Nov 2024 16:31:48 -0800 Subject: [PATCH] Set IFS to default before use in compiler. (#734) * Fix: when compiler uses IFS, set it to default Signed-off-by: Bolun Thompson * fix: remove local path from test Signed-off-by: Bolun Thompson --------- Signed-off-by: Bolun Thompson Co-authored-by: Bolun Thompson --- .../orchestrator_runtime/pash_prepare_call_compiler.sh | 5 +++++ .../speculative/speculative_runtime.sh | 10 ++++++---- evaluation/tests/interface_tests/run.sh | 7 +++++++ evaluation/tests/interface_tests/test-IFS.sh | 5 +++++ runtime/wait_for_output_and_sigpipe_rest.sh | 2 +- 5 files changed, 24 insertions(+), 5 deletions(-) create mode 100644 evaluation/tests/interface_tests/test-IFS.sh diff --git a/compiler/orchestrator_runtime/pash_prepare_call_compiler.sh b/compiler/orchestrator_runtime/pash_prepare_call_compiler.sh index 22a2b37c8..e6294ec9e 100644 --- a/compiler/orchestrator_runtime/pash_prepare_call_compiler.sh +++ b/compiler/orchestrator_runtime/pash_prepare_call_compiler.sh @@ -49,6 +49,9 @@ else pash_runtime_return_code=1 fi +# save IFS to restore after field splitting +[ -n "${IFS+x}" ] && saved_IFS=$IFS +unset IFS # Get assigned process id # We need to split the daemon response into elements of an array by # shell's field splitting. @@ -56,6 +59,8 @@ fi response_args=($daemon_response) process_id=${response_args[1]} +[ -n "${saved_IFS+x}" ] && IFS="$saved_IFS" + pash_redir_output echo "$$: (2) Compiler exited with code: $pash_runtime_return_code" ## only when --assert_all_regions_parallellizable is used do we care about all regions being parallelizable diff --git a/compiler/orchestrator_runtime/speculative/speculative_runtime.sh b/compiler/orchestrator_runtime/speculative/speculative_runtime.sh index 7c91c1bcd..e8f2a55f4 100644 --- a/compiler/orchestrator_runtime/speculative/speculative_runtime.sh +++ b/compiler/orchestrator_runtime/speculative/speculative_runtime.sh @@ -26,8 +26,12 @@ daemon_response=$(pash_spec_communicate_scheduler "$msg") # Blocking step, daemo ## Receive an exit code if [[ "$daemon_response" == *"OK:"* ]]; then + # save IFS to restore after field splitting + [ -n "${IFS+set}" ] && saved_IFS=$IFS + unset IFS # shellcheck disable=SC2206 response_args=($daemon_response) + [ -n "${saved_IFS+set}" ] && IFS=$saved_IFS pash_redir_output echo "$$: (2) Scheduler responded: $daemon_response" cmd_exit_code=${response_args[1]} output_variable_file=${response_args[2]} @@ -46,10 +50,8 @@ elif [[ "$daemon_response" == *"UNSAFE:"* ]]; then ## KK 2023-06-01 Does `eval` work in general? We need to be precise ## about which commands are unsafe to determine how to execute them. cmd=$(cat "$PASH_SPEC_NODE_DIRECTORY/$pash_speculative_command_id") - ## KK 2023-06-01 Not sure if this shellcheck warning must be resolved: - ## > note: Double quote to prevent globbing and word splitting. - # shellcheck disable=SC2086 - eval $cmd + ## Word splitting isn't needed since eval combines all the arguments into a single string + eval "$cmd" cmd_exit_code=$? elif [ -z "$daemon_response" ]; then ## Trouble... Daemon crashed, rip diff --git a/evaluation/tests/interface_tests/run.sh b/evaluation/tests/interface_tests/run.sh index 3d67201e3..0aa93edec 100755 --- a/evaluation/tests/interface_tests/run.sh +++ b/evaluation/tests/interface_tests/run.sh @@ -321,6 +321,12 @@ test_redir_dup() $shell redir-dup.sh } +test_IFS() +{ + local shell=$1 + $shell test-IFS.sh +} + ## We run all tests composed with && to exit on the first that fails if [ "$#" -eq 0 ]; then run_test test1 @@ -365,6 +371,7 @@ if [ "$#" -eq 0 ]; then run_test test_star run_test test_env_vars run_test test_redir_dup + run_test test_IFS else for testname in $@ do diff --git a/evaluation/tests/interface_tests/test-IFS.sh b/evaluation/tests/interface_tests/test-IFS.sh new file mode 100644 index 000000000..ecc977f80 --- /dev/null +++ b/evaluation/tests/interface_tests/test-IFS.sh @@ -0,0 +1,5 @@ +IFS=/ +curr_dir=/test1/test2/test3/test4 +for name in $curr_dir; do + echo "$name" +done diff --git a/runtime/wait_for_output_and_sigpipe_rest.sh b/runtime/wait_for_output_and_sigpipe_rest.sh index a56bfb597..5974da51c 100755 --- a/runtime/wait_for_output_and_sigpipe_rest.sh +++ b/runtime/wait_for_output_and_sigpipe_rest.sh @@ -15,7 +15,7 @@ export internal_exec_status=$? # This value may contains multiple pids as a whitespace-separated string, and # we must split it as multiple pids by shell's field splitting. # shellcheck disable=SC2086 -(> /dev/null 2>&1 kill -SIGPIPE $pids_to_kill || true) +(unset IFS; > /dev/null 2>&1 kill -SIGPIPE $pids_to_kill || true) ## ## Old way of waiting, very inefficient.