Обратите внимание, как просто в
подсчитывается количество (не скрытых) элементов внутри каталога с помощью команд wc и sed:
size=$(ls "$file" | wc −l | sed 's/[^[: digit: ]]//g')
Чтобы получить список содержимого сценария, запустите сценарий без аргументов, как показано в листинге 2.13. Чтобы получить информацию о другом каталоге, передайте имя этого каталога сценарию в виде единственного аргумента командной строки.
Листинг 2.13.Тестирование сценария formatdir
$ formatdir ~
Applications (0 entries)··············Classes (4KB)
DEMO (5 entries)······················Desktop (8 entries)
Documents (38 entries)················Incomplete (9 entries)
IntermediateHTML (3 entries)··········Library (38 entries)
Movies (1 entry)······················Music (1 entry)
NetInfo (9 entries)·················· Pictures (38 entries)
Public (1 entry)······················RedHat 7.2 (2.08GB)
Shared (4 entries)····················Synchronize! Volume ID (4KB)
X Desktop (4KB)······················ automatic-updates.txt (4KB)
bin (31 entries)······················cal-liability.tar.gz (104KB)
cbhma.tar.gz (376KB)··················errata (2 entries)
fire aliases (4KB)····················games (3 entries)
junk (4KB)····························leftside navbar (39 entries)
mail (2 entries)······················perinatal.org (0 entries)
scripts.old (46 entries)··············test.sh (4KB)
testfeatures.sh (4KB)················ topcheck (3 entries)
tweakmktargs.c (4KB)··················websites.tar.gz (18.85MB)
Усовершенствование сценария
С данным сценарием может возникнуть проблема, если в системе имеется пользователь, обожающий последовательности из трех «крышек» в именах файлов. Конечно, это весьма маловероятно — из 116 696 файлов в нашей тестовой системе Linux не нашлось ни одного, имя которого содержало хотя бы один символ крышки, — но если такое случится, вывод сценария окажется испорченным. Если вас волнует эта проблема, попробуйте преобразовывать пробелы в другую последовательность символов, еще менее вероятную в именах файлов. Четыре «крышки»? Пять?
№ 19. Поиск файлов по именам
В системах Linux имеется очень практичная команда locate, которая не всегда присутствует в других разновидностях Unix. Эта команда выполняет поиск в предварительно созданной базе данных имен файлов по регулярному выражению, указанному пользователем. Нужно быстро найти мастер-файл .cshrc ? Ниже показано, как это сделать с помощью locate:
$ locate.cshrc
/.Trashes/501/Previous Systems/private/etc/csh.cshrc
/OS9 Snapshot/Staging Archive/:home/taylor/.cshrc
/private/etc/csh.cshrc
/Users/taylor/.cshrc
/Volumes/110GB/WEBSITES/staging.intuitive.com/home/mdella/.cshrc
Как видите, в системе OS X мастер-файл .cshrc находится в каталоге /private/etc . Версия locate, которую мы напишем, будет просматривать все файлы на диске и конструировать их внутренний список для быстрого поиска, где бы они ни находились — в корзине, на отдельном томе. В списке окажутся даже скрытые файлы, имена которых начинаются с точки. Как вы вскоре поймете, это одновременно достоинство и недостаток новой команды.
Описываемый метод поиска файлов прост в реализации и предполагает создание двух сценариев. Первый (в листинге 2.14) создает базу данных всех имен файлов, вызывая команду find, а второй (в листинге 2.15) — просто вызывает команду grep для поиска в новой базе данных.
Листинг 2.14.Сценарий mklocatedb
··#!/bin/bash
··# mklocatedb — создает базу данных для locate с использованием find.
··#·· Для запуска этого сценария пользователь должен обладать привилегиями
··#·· суперпользователя root.
··locatedb="/var/locate.db"
··if ["$(whoami)"!= "root"]; then
····echo "Must be root to run this command." >&2
····exit 1
··fi
··find / −print > $locatedb
··exit 0
Второй сценарий еще короче.
Листинг 2.15.Сценарий locate
#!/bin/sh
# locate — выполняет поиск в базе данных по заданному шаблону
locatedb="/var/locate.db"
exec grep −i "$@" $locatedb
Сценарий mklocatedb должен запускаться с привилегиями суперпользователя root, чтобы он смог увидеть все файлы во всей системе, поэтому в строке
он проверяет свои привилегии с помощью команды whoami. Однако запуск сценария с привилегиями root влечет за собой проблему безопасности, потому что, если каталог закрыт для рядовых пользователей, база данных locate не должна хранить информацию о нем или его содержимом. Эта проблема будет решена в главе 5, в новом, более безопасном сценарии locate, который учитывает правила защищенности и безопасности (сценарий № 39). А пока данный сценарий просто имитирует поведение стандартной команды locate из Linux, OS X и других дистрибутивов.
Читать дальше