$|=1;
local (*F1,*F2); my %farray = (); my $statF1;
# ------------------------------
# traverse directories
sub scan ($) {
my ($dir) = $_[0];
opendir (DIR, $dir) or die "($dir) $!:$@";
map {
(-d) ? scan ($_) : push @{$farray{-s $_}},$_
unless (-l or -S or -p or -c or -b);
} map "$dir/$_", grep !/^/./.?$/, readdir (DIR); closedir (DIR);
}
# ------------------------------
# get chunk of bytes from a file
sub getchunk ($$) {
my ($fsize,$pfname) = @_;
my $chunksize = 32;
my ($nread,$buff);
return undef unless open(F1,$$pfname);
$statF1 = [(stat F1)[3,1]];
binmode F1;
$nread = read (F1,$buff,$chunksize);
($nread == $chunksize || $nread == $fsize) ? "$buff" : undef;
}
# ------------------------------
# compare two files
sub mycmp ($) {
my ($fptr) = $_[0];
my ($buffa, $buffb);
my ($nread1,$nread2);
my $statF2;
my ($buffsize) = 16*1024;
return -1 unless (open(F2,"<$$fptr"));
$statF2 = [(stat F2)[3,1]];
return 0
if ($statF2->[0] > 1 && $statF1->[1] == $statF2->[1]);
binmode F2;
seek (F1,0,0);
do { $nread1 = read (F1,$buffa,$buffsize);
$nread2 = read (F2,$buffb,$buffsize);
if (($nread1 != $nread2) || ($buffa cmp $buffb)) {
return -1;
}
} while ($nread1);
return 0;
}
# ------------------------------
print "collecting files and sizes .../n";
if (-t STDIN) {
$ARGV[0] = '.' unless $ARGV[0]; # use wd if no arguments given
map scan $_, @ARGV;
} else {
while (<STDIN>) {
s
主站蜘蛛池模板:
天天草夜夜操
|
午夜剧
|
四虎av在线
|
欧美视频一区
|
国产一区二区三区精品久久久
|
欧美综合视频
|
国产一区二区三区在线
|
久久久久国产精品一区二区
|
亚洲男人天堂
|
久久国产精品视频
|
国产在线高清
|
亚洲精品乱码久久久v下载方式
|
亚洲精品在线播放视频
|
国产欧美一区二区精品性色
|
久久久久国产
|
精品免费
|
亚洲97
|
日韩在线播放一区
|
精品欧美一区二区三区久久久小说
|
天天干人人
|
www久久99
|
国精日本亚洲欧州国产中文久久
|
国产精品黄网站在线观看
|
国产精品久久久久久久久久
|
色婷婷av一区二区三区软件
|
天天干天天av
|
久久亚洲美女
|
亚洲精品v
|
亚洲91在线
|
国产ts视频
|
午夜婷婷激情
|
农村少妇kkkk7777
|
伊人天天操
|
亚洲欧美在线免费观看
|
99视频在线免费观看
|
日韩一区二区在线播放
|
免费的色网站
|
中文一区|
夜夜操天天干
|
日韩欧美黄色
|
九九综合网站
|