bash-скрипт, который выполняет команду ln -s, получает код ошибки при выходе, но символические ссылки создаются успешно

Я написал скрипт bash, который должен проходить по файлам и каталогам в TARGET DIR и создавать символическую ссылку на все каталоги в DESTINATION DIR. Сценарий работает, но команда ln выдает код выхода>0 из того, что я могу сказать, и поэтому соответствующее сообщение об успехе не печатается.

ЗДЕСЬ СПРАВОЧНИК ПО НАЗНАЧЕНИЮ ДО ВЫПОЛНЕНИЯ СЦЕНАРИИ:

obi@Hanzomon:/home/dog⟫ ls -la
total 8
drwxr-xr-x 2 obi obi 4096 Dec 24 11:13 .
drwxr-xr-x 8 obi obi 4096 Dec 24 10:32 ..

ЗДЕСЬ ЦЕЛЕВОЙ КАТАЛОГ С ОЧЕНЬ МНОЖЕСТВОМ ПОДРАЗДЕЛЕНИЙ

obi@Hanzomon:/home/dog⟫ ls /home/bud
bzfs.conf  Downloads         Music     Templates  VirtualBox VMs
Desktop    examples.desktop  Pictures  vboxen     vmz
Documents  lab               Public    Videos

Вот выход, когда я запускаю его:

obi@Hanzomon:/home/dog⟫ /home/obi/scripts/dirlink.sh                            
/home/bud/Desktop failed to link to /home/dog/Desktop
/home/bud/Documents failed to link to /home/dog/Documents
/home/bud/Downloads failed to link to /home/dog/Downloads
/home/bud/lab failed to link to /home/dog/lab
/home/bud/Music failed to link to /home/dog/Music
/home/bud/Pictures failed to link to /home/dog/Pictures
/home/bud/Public failed to link to /home/dog/Public
/home/bud/Templates failed to link to /home/dog/Templates
/home/bud/vboxen failed to link to /home/dog/vboxen
/home/bud/Videos failed to link to /home/dog/Videos
/home/bud/VirtualBox VMs failed to link to /home/dog/VirtualBox VMs
/home/bud/vmz failed to link to /home/dog/vmz

ЗДЕСЬ DIR DESTINATION после сценария запускается с добавленными символами.

obi@Hanzomon:/home/dog⟫ ls -la
total 8
drwxr-xr-x 2 obi obi 4096 Dec 24 11:13 .
drwxr-xr-x 8 obi obi 4096 Dec 24 10:32 ..
lrwxrwxrwx 1 obi obi   17 Dec 24 11:13 Desktop -> /home/bud/Desktop
lrwxrwxrwx 1 obi obi   19 Dec 24 11:13 Documents -> /home/bud/Documents
lrwxrwxrwx 1 obi obi   19 Dec 24 11:13 Downloads -> /home/bud/Downloads
lrwxrwxrwx 1 obi obi   13 Dec 24 11:13 lab -> /home/bud/lab
lrwxrwxrwx 1 obi obi   15 Dec 24 11:13 Music -> /home/bud/Music
lrwxrwxrwx 1 obi obi   18 Dec 24 11:13 Pictures -> /home/bud/Pictures
lrwxrwxrwx 1 obi obi   16 Dec 24 11:13 Public -> /home/bud/Public
lrwxrwxrwx 1 obi obi   19 Dec 24 11:13 Templates -> /home/bud/Templates
lrwxrwxrwx 1 obi obi   16 Dec 24 11:13 vboxen -> /home/bud/vboxen
lrwxrwxrwx 1 obi obi   16 Dec 24 11:13 Videos -> /home/bud/Videos
lrwxrwxrwx 1 obi obi   24 Dec 24 11:13 VirtualBox VMs -> /home/bud/VirtualBox VMs
lrwxrwxrwx 1 obi obi   13 Dec 24 11:13 vmz -> /home/bud/vmz

СЮДА ПИСЬМО:

#!/bin/bash

SAVEIFS=$IFS
IFS=$(echo -en "\n\b")

TARDIR="/home/bud"
DESTDIR="/home/dog"

if  [ ! -d $TARDIR ]; then
        printf "$TARDIR does not exist!\n"
        exit
fi

if [ ! -d $DESTDIR ]; then 
        printf "$DESTDIR does not exist!\n"
        exit
fi


TARDIR="$TARDIR/*"
for DIR in $TARDIR; do
        if [ -d $DIR ]; then
                printf "$DIR"
                TARG="$DESTDIR/$(basename "$DIR")"
                if [  $(ln -s "$DIR" "$TARG") ]; then
                        printf " ==>  $TARG\n"
                else
                        printf " failed to link to $TARG\n"
                fi
        fi

done

IFS=$SAVEIFS

Итак, суть в том, что скрипт работает, но [ $(ln -s "$DIR" "$TARG") ] должен возвращать ноль, а строка printf " ==> $TARG\n" должна выводить сообщение об успехе, но вместо этого я получаю сообщение об ошибке "ссылка на", даже если каталог назначения пуст.

Есть идеи / предложения?

Спасибо!

1 ответ

Решение

Эта строка неверна:

if [  $(ln -s "$DIR" "$TARG") ]; then

Это тестирование, если ln генерирует какой-либо вывод, независимо от того, успешно он или нет. Измените это на:

if ln -s "$DIR" "$TARG"; then

Удалите лишнюю печать, привыкните писать сообщения об ошибках в stderr и выходите с ненулевым значением, если ваш скрипт завершится неудачно. (например, printf 'this is an error' >&2; exit 1;)

Другие вопросы по тегам