Filename | /Users/ether/perl5/perlbrew/perls/36.0/lib/5.36.0/Module/Load.pm |
Statements | Executed 38 statements in 1.72ms |
Calls | P | F | Exclusive Time |
Inclusive Time |
Subroutine |
---|---|---|---|---|---|
1 | 1 | 1 | 1.26ms | 1.54ms | _load | Module::Load::
1 | 1 | 1 | 66µs | 70µs | BEGIN@3 | Module::Load::
1 | 1 | 1 | 39µs | 44µs | BEGIN@14 | Module::Load::
1 | 1 | 1 | 23µs | 39µs | _to_file | Module::Load::
1 | 1 | 1 | 12µs | 18µs | BEGIN@89 | Module::Load::
1 | 1 | 1 | 11µs | 33µs | BEGIN@4 | Module::Load::
1 | 1 | 1 | 8µs | 10µs | _is_file | Module::Load::
1 | 1 | 1 | 4µs | 4µs | _who | Module::Load::
1 | 1 | 1 | 3µs | 3µs | BEGIN@5 | Module::Load::
2 | 1 | 1 | 2µs | 2µs | CORE:match (opcode) | Module::Load::
1 | 1 | 1 | 2µs | 2µs | load | Module::Load::
0 | 0 | 0 | 0s | 0s | autoload | Module::Load::
0 | 0 | 0 | 0s | 0s | autoload_remote | Module::Load::
0 | 0 | 0 | 0s | 0s | import | Module::Load::
0 | 0 | 0 | 0s | 0s | load_remote | Module::Load::
Line | State ments |
Time on line |
Calls | Time in subs |
Code |
---|---|---|---|---|---|
1 | package Module::Load; | ||||
2 | |||||
3 | 2 | 50µs | 2 | 74µs | # spent 70µs (66+4) within Module::Load::BEGIN@3 which was called:
# once (66µs+4µs) by YAML::PP::Schema::BEGIN@5 at line 3 # spent 70µs making 1 call to Module::Load::BEGIN@3
# spent 4µs making 1 call to strict::import |
4 | 2 | 23µs | 2 | 55µs | # spent 33µs (11+22) within Module::Load::BEGIN@4 which was called:
# once (11µs+22µs) by YAML::PP::Schema::BEGIN@5 at line 4 # spent 33µs making 1 call to Module::Load::BEGIN@4
# spent 22µs making 1 call to warnings::import |
5 | 2 | 76µs | 1 | 3µs | # spent 3µs within Module::Load::BEGIN@5 which was called:
# once (3µs+0s) by YAML::PP::Schema::BEGIN@5 at line 5 # spent 3µs making 1 call to Module::Load::BEGIN@5 |
6 | |||||
7 | 1 | 1µs | our $VERSION = '0.36'; | ||
8 | |||||
9 | |||||
10 | sub import { | ||||
11 | my $who = _who(); | ||||
12 | my $h; shift; | ||||
13 | |||||
14 | 2 | 353µs | 2 | 49µs | # spent 44µs (39+5) within Module::Load::BEGIN@14 which was called:
# once (39µs+5µs) by YAML::PP::Schema::BEGIN@5 at line 14 # spent 44µs making 1 call to Module::Load::BEGIN@14
# spent 5µs making 1 call to strict::unimport |
15 | |||||
16 | @_ or ( | ||||
17 | *{"${who}::load"} = \&load, # compat to prev version | ||||
18 | *{"${who}::autoload"} = \&autoload, | ||||
19 | return | ||||
20 | ); | ||||
21 | |||||
22 | map { $h->{$_} = () if defined $_ } @_; | ||||
23 | |||||
24 | (exists $h->{none} or exists $h->{''}) | ||||
25 | and shift, last; | ||||
26 | |||||
27 | ((exists $h->{autoload} and shift,1) or (exists $h->{all} and shift)) | ||||
28 | and *{"${who}::autoload"} = \&autoload; | ||||
29 | |||||
30 | ((exists $h->{load} and shift,1) or exists $h->{all}) | ||||
31 | and *{"${who}::load"} = \&load; | ||||
32 | |||||
33 | ((exists $h->{load_remote} and shift,1) or exists $h->{all}) | ||||
34 | and *{"${who}::load_remote"} = \&load_remote; | ||||
35 | |||||
36 | ((exists $h->{autoload_remote} and shift,1) or exists $h->{all}) | ||||
37 | and *{"${who}::autoload_remote"} = \&autoload_remote; | ||||
38 | |||||
39 | } | ||||
40 | |||||
41 | } | ||||
42 | |||||
43 | # spent 2µs within Module::Load::load which was called:
# once (2µs+0s) by YAML::PP::Schema::load_subschemas at line 139 of YAML/PP/Schema.pm | ||||
44 | 1 | 6µs | 1 | 1.54ms | goto &_load; # spent 1.54ms making 1 call to Module::Load::_load |
45 | } | ||||
46 | |||||
47 | sub autoload(*;@){ | ||||
48 | unshift @_, 'autoimport'; | ||||
49 | goto &_load; | ||||
50 | } | ||||
51 | |||||
52 | sub load_remote($$;@){ | ||||
53 | my ($dst, $src, @exp) = @_; | ||||
54 | |||||
55 | eval "package $dst;Module::Load::load('$src', qw/@exp/);"; | ||||
56 | $@ && die "$@"; | ||||
57 | } | ||||
58 | |||||
59 | sub autoload_remote($$;@){ | ||||
60 | my ($dst, $src, @exp) = @_; | ||||
61 | |||||
62 | eval "package $dst;Module::Load::autoload('$src', qw/@exp/);"; | ||||
63 | $@ && die "$@"; | ||||
64 | } | ||||
65 | |||||
66 | # spent 1.54ms (1.26+273µs) within Module::Load::_load which was called:
# once (1.26ms+273µs) by YAML::PP::Schema::load_subschemas at line 44 | ||||
67 | 1 | 1µs | my $autoimport = $_[0] eq 'autoimport' and shift; | ||
68 | 1 | 1µs | my $mod = shift or return; | ||
69 | 1 | 2µs | 1 | 4µs | my $who = _who(); # spent 4µs making 1 call to Module::Load::_who |
70 | |||||
71 | 1 | 2µs | 1 | 10µs | if( _is_file( $mod ) ) { # spent 10µs making 1 call to Module::Load::_is_file |
72 | require $mod; | ||||
73 | } else { | ||||
74 | LOAD: { | ||||
75 | 2 | 0s | my $err; | ||
76 | 1 | 1µs | for my $flag ( qw[1 0] ) { | ||
77 | 1 | 1µs | 1 | 39µs | my $file = _to_file( $mod, $flag); # spent 39µs making 1 call to Module::Load::_to_file |
78 | 2 | 551µs | eval { require $file }; | ||
79 | 1 | 1µs | $@ ? $err .= $@ : last LOAD; | ||
80 | } | ||||
81 | die $err if $err; | ||||
82 | } | ||||
83 | } | ||||
84 | |||||
85 | ### This addresses #41883: Module::Load cannot import | ||||
86 | ### non-Exporter module. ->import() routines weren't | ||||
87 | ### properly called when load() was used. | ||||
88 | |||||
89 | 3 | 584µs | 2 | 24µs | # spent 18µs (12+6) within Module::Load::BEGIN@89 which was called:
# once (12µs+6µs) by YAML::PP::Schema::BEGIN@5 at line 89 # spent 18µs making 1 call to Module::Load::BEGIN@89
# spent 6µs making 1 call to strict::unimport |
90 | 1 | 0s | my $import; | ||
91 | |||||
92 | 1 | 1µs | ((@_ or $autoimport) and ( | ||
93 | $import = $mod->can('import') | ||||
94 | ) and ( | ||||
95 | unshift(@_, $mod), | ||||
96 | goto &$import | ||||
97 | ) | ||||
98 | ); | ||||
99 | } | ||||
100 | |||||
101 | } | ||||
102 | |||||
103 | # spent 39µs (23+16) within Module::Load::_to_file which was called:
# once (23µs+16µs) by Module::Load::_load at line 77 | ||||
104 | 1 | 0s | local $_ = shift; | ||
105 | 1 | 1µs | my $pm = shift || ''; | ||
106 | |||||
107 | ## trailing blanks ignored by default. [rt #69886] | ||||
108 | 1 | 7µs | my @parts = split /::|'/, $_, -1; | ||
109 | ## make sure that we can't hop out of @INC | ||||
110 | 1 | 1µs | shift @parts if @parts && !$parts[0]; | ||
111 | |||||
112 | ### because of [perl #19213], see caveats ### | ||||
113 | 1 | 25µs | 4 | 23µs | my $file = $^O eq 'MSWin32' # spent 16µs making 1 call to File::Spec::Unix::catfile
# spent 5µs making 1 call to File::Spec::Unix::catdir
# spent 2µs making 2 calls to File::Spec::Unix::canonpath, avg 1µs/call |
114 | ? join "/", @parts | ||||
115 | : File::Spec->catfile( @parts ); | ||||
116 | |||||
117 | 1 | 1µs | $file .= '.pm' if $pm; | ||
118 | |||||
119 | ### on perl's before 5.10 (5.9.5@31746) if you require | ||||
120 | ### a file in VMS format, it's stored in %INC in VMS | ||||
121 | ### format. Therefor, better unixify it first | ||||
122 | ### Patch in reply to John Malmbergs patch (as mentioned | ||||
123 | ### above) on p5p Tue 21 Aug 2007 04:55:07 | ||||
124 | 1 | 1µs | $file = VMS::Filespec::unixify($file) if $^O eq 'VMS'; | ||
125 | |||||
126 | 1 | 5µs | return $file; | ||
127 | } | ||||
128 | |||||
129 | 1 | 7µs | # spent 4µs within Module::Load::_who which was called:
# once (4µs+0s) by Module::Load::_load at line 69 | ||
130 | |||||
131 | # spent 10µs (8+2) within Module::Load::_is_file which was called:
# once (8µs+2µs) by Module::Load::_load at line 71 | ||||
132 | 1 | 1µs | local $_ = shift; | ||
133 | 1 | 12µs | 2 | 2µs | return /^\./ ? 1 : # spent 2µs making 2 calls to Module::Load::CORE:match, avg 1µs/call |
134 | /[^\w:']/ ? 1 : | ||||
135 | undef | ||||
136 | } | ||||
137 | |||||
- - | |||||
140 | 1 | 4µs | 1; | ||
141 | |||||
142 | __END__ | ||||
# spent 2µs within Module::Load::CORE:match which was called 2 times, avg 1µs/call:
# 2 times (2µs+0s) by Module::Load::_is_file at line 133, avg 1µs/call |