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
|
package LXRng::Repo::Git::File;
use strict;
use base qw(LXRng::Repo::File);
use LXRng::Repo::TmpFile;
use File::Temp qw(tempdir);
sub new {
my ($class, $repo, $name, $ref, $rel) = @_;
return bless({repo => $repo, name => $name, ref => $ref, rel => $rel},
$class);
}
sub time {
my ($self) = @_;
if ($$self{'repo'}->_use_author_timestamp) {
# This is painfully slow. It is only performed index-time,
# but that might stil be bad enough that you would want to
# just use the release-timestamp insted.
my $cinfo = $$self{'repo'}->_git_cmd('log', '--pretty=raw',
'--max-count=1', '--all',
'..'.$$self{'rel'},
'--', $self->name);
my $time;
while (<$cinfo>) {
$time = $1 if /^author .*? (\d+(?: [-+]\d+|))$/ ;
$time ||= $1 if /^committer .*? (\d+(?: [-+]\d+|))$/ ;
}
return $time if $time;
}
return $$self{'repo'}->_release_timestamp($$self{'rel'});
}
sub size {
my ($self) = @_;
my $git = $$self{'repo'}->_git_cmd('cat-file', '-s', $$self{'ref'});
my $size = <$git>;
close($git);
chomp($size);
return $size;
}
sub handle {
my ($self) = @_;
return $$self{'repo'}->_git_cmd('cat-file', 'blob', $$self{'ref'});
}
sub revision {
my ($self) = @_;
return $$self{'ref'};
}
sub phys_path {
my ($self) = @_;
return $$self{'phys_path'} if exists $$self{'phys_path'};
my $tmpdir = tempdir() or die($!);
open(my $phys, ">", $tmpdir.'/'.$self->node) or die($!);
my $handle = $self->handle();
my $buf = '';
while (sysread($handle, $buf, 64*1024) > 0) {
print($phys $buf) or die($!);
}
close($handle);
close($phys) or die($!);
return $$self{'phys_path'} =
LXRng::Repo::TmpFile->new(dir => $tmpdir,
node => $self->node);
}
1;
|