Filename | /usr/lib/perl5/Sub/Name.pm |
Statements | Executed 15 statements in 150µs |
Calls | P | F | Exclusive Time |
Inclusive Time |
Subroutine |
---|---|---|---|---|---|
2667223 | 8 | 5 | 9.23s | 9.23s | subname (xsub) | Sub::Name::
1 | 1 | 1 | 15µs | 15µs | bootstrap (xsub) | Sub::Name::
1 | 1 | 1 | 10µs | 10µs | BEGIN@42 | Sub::Name::
1 | 1 | 1 | 6µs | 10µs | BEGIN@45 | Sub::Name::
1 | 1 | 1 | 6µs | 63µs | BEGIN@49 | Sub::Name::
1 | 1 | 1 | 5µs | 48µs | BEGIN@50 | Sub::Name::
1 | 1 | 1 | 5µs | 13µs | BEGIN@44 | Sub::Name::
Line | State ments |
Time on line |
Calls | Time in subs |
Code |
---|---|---|---|---|---|
1 | package Sub::Name; | ||||
2 | |||||
3 | =head1 NAME | ||||
4 | |||||
5 | Sub::Name - (re)name a sub | ||||
6 | |||||
7 | =head1 SYNOPSIS | ||||
8 | |||||
9 | use Sub::Name; | ||||
10 | |||||
11 | subname $name, $subref; | ||||
12 | |||||
13 | $subref = subname foo => sub { ... }; | ||||
14 | |||||
15 | =head1 DESCRIPTION | ||||
16 | |||||
17 | This module has only one function, which is also exported by default: | ||||
18 | |||||
19 | =head2 subname NAME, CODEREF | ||||
20 | |||||
21 | Assigns a new name to referenced sub. If package specification is omitted in | ||||
22 | the name, then the current package is used. The return value is the sub. | ||||
23 | |||||
24 | The name is only used for informative routines (caller, Carp, etc). You won't | ||||
25 | be able to actually invoke the sub by the given name. To allow that, you need | ||||
26 | to do glob-assignment yourself. | ||||
27 | |||||
28 | Note that for anonymous closures (subs that reference lexicals declared outside | ||||
29 | the sub itself) you can name each instance of the closure differently, which | ||||
30 | can be very useful for debugging. | ||||
31 | |||||
32 | =head1 AUTHOR | ||||
33 | |||||
34 | Matthijs van Duin <xmath@cpan.org> | ||||
35 | |||||
36 | Copyright (C) 2004, 2008 Matthijs van Duin. All rights reserved. | ||||
37 | This program is free software; you can redistribute it and/or modify | ||||
38 | it under the same terms as Perl itself. | ||||
39 | |||||
40 | =cut | ||||
41 | |||||
42 | 2 | 32µs | 1 | 10µs | # spent 10µs within Sub::Name::BEGIN@42 which was called:
# once (10µs+0s) by Try::Tiny::BEGIN@1 at line 42 # spent 10µs making 1 call to Sub::Name::BEGIN@42 |
43 | |||||
44 | 2 | 16µs | 2 | 21µs | # spent 13µs (5+8) within Sub::Name::BEGIN@44 which was called:
# once (5µs+8µs) by Try::Tiny::BEGIN@1 at line 44 # spent 13µs making 1 call to Sub::Name::BEGIN@44
# spent 8µs making 1 call to strict::import |
45 | 2 | 28µs | 2 | 13µs | # spent 10µs (6+3) within Sub::Name::BEGIN@45 which was called:
# once (6µs+3µs) by Try::Tiny::BEGIN@1 at line 45 # spent 10µs making 1 call to Sub::Name::BEGIN@45
# spent 3µs making 1 call to warnings::import |
46 | |||||
47 | 1 | 300ns | our $VERSION = '0.05'; | ||
48 | |||||
49 | 2 | 21µs | 2 | 121µs | # spent 63µs (6+58) within Sub::Name::BEGIN@49 which was called:
# once (6µs+58µs) by Try::Tiny::BEGIN@1 at line 49 # spent 63µs making 1 call to Sub::Name::BEGIN@49
# spent 58µs making 1 call to base::import |
50 | 2 | 43µs | 2 | 92µs | # spent 48µs (5+44) within Sub::Name::BEGIN@50 which was called:
# once (5µs+44µs) by Try::Tiny::BEGIN@1 at line 50 # spent 48µs making 1 call to Sub::Name::BEGIN@50
# spent 44µs making 1 call to base::import |
51 | |||||
52 | 1 | 600ns | our @EXPORT = qw(subname); | ||
53 | 1 | 400ns | our @EXPORT_OK = @EXPORT; | ||
54 | |||||
55 | 1 | 4µs | 1 | 138µs | bootstrap Sub::Name $VERSION; # spent 138µs making 1 call to DynaLoader::bootstrap |
56 | |||||
57 | 1 | 4µs | 1; | ||
# spent 15µs within Sub::Name::bootstrap which was called:
# once (15µs+0s) by DynaLoader::bootstrap at line 207 of DynaLoader.pm | |||||
# spent 9.23s within Sub::Name::subname which was called 2667223 times, avg 3µs/call:
# 1332073 times (4.58s+0s) by Try::Tiny::try at line 60 of Try/Tiny.pm, avg 3µs/call
# 1232780 times (4.35s+0s) by Class::MOP::Class::Immutable::Class::MOP::Class::_method_map or Class::MOP::Class::Immutable::Class::MOP::Class::class_precedence_list or Class::MOP::Class::Immutable::Class::MOP::Class::get_all_attributes or Class::MOP::Class::Immutable::Class::MOP::Class::get_meta_instance or Class::MOP::Class::Immutable::Class::MOP::Class::is_immutable or Class::MOP::Class::Immutable::Class::MOP::Class::linearized_isa or Class::MOP::Class::Immutable::Class::MOP::Class::superclasses or Class::MOP::Class::Immutable::Moose::Meta::Class::_method_map or Class::MOP::Class::Immutable::Moose::Meta::Class::calculate_all_roles or Class::MOP::Class::Immutable::Moose::Meta::Class::calculate_all_roles_with_inheritance or Class::MOP::Class::Immutable::Moose::Meta::Class::class_precedence_list or Class::MOP::Class::Immutable::Moose::Meta::Class::does_role or Class::MOP::Class::Immutable::Moose::Meta::Class::get_meta_instance or Class::MOP::Class::Immutable::Moose::Meta::Class::is_immutable or Class::MOP::Class::Immutable::Moose::Meta::Class::linearized_isa or Class::MOP::Class::Immutable::Moose::Meta::Class::superclasses or Moose::Meta::Class::__ANON__::SERIAL::10::_eval_environment or Moose::Meta::Class::__ANON__::SERIAL::10::_inline_tc_code or Moose::Meta::Class::__ANON__::SERIAL::10::new or Moose::Meta::Class::__ANON__::SERIAL::1::_canonicalize_handles or Moose::Meta::Class::__ANON__::SERIAL::1::_make_delegation_method or Moose::Meta::Class::__ANON__::SERIAL::1::_process_options or Moose::Meta::Class::__ANON__::SERIAL::1::install_accessors or Moose::Meta::Class::__ANON__::SERIAL::2::new or Moose::Meta::Class::__ANON__::SERIAL::3::new or Moose::Meta::Class::__ANON__::SERIAL::4::new or Moose::Meta::Class::__ANON__::SERIAL::5::new or Moose::Meta::Class::__ANON__::SERIAL::6::_eval_environment or Moose::Meta::Class::__ANON__::SERIAL::6::_inline_check_argument_count or Moose::Meta::Class::__ANON__::SERIAL::6::_inline_tc_code or Moose::Meta::Class::__ANON__::SERIAL::6::new or Moose::Meta::Class::__ANON__::SERIAL::7::_canonicalize_handles or Moose::Meta::Class::__ANON__::SERIAL::7::_make_delegation_method or Moose::Meta::Class::__ANON__::SERIAL::7::_process_options or Moose::Meta::Class::__ANON__::SERIAL::7::install_accessors or Moose::Meta::Class::__ANON__::SERIAL::8::new or Moose::Meta::Class::__ANON__::SERIAL::9::new at line 94 of Class/MOP/Method/Wrapped.pm, avg 4µs/call
# 101107 times (295ms+0s) by Try::Tiny::try at line 61 of Try/Tiny.pm, avg 3µs/call
# 687 times (1.53ms+0s) by Class::MOP::Mixin::HasMethods::add_method at line 75 of Class/MOP/Mixin/HasMethods.pm, avg 2µs/call
# 504 times (822µs+0s) by Moose::Exporter::__ANON__[/usr/local/lib/perl/5.18.2/Moose/Exporter.pm:389] at line 384 of Moose/Exporter.pm, avg 2µs/call
# 62 times (95µs+0s) by Class::MOP::Class::add_around_method_modifier at line 1109 of Class/MOP/Class.pm, avg 2µs/call
# 6 times (15µs+0s) by Moose::Exporter::build_import_methods at line 91 of Moose/Exporter.pm, avg 3µs/call
# 4 times (6µs+0s) by Class::MOP::Class::add_before_method_modifier at line 1089 of Class/MOP/Class.pm, avg 2µs/call |