#include "paper-def.hh"
#include "debug.hh"
#include "paper-column.hh"
-#include "atom.hh"
+
Crescendo::Crescendo ()
{
-Molecule*
-Crescendo::do_brew_molecule_p () const
+
+Molecule
+Crescendo::do_brew_molecule () const
{
Real absdyn_dim = paper_l ()-> get_var ("crescendo_shorten");
Real extra_left = get_broken_left_end_align ();
if (!isdir_b (dir) || !gh_pair_p (dyns))
{
-Crescendo * me = (Crescendo*)this;
+ Crescendo * me = (Crescendo*)this;
me->set_elt_property ("transparent", SCM_BOOL_T);
- return new Molecule;
+ Molecule m;
+
+ return m;
}
Direction gd = to_dir (dir);
Drul_array<bool> broken;
Direction d = LEFT;
- do {
- Paper_column* s = dynamic_cast<Paper_column*>(spanned_drul_[d]); // UGH
- broken[d] = (!s->musical_b ());
- } while (flip (&d) != LEFT);
+ do
+ {
+ Paper_column* s = dynamic_cast<Paper_column*>(get_bound (d)); // UGH
+ broken[d] = (!s->musical_b ());
+ }
+ while (flip (&d) != LEFT);
+
+ Molecule m;
+
+ Real pad = 0;
+ SCM s = get_elt_property ("start-text");
+ if (gh_string_p (s))
+ {
+ Molecule start_text (lookup_l ()->text ("italic",
+ ly_scm2string (s),
+ paper_l ()));
+ m.add_molecule (start_text);
+
+ pad = paper_l ()->get_var ("interline") / 2;
+
+ width -= start_text.extent (X_AXIS).length ();
+ width -= pad;
+ width = width >? 0;
+ }
+
+ SCM at;
+ s = get_elt_property ("spanner");
+ Real height;
+ if (gh_string_p (s) && ly_scm2string (s) == "dashed-line")
+ {
+ Real thick = paper_l ()->get_var ("crescendo_dash_thickness");
+ Real dash = paper_l ()->get_var ("crescendo_dash");
+ height = thick;
+ at = gh_list (ly_symbol2scm (ly_scm2string (s).ch_C ()),
+ gh_double2scm (thick),
+ gh_double2scm (dash),
+ gh_double2scm (width),
+ SCM_UNDEFINED);
+ }
+ else
+ {
+ bool continued = broken[Direction (-gd)];
+ height = paper_l()->get_var ("crescendo_height");
+ Real thick = paper_l ()->get_var ("crescendo_thickness");
+
+ const char* hairpin = (gd < 0)? "decrescendo" : "crescendo";
+
+ at = gh_list (ly_symbol2scm (hairpin),
+ gh_double2scm (thick),
+ gh_double2scm (width),
+ gh_double2scm (height),
+ gh_double2scm (continued ? height/2 : 0.0),
+ SCM_UNDEFINED);
+ }
+ Box b (Interval (0, width), Interval (-2*height, 2*height));
+ Molecule span (b, at);
+
+ m.add_at_edge (X_AXIS, RIGHT, span, pad);
+ m.translate_axis (extra_left, X_AXIS);
- bool continued = broken[Direction (-gd)];
- Real height = paper_l()->get_var ("crescendo_height");
- Real thick = paper_l ()->get_var ("crescendo_thickness");
-
- const char* hairpin = (gd < 0)? "decrescendo" : "crescendo";
- Molecule * m
- = new Molecule;
- m->dim_.x () = Interval (0, width);
- m->dim_.y () = Interval (-2*height, 2*height);
-
- SCM at = gh_list (ly_symbol2scm (hairpin),
- gh_double2scm (thick),
- gh_double2scm (width),
- gh_double2scm (height),
- gh_double2scm (continued ? height/2 : 0.0),
- SCM_UNDEFINED);
-
- m->add_atom (at);
- m->translate_axis (extra_left, X_AXIS);
return m;
}