X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Faccidental-placement.cc;h=268580e4ab1d55d77c301466a2aa160b27cfaf9f;hb=0f491fbd52e8a7b5160e980eb700847932089778;hp=15049f5bc0d076c568cc395608bd46a808407bb4;hpb=ade39b0e10fdf852db6254afac36473a1c66a4d3;p=lilypond.git diff --git a/lily/accidental-placement.cc b/lily/accidental-placement.cc index 15049f5bc0..268580e4ab 100644 --- a/lily/accidental-placement.cc +++ b/lily/accidental-placement.cc @@ -68,7 +68,8 @@ Accidental_placement::split_accidentals (Grob *accs, { Grob *a = unsmob_grob (scm_car (s)); - if (unsmob_grob (a->get_object ("tie"))) + if (unsmob_grob (a->get_object ("tie")) + && !to_boolean (a->get_property ("forced"))) break_reminder->push_back (a); else real_acc->push_back (a); @@ -76,54 +77,23 @@ Accidental_placement::split_accidentals (Grob *accs, } vector -Accidental_placement::get_break_reminder_accidentals (vector const &elts, Grob *left) +Accidental_placement::get_relevant_accidentals (vector const &elts, Grob *left) { vector br; vector ra; vector ret; - - if (dynamic_cast (left)->break_status_dir () != RIGHT) - return vector (); + bool right = dynamic_cast (left)->break_status_dir () == RIGHT; for (vsize i = 0; i < elts.size (); i++) { split_accidentals (elts[i], &br, &ra); - ret.insert (ret.end (), br.begin (), br.end ()); - } - return ret; -} - -/* - Accidentals are special, because they appear and disappear after - ties at will. -*/ -Interval -Accidental_placement::get_relevant_accidental_extent (Grob *me, - Item *item_col, - Grob *left_object) -{ - vector br, ra; - vector *which = 0; - - Accidental_placement::split_accidentals (me, &br, &ra); - concat (br, ra); - - if (dynamic_cast (left_object)->break_status_dir () == RIGHT) - which = &br; - else - which = &ra; - - Interval extent; - for (vsize i = 0; i < which->size (); i++) - extent.unite (which->at (i)->extent (item_col, X_AXIS)); + + ret.insert (ret.end (), ra.begin (), ra.end ()); - if (!extent.is_empty ()) - { - Real p = robust_scm2double (me->get_property ("left-padding"), 0.2); - extent[LEFT] -= p; + if (right) + ret.insert (ret.end (), br.begin (), br.end ()); } - - return extent; + return ret; } struct Accidental_placement_entry @@ -243,7 +213,7 @@ stagger_apes (vector *apes) */ -MAKE_SCHEME_CALLBACK(Accidental_placement, calc_positioning_done, 1); +MAKE_SCHEME_CALLBACK (Accidental_placement, calc_positioning_done, 1); SCM Accidental_placement::calc_positioning_done (SCM smob) {