X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fprob.cc;h=4e068fa4d45301a7b19daea13b277e55e7795353;hb=8c603a010e6700558cee38a801fbafe4c6968765;hp=2c651358f3086de4c96182b9a80fa6d6c136f4e4;hpb=3465d3e1c1d2b87f7a1adc5c7c1dfe868c754e57;p=lilypond.git diff --git a/lily/prob.cc b/lily/prob.cc index 2c651358f3..4e068fa4d4 100644 --- a/lily/prob.cc +++ b/lily/prob.cc @@ -3,12 +3,14 @@ source file of the GNU LilyPond music typesetter - (c) 2004--2006 Jan Nieuwenhuizen + (c) 2004--2007 Jan Nieuwenhuizen */ #include "prob.hh" #include "main.hh" #include "item.hh" +#include "input.hh" +#include "profile.hh" #include "ly-smobs.icc" @@ -41,12 +43,20 @@ Prob::equal_p (SCM sa, SCM sb) /* Compare mutable and immutable lists, element by element. */ for (i = 0; i < 2; i++) { - SCM aprop = props[0][i], bprop = props[1][i]; + SCM aprop = props[0][i]; + SCM bprop = props[1][i]; - for (; scm_is_pair (aprop) && scm_is_pair(bprop); aprop = scm_cdr (aprop), bprop = scm_cdr (bprop)) + for (; + scm_is_pair (aprop) && scm_is_pair (bprop); + aprop = scm_cdr (aprop), bprop = scm_cdr (bprop)) { + SCM aval = scm_cdar (aprop); + SCM bval = scm_cdar (bprop); if (scm_caar (aprop) != scm_caar (bprop) || - !to_boolean (scm_equal_p (scm_cdar (aprop), scm_cdar (bprop)))) + ( + !(unsmob_input (aval) && unsmob_input (bval)) + && + !to_boolean (scm_equal_p (aval, bval)))) return SCM_BOOL_F; } @@ -101,6 +111,8 @@ Prob::derived_mark () const SCM Prob::mark_smob (SCM smob) { + ASSERT_LIVE_IS_ALLOWED (); + Prob *system = (Prob *) SCM_CELL_WORD_1 (smob); scm_gc_mark (system->mutable_property_alist_); system->derived_mark (); @@ -129,6 +141,11 @@ Prob::print_smob (SCM smob, SCM port, scm_print_state*) SCM Prob::internal_get_property (SCM sym) const { +#ifndef NDEBUG + if (profile_property_accesses) + note_property_access (&prob_property_lookup_table, sym); +#endif + /* TODO: type checking */ @@ -140,12 +157,15 @@ Prob::internal_get_property (SCM sym) const return (s == SCM_BOOL_F) ? SCM_EOL : scm_cdr (s); } +/* We don't (yet) instrument probs */ void -Prob::internal_set_property (SCM sym, SCM val -#ifndef NDEBUG - , char const *file, int line, char const *fun -#endif - ) +Prob::instrumented_set_property (SCM sym, SCM val, const char*, int, const char*) +{ + internal_set_property (sym, val); +} + +void +Prob::internal_set_property (SCM sym, SCM val) { if (do_internal_type_checking_global) type_check_assignment (sym, val);