Небольшое тестирование показывает, что мой предыдущий комментарий неверен:
$ cat long_running.sh
#!/bin/bash
sleep 3
echo "long_running: $$"
pstree -ps $$
status=$((RANDOM % 2))
echo "exiting with status $status"
exit $status
$./long_running.sh
long_running: 6599
systemd(1)───gnome-terminal-(4112)───bash(5899)───long_running.sh(6599)───pstree(6601)
exiting with status 1
$ (./long_running.sh )
long_running: 6618
systemd(1)───gnome-terminal-(4112)───bash(5899)───long_running.sh(6618)───pstree(6621)
exiting with status 0
Нет «man -в -средней -оболочке, поэтому я полагаю, что bash порождает подоболочку и exec
команды.
Чтобы зафиксировать статус выхода, вы делаете правильную вещь
$ (./long_running.sh ) & pid=$!; wait $pid && echo ok || echo damn
[1] 7439
long_running: 7439
systemd(1)───gnome-terminal-(4112)───bash(5899)───long_running.sh(7439)───pstree(7441)
exiting with status 0
[1]+ Done (./long_running.sh )
ok
$ (./long_running.sh ) & pid=$!; wait $pid && echo ok || echo damn
[1] 7457
long_running: 7457
systemd(1)───gnome-terminal-(4112)───bash(5899)───long_running.sh(7457)───pstree(7461)
exiting with status 1
[1]+ Exit 1 (./long_running.sh )
damn
Используйте
mv -n dirB/* dirA/
или
cp -n dirB/* dirA/
Из справочной страницы mv и cp:
-n, --no-clobber
do not overwrite an existing file