Анимация
JavaScript


Главная  Библионтека 

0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 [ 109 ] 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242

344 Глава 9 • Каталоги Пример 9.6 (продолжение)

> else { # Создать каталог

mkdir($dstdir, 07777) or die "cant mkdir Sdstdir: $!";

} continue {

s#"(?!/)#$cwd/#;

chdir $srcdir; find(\&wanted, ,);

# Исправить относительные пути

sub wanted {

my($dev, $ino, $mode) = lstat($ ); my $name = $File::Find;:name;

$mode &= 07777; # Сохранить права доступа

$name =~ s!~\./!; « Правильное имя

if (-d ) { # Затем создать каталог

mkdir("$dstdir/$name", $mode)

or die "cant mkdir $dstdir/$name; $!"; } else { # Продублировать все остальное

symlink("$srcdir/$name", "$dstdir/$name")

or die "cant symlink $srcdir/$name to $dstdir/$name; i

9.12. Программа: 1st

Вам не приходилось отбирать из каталога самые большие или созданные последними файлы? В стандартной программе Is предусмотрены параметры для сортировки содержимого каталогов по времени (флаг -t) и для рекурсивного просмотра подкаталогов (флаг -R). Однако Is делает паузу для каждого каталога и выводит только его содержимое. Программа не просматривает все подкаталоги, чтобы потом отсортировать найденные файлы.

Следующая программа 1st справляетсяс этой задачей. Ниже показан пример подробного вывода, полученного с использованием флага -1:

% 1st -1 /etc

12695 0600 1

root

wheel

512 Fri May 29

42:41

1998

/etc/ssh random

seed

12840 0844 1

root

wheel

10104 Men May 25

39:19

1998

/etc/Id.so.cache

12826 0864 1

root

wheel

12288 Sun May 24

23:08

1998

/etc/psdevtab

12304 0844 1

root

root

237 Sun May 24

59:33

1998

/etc/exports

12309 0844 1

root

root

3388 Sun May 24

24:33

1998

/etc/inetd.conf

12399 0844 1

root

root

30205 Sun May 24

08:37

1998

/etc/sendraail.cf

18774 0644 1

gnat

perldoc

2199 Sun May 24

35:57

1998



/etc/X11/XMetroconfig 12636 0644 1 root wheel 290 Sun May 24 9:05:40 1998

/etc/ratab

12627 0640 1 root root 0 Sun May 24 8:24:31 1998

/etc/wtmplock

12310 0644 1 root tchrist 65 Sun May 24 8:23:04 1998

/etc/issue

Файл /etc/X11/XMetroconfig оказался посреди содержимого /etc, поскольку листинг относится не только к /etc, но и ко всему, что находится внутри каталога.

К числу поддерживаемых параметров также относится сортировка по времени последнего чтения вместо записи (-и) и сортировка по размеру вместо времени (-s). Флаг -i приводит к получению списка имен из стандартного ввода вместо рекурсивного просмотра каталога функцией find. Если у вас уже есть готовый список имен, его можно передать 1st для сортировки.

Исходный текст программы приведен в примере 9.7.

Пример 9.7. 1st

#!/usr/bin/perl

# 1st - вывод отсортированного содержимого каталогов

use Getopt;:Std; use File:;Find; use File:;stat; use User;;pwent; use User;;grent;

getopts(lusrcmi) or die «DEATH;

Usage; $0 [-mucsril] [dirs .,.] or $0 -i [-mucsrl] < filelist

Input format;

-i read pathnames from stdin Output format:

-1 long listing Sort on;

-m use mtime (modify time) [DEFAULT]

-u use atime (access time)

-c use ctime (inode change time)

-s use size for sorting Ordering;

-r reverse sort NB; You may only use select one sorting option at a time. DEATH

unless ($opt i II @ARGV) { @ARGV = C.) } if ($opt c + $opt u + $opt s + $opt m > 1) {



Пример 9.7 (продолжение)

die can only sort on one time or size ,

$IDX = mtime , $IDX = atime if $opt u, $IDX = ctime if $opt c, $IDX = size if $opt s,

$TIME IDX = $opt s mtime $IDX

•name = *File Find name, # Принудительное импортирование переменной

й Флаг $opt i заставляет wanted брать имена файлов й из ARGV вместо получения от find

If ($opt i) {

•name = • й $name теперь является синонимом $ while (о) { chomp, &wanted } й Все нормально это не stdin } else {

find(\&wanted, @ARGV) } •

й Отсортировать файлы по кэшированным значениям времени, й начиная с самых новых

@skeys = sort { $time{$b} <=> $time{$a} } keys %time,

Й Изменить порядок, если в командной строке был указан флаг -г @skeys = reverse @skeys if $opt r

for (@skeys) {

unless ($opt l) { » Эмулировать Is -1, кроме прав доступа print $ \n , next,

Snow = localtime $stat{$ }->$TIME IDX(),

printf %6d %04o %6d %8s %Bs %8d %s %s\n , $stat{$ }->ino(), $stat{$ }->mode() & 07777, $stat{$ }->nlink(), user($stat{$ }->uid()), group($stat{$ }->gid()), $stat{$ }->size(), $now, $ ,

Й Получить от stat информацию о файле сохраняя критерий

й сортировки (mtime, atime, ctime или size)

й в хэше %time, индексируемом по имени файла

й Если нужен длинный список, весь объект stat приходится



0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 [ 109 ] 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242