← Index
NYTProf Performance Profile   « block view • line view • sub view »
For conv.pl
  Run on Sun Nov 14 22:50:31 2010
Reported on Sun Nov 14 22:51:21 2010

Filename/usr/lib/perl5/XML/LibXML/Number.pm
StatementsExecuted 17 statements in 766µs
Subroutines
Calls P F Exclusive
Time
Inclusive
Time
Subroutine
111683µs879µsXML::LibXML::Number::::BEGIN@12XML::LibXML::Number::BEGIN@12
11128µs89µsXML::LibXML::Number::::BEGIN@19XML::LibXML::Number::BEGIN@19
11120µs20µsXML::LibXML::Number::::BEGIN@11XML::LibXML::Number::BEGIN@11
11114µs20µsXML::LibXML::Number::::BEGIN@13XML::LibXML::Number::BEGIN@13
11113µs54µsXML::LibXML::Number::::BEGIN@15XML::LibXML::Number::BEGIN@15
0000s0sXML::LibXML::Number::::as_stringXML::LibXML::Number::as_string
0000s0sXML::LibXML::Number::::as_xmlXML::LibXML::Number::as_xml
0000s0sXML::LibXML::Number::::cmpXML::LibXML::Number::cmp
0000s0sXML::LibXML::Number::::evaluateXML::LibXML::Number::evaluate
0000s0sXML::LibXML::Number::::newXML::LibXML::Number::new
0000s0sXML::LibXML::Number::::string_valueXML::LibXML::Number::string_value
0000s0sXML::LibXML::Number::::to_booleanXML::LibXML::Number::to_boolean
0000s0sXML::LibXML::Number::::to_literalXML::LibXML::Number::to_literal
0000s0sXML::LibXML::Number::::to_numberXML::LibXML::Number::to_number
0000s0sXML::LibXML::Number::::valueXML::LibXML::Number::value
Call graph for these subroutines as a Graphviz dot language file.
Line State
ments
Time
on line
Calls Time
in subs
Code
1# $Id: Number.pm 785 2009-07-16 14:17:46Z pajas $
2#
3# This is free software, you may use it and distribute it under the same terms as
4# Perl itself.
5#
6# Copyright 2001-2003 AxKit.com Ltd., 2002-2006 Christian Glahn, 2006-2009 Petr Pajas
7#
8#
9
10package XML::LibXML::Number;
11343µs120µs
# spent 20µs within XML::LibXML::Number::BEGIN@11 which was called: # once (20µs+0s) by XML::LibXML::Boolean::BEGIN@12 at line 11
use XML::LibXML::Boolean;
# spent 20µs making 1 call to XML::LibXML::Number::BEGIN@11
123154µs1879µs
# spent 879µs (683+196) within XML::LibXML::Number::BEGIN@12 which was called: # once (683µs+196µs) by XML::LibXML::Boolean::BEGIN@12 at line 12
use XML::LibXML::Literal;
# spent 879µs making 1 call to XML::LibXML::Number::BEGIN@12
13343µs226µs
# spent 20µs (14+6) within XML::LibXML::Number::BEGIN@13 which was called: # once (14µs+6µs) by XML::LibXML::Boolean::BEGIN@12 at line 13
use strict;
# spent 20µs making 1 call to XML::LibXML::Number::BEGIN@13 # spent 6µs making 1 call to strict::import
14
15371µs295µs
# spent 54µs (13+41) within XML::LibXML::Number::BEGIN@15 which was called: # once (13µs+41µs) by XML::LibXML::Boolean::BEGIN@12 at line 15
use vars qw ($VERSION);
# spent 54µs making 1 call to XML::LibXML::Number::BEGIN@15 # spent 41µs making 1 call to vars::import
1612µs$VERSION = "1.70"; # VERSION TEMPLATE: DO NOT CHANGE
17
18use overload
19161µs
# spent 89µs (28+61) within XML::LibXML::Number::BEGIN@19 which was called: # once (28µs+61µs) by XML::LibXML::Boolean::BEGIN@12 at line 21
'""' => \&value,
# spent 61µs making 1 call to overload::import
20 '0+' => \&value,
213449µs189µs '<=>' => \&cmp;
# spent 89µs making 1 call to XML::LibXML::Number::BEGIN@19
22
23sub new {
24 my $class = shift;
25 my $number = shift;
26 if ($number !~ /^\s*(-\s*)?(\d+(\.\d*)?|\.\d+)\s*$/) {
27 $number = undef;
28 }
29 else {
30 $number =~ s/\s+//g;
31 }
32 bless \$number, $class;
33}
34
35sub as_string {
36 my $self = shift;
37 defined $$self ? $$self : 'NaN';
38}
39
40sub as_xml {
41 my $self = shift;
42 return "<Number>" . (defined($$self) ? $$self : 'NaN') . "</Number>\n";
43}
44
45sub value {
46 my $self = shift;
47 $$self;
48}
49
50sub cmp {
51 my $self = shift;
52 my ($other, $swap) = @_;
53 if ($swap) {
54 return $other <=> $$self;
55 }
56 return $$self <=> $other;
57}
58
59sub evaluate {
60 my $self = shift;
61 $self;
62}
63
64sub to_boolean {
65 my $self = shift;
66 return $$self ? XML::LibXML::Boolean->True : XML::LibXML::Boolean->False;
67}
68
69sub to_literal { XML::LibXML::Literal->new($_[0]->as_string); }
70sub to_number { $_[0]; }
71
72sub string_value { return $_[0]->value }
73
7414µs1;
75__END__