| File | /usr/local/lib/perl5/site_perl/5.10.1/MooseX/AttributeHelpers/Trait/Collection/Hash.pm |
| Statements Executed | 17 |
| Statement Execution Time | 270µs |
| Calls | P | F | Exclusive Time |
Inclusive Time |
Subroutine |
|---|---|---|---|---|---|
| 1 | 1 | 1 | 624µs | 8.12ms | MooseX::AttributeHelpers::Trait::Collection::Hash::BEGIN@9 |
| 1 | 1 | 1 | 13µs | 1.42ms | MooseX::AttributeHelpers::Trait::Collection::Hash::BEGIN@3 |
| 1 | 1 | 1 | 8µs | 115µs | MooseX::AttributeHelpers::Trait::Collection::Hash::BEGIN@22 |
| 2 | 1 | 1 | 4µs | 4µs | MooseX::AttributeHelpers::Trait::Collection::Hash::helper_type |
| Line | State ments |
Time on line |
Calls | Time in subs |
Code |
|---|---|---|---|---|---|
| 1 | |||||
| 2 | package MooseX::AttributeHelpers::Trait::Collection::Hash; | ||||
| 3 | 3 | 50µs | 2 | 2.82ms | # spent 1.42ms (13µs+1.40) within MooseX::AttributeHelpers::Trait::Collection::Hash::BEGIN@3 which was called
# once (13µs+1.40ms) by MooseX::AttributeHelpers::BEGIN@19 at line 3 # spent 1.42ms making 1 call to MooseX::AttributeHelpers::Trait::Collection::Hash::BEGIN@3
# spent 1.40ms making 1 call to Moose::Exporter::__ANON__[Moose/Exporter.pm:389] |
| 4 | |||||
| 5 | 1 | 600ns | our $VERSION = '0.23'; | ||
| 6 | 1 | 14µs | $VERSION = eval $VERSION; | ||
| 7 | 1 | 300ns | our $AUTHORITY = 'cpan:STEVAN'; | ||
| 8 | |||||
| 9 | 3 | 146µs | 1 | 8.12ms | # spent 8.12ms (624µs+7.49) within MooseX::AttributeHelpers::Trait::Collection::Hash::BEGIN@9 which was called
# once (624µs+7.49ms) by MooseX::AttributeHelpers::BEGIN@19 at line 9 # spent 8.12ms making 1 call to MooseX::AttributeHelpers::Trait::Collection::Hash::BEGIN@9 |
| 10 | |||||
| 11 | 1 | 2µs | 1 | 1.97ms | with 'MooseX::AttributeHelpers::Trait::Collection'; # spent 1.97ms making 1 call to Moose::Role::with |
| 12 | |||||
| 13 | 1 | 2µs | 1 | 95µs | has 'method_provider' => ( # spent 95µs making 1 call to Moose::Role::has |
| 14 | is => 'ro', | ||||
| 15 | isa => 'ClassName', | ||||
| 16 | predicate => 'has_method_provider', | ||||
| 17 | default => 'MooseX::AttributeHelpers::MethodProvider::Hash' | ||||
| 18 | ); | ||||
| 19 | |||||
| 20 | 2 | 6µs | # spent 4µs within MooseX::AttributeHelpers::Trait::Collection::Hash::helper_type which was called 2 times, avg 2µs/call:
# 2 times (4µs+0s) by MooseX::AttributeHelpers::Trait::Base::process_options_for_provides at line 59 of MooseX/AttributeHelpers/Trait/Base.pm, avg 2µs/call | ||
| 21 | |||||
| 22 | 3 | 32µs | 2 | 222µs | # spent 115µs (8+107) within MooseX::AttributeHelpers::Trait::Collection::Hash::BEGIN@22 which was called
# once (8µs+107µs) by MooseX::AttributeHelpers::BEGIN@19 at line 22 # spent 115µs making 1 call to MooseX::AttributeHelpers::Trait::Collection::Hash::BEGIN@22
# spent 107µs making 1 call to Moose::Exporter::__ANON__[Moose/Exporter.pm:478] |
| 23 | |||||
| 24 | 1 | 16µs | 1; | ||
| 25 | |||||
| 26 | __END__ | ||||
| 27 | |||||
| 28 | =pod | ||||
| 29 | |||||
| 30 | =head1 NAME | ||||
| 31 | |||||
| 32 | MooseX::AttributeHelpers::Collection::Hash | ||||
| 33 | |||||
| 34 | =head1 SYNOPSIS | ||||
| 35 | |||||
| 36 | package Stuff; | ||||
| 37 | use Moose; | ||||
| 38 | use MooseX::AttributeHelpers; | ||||
| 39 | |||||
| 40 | has 'options' => ( | ||||
| 41 | metaclass => 'Collection::Hash', | ||||
| 42 | is => 'ro', | ||||
| 43 | isa => 'HashRef[Str]', | ||||
| 44 | default => sub { {} }, | ||||
| 45 | provides => { | ||||
| 46 | 'set' => 'set_option', | ||||
| 47 | 'get' => 'get_option', | ||||
| 48 | 'empty' => 'has_options', | ||||
| 49 | 'count' => 'num_options', | ||||
| 50 | 'delete' => 'delete_option', | ||||
| 51 | } | ||||
| 52 | ); | ||||
| 53 | |||||
| 54 | =head1 DESCRIPTION | ||||
| 55 | |||||
| 56 | This module provides a Hash attribute which provides a number of | ||||
| 57 | hash-like operations. See L<MooseX::AttributeHelpers::MethodProvider::Hash> | ||||
| 58 | for more details. | ||||
| 59 | |||||
| 60 | =head1 METHODS | ||||
| 61 | |||||
| 62 | =over 4 | ||||
| 63 | |||||
| 64 | =item B<meta> | ||||
| 65 | |||||
| 66 | =item B<method_provider> | ||||
| 67 | |||||
| 68 | =item B<has_method_provider> | ||||
| 69 | |||||
| 70 | =item B<helper_type> | ||||
| 71 | |||||
| 72 | =back | ||||
| 73 | |||||
| 74 | =head1 BUGS | ||||
| 75 | |||||
| 76 | All complex software has bugs lurking in it, and this module is no | ||||
| 77 | exception. If you find a bug please either email me, or add the bug | ||||
| 78 | to cpan-RT. | ||||
| 79 | |||||
| 80 | =head1 AUTHOR | ||||
| 81 | |||||
| 82 | Stevan Little E<lt>stevan@iinteractive.comE<gt> | ||||
| 83 | |||||
| 84 | =head1 COPYRIGHT AND LICENSE | ||||
| 85 | |||||
| 86 | Copyright 2007-2009 by Infinity Interactive, Inc. | ||||
| 87 | |||||
| 88 | L<http://www.iinteractive.com> | ||||
| 89 | |||||
| 90 | This library is free software; you can redistribute it and/or modify | ||||
| 91 | it under the same terms as Perl itself. | ||||
| 92 | |||||
| 93 | =cut |