← Index
NYTProf Performance Profile   « line view »
For svc/members/upsert
  Run on Tue Jan 13 11:50:22 2015
Reported on Tue Jan 13 12:09:46 2015

Filename/usr/share/perl/5.20/Symbol.pm
StatementsExecuted 102 statements in 1.27ms
Subroutines
Calls P F Exclusive
Time
Inclusive
Time
Subroutine
233389µs89µsSymbol::::gensymSymbol::gensym
11123µs23µsSymbol::::BEGIN@3Symbol::BEGIN@3
0000s0sSymbol::::delete_packageSymbol::delete_package
0000s0sSymbol::::geniosymSymbol::geniosym
0000s0sSymbol::::qualifySymbol::qualify
0000s0sSymbol::::qualify_to_refSymbol::qualify_to_ref
0000s0sSymbol::::ungensymSymbol::ungensym
Call graph for these subroutines as a Graphviz dot language file.
Line State
ments
Time
on line
Calls Time
in subs
Code
1package Symbol;
2
311.14ms123µs
# spent 23µs within Symbol::BEGIN@3 which was called: # once (23µs+0s) by IO::File::BEGIN@9 at line 3
BEGIN { require 5.005; }
# spent 23µs making 1 call to Symbol::BEGIN@3
4
51600nsrequire Exporter;
615µs@ISA = qw(Exporter);
71700ns@EXPORT = qw(gensym ungensym qualify qualify_to_ref);
81200ns@EXPORT_OK = qw(delete_package geniosym);
9
101100ns$VERSION = '1.07';
11
121300nsmy $genpkg = "Symbol::";
131100nsmy $genseq = 0;
14
1518µsmy %global = map {$_ => 1} qw(ARGV ARGVOUT ENV INC SIG STDERR STDIN STDOUT);
16
17#
18# Note that we never _copy_ the glob; we just make a ref to it.
19# If we did copy it, then SVf_FAKE would be set on the copy, and
20# glob-specific behaviors (e.g. C<*$ref = \&func>) wouldn't work.
21#
22
# spent 89µs within Symbol::gensym which was called 23 times, avg 4µs/call: # 20 times (66µs+0s) by XML::SAX::ParserFactory::_parser_class at line 83 of XML/SAX/ParserFactory.pm, avg 3µs/call # 2 times (16µs+0s) by IO::Handle::new at line 67 of IO/Handle.pm, avg 8µs/call # once (7µs+0s) by XML::SAX::load_parsers at line 60 of XML/SAX.pm
sub gensym () {
232314µs my $name = "GEN" . $genseq++;
242337µs my $ref = \*{$genpkg . $name};
252313µs delete $$genpkg{$name};
262340µs $ref;
27}
28
29sub geniosym () {
30 my $sym = gensym();
31 # force the IO slot to be filled
32 select(select $sym);
33 *$sym{IO};
34}
35
36sub ungensym ($) {}
37
38sub qualify ($;$) {
39 my ($name) = @_;
40 if (!ref($name) && index($name, '::') == -1 && index($name, "'") == -1) {
41 my $pkg;
42 # Global names: special character, "^xyz", or other.
43 if ($name =~ /^(([^a-z])|(\^[a-z_]+))\z/i || $global{$name}) {
44 # RGS 2001-11-05 : translate leading ^X to control-char
45 $name =~ s/^\^([a-z_])/'qq(\c'.$1.')'/eei;
46 $pkg = "main";
47 }
48 else {
49 $pkg = (@_ > 1) ? $_[1] : caller;
50 }
51 $name = $pkg . "::" . $name;
52 }
53 $name;
54}
55
56sub qualify_to_ref ($;$) {
57 return \*{ qualify $_[0], @_ > 1 ? $_[1] : caller };
58}
59
60#
61# of Safe.pm lineage
62#
63sub delete_package ($) {
64 my $pkg = shift;
65
66 # expand to full symbol table name if needed
67
68 unless ($pkg =~ /^main::.*::$/) {
69 $pkg = "main$pkg" if $pkg =~ /^::/;
70 $pkg = "main::$pkg" unless $pkg =~ /^main::/;
71 $pkg .= '::' unless $pkg =~ /::$/;
72 }
73
74 my($stem, $leaf) = $pkg =~ m/(.*::)(\w+::)$/;
75 my $stem_symtab = *{$stem}{HASH};
76 return unless defined $stem_symtab and exists $stem_symtab->{$leaf};
77
78 # free all the symbols in the package
79
80 my $leaf_symtab = *{$stem_symtab->{$leaf}}{HASH};
81 foreach my $name (keys %$leaf_symtab) {
82 undef *{$pkg . $name};
83 }
84
85 # delete the symbol table
86
87 %$leaf_symtab = ();
88 delete $stem_symtab->{$leaf};
89}
90
9115µs1;