Linux программирование в примерах
Шрифт:
– -apparent-size вывести видимые размеры, а не использование
диска; хотя видимый размер обычно меньше, он
может быть и больше из-за дыр в файлах,
внутренней фрагментации, косвенных блоков и т.п.
– В, --block-size=SIZE использовать блоки размером SIZE байтов
– b, --bytes эквивалентно '--apparent-size --block-size=1'
– с, --total выводит итоговую сумму
– D, --dereference-args
разыменовывать FILE, которые являются
символическими ссылками
– h, --human-readable вывести размеры в удобном для восприятия
формате (например, 1K 234М 2G)
– Н, --si так же, но использовать степени 1000, не 1024
– k подобно --block-size=1K
– l, --count-links считать размеры несколько раз при прямых
ссылках
– L, --dereference разыменовывать все символические ссылки
– S, --separate-dirs не включать размер подкаталогов
– s, --summarize отобразить для каждого аргумента лишь итоги
– х, --one-file-system пропускать каталоги на различных файловых
системах
– X --exclude- исключить файлы, подходящие под любой
FILE from=FILE образец в FILE
– -exclude=PATTERN исключить файлы, соответствующие PATTERN
– -max-depth=N вывести итог для каталога (или файла, с --all)
только если он находится на N или менее уровней
глубже аргумента командной строки;
– -max-depth=0 то же самое, что и --summarize
– -help отобразить экран справки и выйти
– -version вывести сведения о версии и выйти
SIZE может быть (или может быть целым, за которым
может следовать это) одним из
следующих: kB 1000, K 1024, MB 1 000 000, M 1 048 576 и т.д.
для G, T, Р, E, Z, Y.
Чтобы еще больше усложнить дело,
du
использует частную версию nftw
, у которой есть несколько расширений. Сначала имеются дополнительные значения флагов для функции обратного вызова:
FTW_DCHP
Это значение означает, что
nftw
не может выполнять 'chdir("..")
'.
FTW_DCH
Это значение означает, что
nftw
не может использовать chdir
для перехода в сам каталог.
FTW_DPRE
Частная
nftw
вызывает для каталогов функцию обратного вызова дважды. Это значение используется при первой встрече с каталогом. После обработки всех нижележащих объектов каталога используется стандартное значение FTW_DP
. Частная
nftw
добавляет также в struct FTW
новый член, int skip
. Если текущий объект является каталогом и функция обратного вызова устанавливает в поле skip
ненулевое значение, nftw
не будет больше обрабатывать этот каталог. (Функция обратного вызова должна установить skip
таким образом, когда flag
равен FTW_DPRE
; делать это для FTW_DP
слишком поздно.) С этим объяснением за поясом, вот функция
process_file
из du.c
. Номера строк приведены относительно начала функции:
1 /* Эта функция вызывается один раз для каждого объекта файловой
2 системы, с которой сталкивается nftw. nftw осуществляет сначала
3 поиск вглубь. Эта функция знает это и собирает итоги для каталогов
4 на основе изменений в глубине текущего элемента. */
5
6 static int
7 process_file(const char *file, const struct stat *sb,
8 int file_type, struct FTW *info)
9 {
10 uintmax_t size;
11 uintmax_t size_to_print;
12 static int first_call = 1;
13 static size_t prev_level;
14 static size_t n_alloc;
15 static uintmax_t *sum_ent;
16 static uintmax_t *sum_subdir;
17 int print = 1;
18
19 /* Всегда определяйте info->skip перед возвратом. */
20 info->skip = excluded_filename(exclude, file + info->base);
/* Для --exclude */
Эта функция делает многое, поскольку ей приходится реализовать все опции
du
. Строка 17 устанавливает print
в true (1); по умолчанию выводятся сведения о каждом файле. Дальнейший код устанавливает ее при необходимости в false (0). Строка 20 устанавливает
info->skip
на основе опции – -exclude
. Обратите внимание, что это исключает подкаталоги, если каталог совпадает с шаблоном для – -exclude
.
22 switch (file_type)
23 {
24 case FTW_NS:
25 error (0, errno, _("cannot access %s"), quote(file));
26 G_fail = 1; /* Установить глобальную переменную для дальнейшего */
27 return 0; /* Вернуть 0 для продолжения */
28
29 case FTW_DCHP:
30 error(0, errno, _("cannot change to parent of directory %s"),
Поделиться с друзьями: