X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fprofile.cc;h=a109c4bf4feb9ecb06cb9a755cc6d3c3f089ee38;hb=2fef7b7eb7ac5d7a2ed237bf22a6ec6fe5d946d9;hp=025bea809bbcc83620771ae535aefbdd9c4f0b04;hpb=74daefdc62920b729061cb8711b63890de1f0c17;p=lilypond.git diff --git a/lily/profile.cc b/lily/profile.cc index 025bea809b..a109c4bf4f 100644 --- a/lily/profile.cc +++ b/lily/profile.cc @@ -18,12 +18,11 @@ */ #include "profile.hh" +#include "protected-scm.hh" -void note_property_access (SCM *table, SCM sym); - -SCM context_property_lookup_table; -SCM grob_property_lookup_table; -SCM prob_property_lookup_table; +Protected_scm context_property_lookup_table; +Protected_scm grob_property_lookup_table; +Protected_scm prob_property_lookup_table; LY_DEFINE (ly_property_lookup_stats, "ly:property-lookup-stats", 1, 0, 0, (SCM sym), @@ -31,26 +30,26 @@ LY_DEFINE (ly_property_lookup_stats, "ly:property-lookup-stats", " @var{sym}. Choices are @code{prob}, @code{grob}, and" " @code{context}.") { - if (scm_is_eq (sym, ly_symbol2scm ("context"))) - return context_property_lookup_table ? context_property_lookup_table - : scm_c_make_hash_table (1); - if (scm_is_eq (sym, ly_symbol2scm ("prob"))) - return prob_property_lookup_table ? prob_property_lookup_table - : scm_c_make_hash_table (1); - if (scm_is_eq (sym, ly_symbol2scm ("grob"))) - return grob_property_lookup_table ? grob_property_lookup_table - : scm_c_make_hash_table (1); + if (context_property_lookup_table.is_bound () + && scm_is_eq (sym, ly_symbol2scm ("context"))) + return context_property_lookup_table; + if (prob_property_lookup_table.is_bound () + && scm_is_eq (sym, ly_symbol2scm ("prob"))) + return prob_property_lookup_table; + if (grob_property_lookup_table.is_bound () + && scm_is_eq (sym, ly_symbol2scm ("grob"))) + return grob_property_lookup_table; return scm_c_make_hash_table (1); } void -note_property_access (SCM *table, SCM sym) +note_property_access (Protected_scm *table, SCM sym) { /* Statistics: which properties are looked up? */ - if (!*table) - *table = scm_permanent_object (scm_c_make_hash_table (259)); + if (!table->is_bound ()) + *table = scm_c_make_hash_table (259); SCM hashhandle = scm_hashq_get_handle (*table, sym); if (scm_is_false (hashhandle))