summaryrefslogtreecommitdiff
path: root/hv.c
diff options
context:
space:
mode:
authorNicholas Clark <nick@ccl4.org>2008-09-12 00:19:51 +0000
committerNicholas Clark <nick@ccl4.org>2008-09-12 00:19:51 +0000
commita49ba3fcbe357fbacf7b9898df08daa2cbdfc8c4 (patch)
tree43834e70391760038633daf86cecae00b95fef4e /hv.c
parentc109477dfda0dedbe3c4ffa3d6074085d3b8497a (diff)
downloadperl-a49ba3fcbe357fbacf7b9898df08daa2cbdfc8c4.tar.gz
Create a direct lookup hash for ->isa() lookup, by retaining the
de-duping hash used by S_mro_get_linear_isa_dfs(). Provide a new function Perl_get_isa_hash() to lazily retrieve this. (Which could actually be static if S_isa_lookup() and Perl_sv_derived_from() moved into mro.c.) Make S_isa_lookup() use this lookup hash in place of a linear walk of the linear isa. This should turn isa lookups from O(n) to O(1), which should make heavy users of ->isa() faster. (eg PPI, and hence Perl Critic). p4raw-id: //depot/perl@34354
Diffstat (limited to 'hv.c')
-rw-r--r--hv.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/hv.c b/hv.c
index c394e73fb0..0cbb4836f9 100644
--- a/hv.c
+++ b/hv.c
@@ -1688,6 +1688,7 @@ S_hfreeentries(pTHX_ HV *hv)
if(meta->mro_linear_dfs) SvREFCNT_dec(meta->mro_linear_dfs);
if(meta->mro_linear_c3) SvREFCNT_dec(meta->mro_linear_c3);
if(meta->mro_nextmethod) SvREFCNT_dec(meta->mro_nextmethod);
+ SvREFCNT_dec(meta->isa);
Safefree(meta);
iter->xhv_mro_meta = NULL;
}