← Index
NYTProf Performance Profile   « line view »
For ../prof.pl
  Run on Wed Dec 14 16:10:05 2022
Reported on Wed Dec 14 16:12:58 2022

Filename/Users/ether/.perlbrew/libs/36.0@std/lib/perl5/Role/Tiny/With.pm
StatementsExecuted 16 statements in 290µs
Subroutines
Calls P F Exclusive
Time
Inclusive
Time
Subroutine
11143µs46µsRole::Tiny::With::::BEGIN@3Role::Tiny::With::BEGIN@3
11133µs80µsRole::Tiny::With::::BEGIN@4Role::Tiny::With::BEGIN@4
22213µs6.05msRole::Tiny::With::::withRole::Tiny::With::with
11111µs21µsRole::Tiny::With::::BEGIN@11Role::Tiny::With::BEGIN@11
1114µs4µsRole::Tiny::With::::BEGIN@9Role::Tiny::With::BEGIN@9
Call graph for these subroutines as a Graphviz dot language file.
Line State
ments
Time
on line
Calls Time
in subs
Code
1package Role::Tiny::With;
2
3235µs249µs
# spent 46µs (43+3) within Role::Tiny::With::BEGIN@3 which was called: # once (43µs+3µs) by Data::Perl::Collection::Array::MooseLike::BEGIN@7 at line 3
use strict;
# spent 46µs making 1 call to Role::Tiny::With::BEGIN@3 # spent 3µs making 1 call to strict::import
4269µs2127µs
# spent 80µs (33+47) within Role::Tiny::With::BEGIN@4 which was called: # once (33µs+47µs) by Data::Perl::Collection::Array::MooseLike::BEGIN@7 at line 4
use warnings;
# spent 80µs making 1 call to Role::Tiny::With::BEGIN@4 # spent 47µs making 1 call to warnings::import
5
610sour $VERSION = '2.002004';
712µs$VERSION =~ tr/_//d;
8
9223µs14µs
# spent 4µs within Role::Tiny::With::BEGIN@9 which was called: # once (4µs+0s) by Data::Perl::Collection::Array::MooseLike::BEGIN@7 at line 9
use Role::Tiny ();
# spent 4µs making 1 call to Role::Tiny::With::BEGIN@9
10
112134µs231µs
# spent 21µs (11+10) within Role::Tiny::With::BEGIN@11 which was called: # once (11µs+10µs) by Data::Perl::Collection::Array::MooseLike::BEGIN@7 at line 11
use Exporter 'import';
# spent 21µs making 1 call to Role::Tiny::With::BEGIN@11 # spent 10µs making 1 call to Exporter::import
1211µsour @EXPORT = qw( with );
13
14
# spent 6.05ms (13µs+6.04) within Role::Tiny::With::with which was called 2 times, avg 3.03ms/call: # once (7µs+4.22ms) by Module::Runtime::require_module at line 10 of Data/Perl/Collection/Array/MooseLike.pm # once (6µs+1.82ms) by Module::Runtime::require_module at line 10 of Data/Perl/Collection/Hash/MooseLike.pm
sub with {
1521µs my $target = caller;
16214µs26.04ms Role::Tiny->apply_roles_to_package($target, @_)
# spent 6.04ms making 2 calls to Role::Tiny::apply_roles_to_package, avg 3.02ms/call
17}
18
19111µs1;
20
21=head1 NAME
22
23Role::Tiny::With - Neat interface for consumers of Role::Tiny roles
24
25=head1 SYNOPSIS
26
27 package Some::Class;
28
29 use Role::Tiny::With;
30
31 with 'Some::Role';
32
33 # The role is now mixed in
34
35=head1 DESCRIPTION
36
37C<Role::Tiny> is a minimalist role composition tool. C<Role::Tiny::With>
38provides a C<with> function to compose such roles.
39
40=head1 AUTHORS
41
42See L<Role::Tiny> for authors.
43
44=head1 COPYRIGHT AND LICENSE
45
46See L<Role::Tiny> for the copyright and license.
47
48=cut
49
50