Чтение онлайн

на главную - закладки

Жанры

Linux программирование в примерах
Шрифт:

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"),

31 quote(file));

32 G_fail = 1;

33 return 0;

34

35 case FTW_DCH:

36 /* Нельзя просто вернуться, поскольку, хотя nftw не может войти в

37 каталог, она может использовать stat, постольку у нас есть размер */

38 error(0, errno, _("cannot change to directory %s"), quote(file));

39 G_fail = 1;

40 break;

41

42 case FTW_DNR:

43 /* Нельзя просто вернуться, поскольку, хотя nftw не может прочесть

44 каталог, она может вызвать stat, постольку у нас есть размер. */

45 error(0, errno, _("cannot read directory %s"), quote(file));

46 G_fail = 1;

47 break;

48

49 default:

50 break;

51 }

52

53 /* Если это первая (предварительная) встреча с каталогом,

54 сразу вернуться. */

55 if (file_type == FTW_DPRE)

56 return 0;

Строки 22–51 являются стандартным оператором

switch
. Ошибки, для которых нет информации о размере, устанавливают глобальную переменную
G_fail
в 1 и возвращают 0, чтобы продолжить обработку (см строки 24–27 и 29–33). Ошибки, для которых есть размер, также устанавливают
G_fail
, но затем прерывают
switch
для того, чтобы обработать статистику (см. строки 35–40 и 42–47).

Строки 55–56 сразу завершают функцию, если это первая встреча с каталогом

58 /* Если файл исключается или если он уже учитывался

59 через прямую ссылку, не включать его в сумму. */

60 if (info->skip,

61 || (!opt_count_all

62 && 1 < sb->st_nlink

63 && hash_ins(sb->st_ino, sb->st_dev)))

64 {

65 /* Заметьте, мы не должны здесь просто возвращаться.

66 Нам все еще нужно обновить prev_level и, возможно, передать

67 некоторые суммы выше по иерархии. */

68 size = 0;

69 print = 0;

70 }

71 else

72 {

73 size = (apparent_size

74 ? sb->st_size

75 : ST_NBLOCKS (*sb) * ST_NBLOCKSIZE);

76 }

Теперь становится интересно. По умолчанию

du
подсчитывает пространство, занимаемое прямыми ссылками, лишь одни раз. Опция
– -count-links
заставляет ее подсчитывать пространство для каждой ссылки; переменная
opt_count_all
равна true, когда указана
– -count-links
. Для отслеживания ссылок
du
содержит хэш-таблицу [87] уже встречавшихся пар (устройство, индекс).

87

Хэш-таблица является структурой данных, позволяющей быстрое получение сохраненной информации, подробности выходят за рамки данной книги — Примеч. автора.

Строки 60–63 проверяют, следует ли не включать файл в подсчет, либо из-за того, что он был исключен (

info->skip
равно true, строка 60), либо потому что не была указана
– -count-links
(строка 61) и у файла несколько ссылок (строка 62) и файл уже находится в хеш-таблице (строка 63). В этом случае размер устанавливается в 0, поэтому он не входит в конечную сумму, a
print
также устанавливается в false (строки 68–69).

Если ни одно из этих условий не отмечается, размер вычисляется либо в соответствии с размером в

struct stat
, либо в соответствии с числом блоков диска (строки 73–75) Это решение основывается на переменной
apparent_size
, которая установлена при использовании опции
– -apparent-size
.

78 if (first_call)

79 {

80 n_alloc = info->level + 10; /* Allocate arrays */

81 sum_ent = XCALLOC(uintmax_t, n_alloc); /* to hold sums */

82 sum_subdir = XCALLOC(uintmax_t, n_alloc);

83 }

84 else

85 {

86 /* FIXME: Стыдно, что нам нужно приводить к типу size_t для избежания

87 предупреждений gcc о 'сравнении между знаковым и беззнаковым'.

88 Возможно, неизбежно, при условии, что члены структуры FTW

89 имеют тип 'int' (исторически), так как мне нужно, чтобы переменные

Поделиться:
Популярные книги

Идеальный мир для Лекаря 2

Сапфир Олег
2. Лекарь
Фантастика:
юмористическая фантастика
попаданцы
аниме
5.00
рейтинг книги
Идеальный мир для Лекаря 2

Моров. Том 3

Кощеев Владимир
2. Моров
Фантастика:
фэнтези
попаданцы
аниме
5.00
рейтинг книги
Моров. Том 3

Гнездо Седого Ворона

Свержин Владимир Игоревич
2. Трактир "Разбитые надежды"
Фантастика:
боевая фантастика
7.50
рейтинг книги
Гнездо Седого Ворона

Древесный маг Орловского княжества 3

Павлов Игорь Васильевич
3. Орловское княжество
Фантастика:
аниме
сказочная фантастика
фэнтези
попаданцы
гаремник
5.00
рейтинг книги
Древесный маг Орловского княжества 3

Кодекс Охотника. Книга XIX

Винокуров Юрий
19. Кодекс Охотника
Фантастика:
фэнтези
5.00
рейтинг книги
Кодекс Охотника. Книга XIX

Идеальный мир для Лекаря 13

Сапфир Олег
13. Лекарь
Фантастика:
фэнтези
юмористическое фэнтези
аниме
5.00
рейтинг книги
Идеальный мир для Лекаря 13

Третий

INDIGO
Фантастика:
космическая фантастика
попаданцы
5.00
рейтинг книги
Третий

На границе империй. Том 10. Часть 4

INDIGO
Вселенная EVE Online
Фантастика:
боевая фантастика
космическая фантастика
попаданцы
5.00
рейтинг книги
На границе империй. Том 10. Часть 4

Мой муж – чудовище! Изгнанная жена дракона

Терин Рем
Любовные романы:
любовно-фантастические романы
5.00
рейтинг книги
Мой муж – чудовище! Изгнанная жена дракона

Я еще не царь

Дрейк Сириус
25. Дорогой барон!
Фантастика:
юмористическое фэнтези
аниме
попаданцы
5.00
рейтинг книги
Я еще не царь

Я уже князь. Книга XIX

Дрейк Сириус
19. Дорогой барон!
Фантастика:
юмористическое фэнтези
попаданцы
аниме
5.00
рейтинг книги
Я уже князь. Книга XIX

Изгой Проклятого Клана

Пламенев Владимир
1. Изгой
Фантастика:
попаданцы
аниме
фэнтези
5.00
рейтинг книги
Изгой Проклятого Клана

Имя нам Легион. Том 7

Дорничев Дмитрий
7. Меж двух миров
Фантастика:
боевая фантастика
рпг
аниме
5.00
рейтинг книги
Имя нам Легион. Том 7

Герцог. Книга 1. Формула геноцида

Юллем Евгений
1. Псевдоним "Испанец" - 2
Фантастика:
фэнтези
попаданцы
аниме
5.00
рейтинг книги
Герцог. Книга 1. Формула геноцида