Если все сценарии завершаются ошибкой, желательно, чтобы наряду с указанием на стандартную ошибку отображалось и название сценария. В конце концов, пользователю важно знать название сценария, выполнение которого привело к появлению ошибки.
$ pg ifcp
#!/bin/sh
# ifcp
if cp myfile myfile.bak; then
echo "good copy"
else
echo "`basename $0`: error could not copy the files" >&2 fi
$ ifcp
cp: myfile: No such file or directory
ifcp: error could not copy the files
Обратите внимание на то, что в данном случае файл не может быть найден, и генерируется системное сообщение об ошибке. Ошибки такого типа могут негативно
отразиться на выводимых данных; сценарий уже отображает сообщения об ошибках, поэтому известно, что он функционирует неверно. Зачем же нам повторное уведомление? Чтобы избавиться от ошибок, генерируемых системой, и системных данных вывода, достаточно применить перенаправление стандартного потока ошибок и потока вывода. Для этого немного перепишем сценарий: > /dev/null 2>&1. В этом случае получим следующее:
$ pg ifcp
#!/bin/sh
# ifcp
if cp myfile myfile.bak >/dev/null 2>&1; then
echo "good copy"
else
echo "`basename $0`: error could not copy the files" >&2
fi
При выполнении сценария все выводимые данные, включая ошибки, направляются в системную корзину.
$ ifcp
ifcp: error could not copy the files
18.3.6. Проверка текущего каталога
Некоторые сценарии, реализующие административные задачи, можно выполнять из корневого каталога. Если производится глобальное перемещение файлов или же изменяются права доступа к файлу, несложный тест позволяет уточнить, вовлекается ли в этот процесс корневой каталог. В следующем сценарии для хранения текущего каталога переменная DIRECTORY использует подстановку команд. Затем значение этой переменой сравнивается со строкой, содержащей значение "/" (которое и соответствует корневому каталогу). Если значение переменной directory не идентично этой строке, пользователь завершает работу со сценарием. В этом случае код завершения будет 1, что свидетельствует о наличии ошибки.
$ pg ifpwd
#!/bin/sh
# ifpwd DIRECTORY=`pwd`
# захват текущего каталога
if [ "$DIRECTORY" != "/" ]; then
#это корневой каталог ?
#нет, перенаправление вывода в стандартный поток ошибок, который
#отображается на экране по умолчанию.
echo "You need to be in the root directory not $DIRECTORY to run this script" >&2
# выход из сценария со значением 1, ошибка
exit 1
fi
18.3.7. Проверка прав доступа к файлу
Вы можете также осуществлять контроль прав доступа к файлу. Ниже приводится несложная проверка на предмет того, можно ли вести записи в файле test.txt, который переприсвоен переменной logfile.
$ pg ifwr
#!/bin/sh
# ifwr
LOGFILE=test.txt echo $LOGFILE
if [ ! —w "$LOGFILE" ]; then
echo " You cannot write to $LOGFILE " >&2
fi
18.3.8. Проверка параметров, передаваемых сценарию
Оператор if может применяться при определении числа параметров, которые передаются сценарию. Чтобы проверить, соответствует ли количество необходимых параметров количеству вызываемых параметров, используется специальная переменная $#, содержащая число вызываемых параметров.
В приведенном ниже примере проверяется наличие трех параметров; если они отсутствуют, на экран выводится сообщение из стандартного потока ошибок. Затем сценарий завершается, отображая статус ошибки. Если же количество параметров равно трем, все аргументы выводятся на экран.
$ pg ifparam
#!/bin/sh
# ifparam
if [ $# -lt 3 ] ; then
#вызывается меньше, чем 3 параметра, на экран выводится сообщение, затем
#прерывается выполнение сценария
echo "Usage: `basename $0` arg1 arg2 arg3" >&2
exit 1
fi
# хорошо, получено 3 параметра, отображаются на экране
echo "arg1: $1"
echo "arg2: $2"
echo "arg3: $3"
Если передается только два параметра, на экран выводится соответствующее сообщение, и сценарий прекращает выполняться:
$ ifparam cup medal
Usage:ifparam argl arg2 arg3
При передаче трех параметров происходит следующее:
$ ifparam cup medal trophy
argl: cup arg2: medal arg3: trophy
18.3.9. Определение интерактивного режима выполнения сценария
Иногда требуется выяснить, выполняется сценарий в интерактивном режиме (режим терминала( либо не в интерактивном режиме (команды cron или at). Такая информация необходима для того, чтобы сценарий мог определить, где можно получить вводимые данные и куда направлять выводимые данные. Чтобы уточнить режим выполнения сценария, достаточно воспользоваться командой test с опцией -t. Если возвращается значение "истина", сценарий выполняется в интерактивном режиме.
$ pg ifinteractive
#! /bin/sh
# ifinteractive
if [ -t ]; then
echo "We are interactive with a terminal"
else
echo "We must be running from some background process probably cron or at " fi
18.3.10. Простые операторы if else
Следующая форма оператора if применяется чаще всего:
if условие
then команды1
else
команды2
fi
Если условие не удовлетворяет тестированию, часть else оператора if позволяет перейти к соответствующей операции.
18.3.11. Проверка установок переменных
Ниже проверяется установка переменной среды editor. Если переменной EDITOR не присвоено значение, пользователь информируется о том, что переменная editor не установлена. Если переменная editor установлена, тип редактора отображается на экране:
$ рg ifeditor
#!/bin/sh
# ifeditor
if [ -z $EDITOR ]; then
#переменная не установлена
echo "Your EDITOR environment is not set"
else
#посмотрим, что же это
echo "Using $EDITOR as the default editor"
18.3.12. Проверка пользователя, выполняющего сценарий
В следующем примере для проверки условия используется переменная среды. Здесь проверяется, присвоено ли переменной LOGNAME значение "root". Обычно этот тип оператора добавляется в начале сценариев в качестве дополнительной меры безопасности. Несомненно, переменная LOGNAME может проверяться для каждого действительного пользователя.
Если значение переменной не равно строке "root", на экран выводится сообщение из стандартного потока ошибок. Пользователь информируется о том, что он не является пользователем root, а сценарий завершается со значением ошибки, равным 1.
Если строка "root" равна значению переменной LOGNAME, выполняется оператор, который находится после else.
На практике в этом случае сценарий продолжает обработку задания в обычном режиме. Соответствующие операторы находятся после конструкции fi, поскольку все пользователи, отличные от пользователя root, лишаются доступа к сценарию еще на первом этапе проверки.
$ pg ifroot
#!/bin/sh
# ifroot
if [ "$LOGNAME" != "root" ]
# если пользователь не является пользователем root
echo "You need to be root to run this script" >&2
exit 1
else
# да, это пользователь root