line |
stmt |
bran |
cond |
sub |
pod |
time |
code |
1
|
|
|
|
|
|
|
package Plack::Middleware::Runtime; |
2
|
2
|
|
|
2
|
|
14
|
use strict; |
|
2
|
|
|
|
|
4
|
|
|
2
|
|
|
|
|
90
|
|
3
|
2
|
|
|
2
|
|
10
|
use parent qw(Plack::Middleware); |
|
2
|
|
|
|
|
2
|
|
|
2
|
|
|
|
|
13
|
|
4
|
2
|
|
|
2
|
|
115
|
use Plack::Util; |
|
2
|
|
|
|
|
3
|
|
|
2
|
|
|
|
|
46
|
|
5
|
2
|
|
|
2
|
|
9
|
use Plack::Util::Accessor qw(header_name); |
|
2
|
|
|
|
|
3
|
|
|
2
|
|
|
|
|
13
|
|
6
|
2
|
|
|
2
|
|
898
|
use Time::HiRes; |
|
2
|
|
|
|
|
2532
|
|
|
2
|
|
|
|
|
8
|
|
7
|
|
|
|
|
|
|
|
8
|
|
|
|
|
|
|
sub call { |
9
|
5
|
|
|
5
|
1
|
13
|
my($self, $env) = @_; |
10
|
|
|
|
|
|
|
|
11
|
5
|
|
|
|
|
26
|
my $start = [ Time::HiRes::gettimeofday ]; |
12
|
5
|
|
|
|
|
47
|
my $res = $self->app->($env); |
13
|
5
|
|
50
|
|
|
1000231
|
my $header = $self->header_name || 'X-Runtime'; |
14
|
|
|
|
|
|
|
|
15
|
|
|
|
|
|
|
$self->response_cb($res, sub { |
16
|
5
|
|
|
5
|
|
10
|
my $res = shift; |
17
|
5
|
|
|
|
|
29
|
my $req_time = sprintf '%.6f', Time::HiRes::tv_interval($start); |
18
|
5
|
|
|
|
|
158
|
Plack::Util::header_set($res->[1], $header, $req_time); |
19
|
5
|
|
|
|
|
52
|
}); |
20
|
|
|
|
|
|
|
} |
21
|
|
|
|
|
|
|
|
22
|
|
|
|
|
|
|
1; |
23
|
|
|
|
|
|
|
|
24
|
|
|
|
|
|
|
__END__ |