2 request.cc -- implement all musical requests.
4 source file of the GNU LilyPond music typesetter
6 (c) 1997--2000 Han-Wen Nienhuys <hanwen@cs.uu.nl>
9 #include "musical-request.hh"
12 #include "music-list.hh"
15 Tremolo_req::Tremolo_req ()
22 Melodic_req::transpose (Musical_pitch delta)
24 pitch_.transpose (delta);
26 if (abs (pitch_.accidental_i_) > 2)
28 warning (_f ("Transposition by %s makes accidental larger than two",
34 Melodic_req::do_equal_b (Request const* r) const
36 Melodic_req const* m= dynamic_cast <Melodic_req const*> (r);
37 return m&& !compare (*m, *this);
41 Melodic_req::compare (Melodic_req const &m1 , Melodic_req const&m2)
43 return Musical_pitch::compare (m1.pitch_, m2.pitch_);
47 Rhythmic_req::compare (Rhythmic_req const &r1, Rhythmic_req const &r2)
49 return (r1.length_mom () - r2.length_mom ());
53 Rhythmic_req::do_equal_b (Request const* r) const
55 Rhythmic_req const* rh = dynamic_cast <Rhythmic_req const*> (r);
57 return rh && !compare (*this, *rh);
63 Rhythmic_req::length_mom () const
65 return duration_.length_mom ();
69 Rhythmic_req::compress (Moment m)
71 duration_.compress (m);
77 Note_req::do_equal_b (Request const* r) const
79 Note_req const* n = dynamic_cast<Note_req const*> (r);
80 return n&& Rhythmic_req::do_equal_b (n) && Melodic_req::do_equal_b (n);
86 cautionary_b_ = false;
95 Span_req::do_equal_b (Request const*r) const
97 Span_req const* s = dynamic_cast <Span_req const*> (r);
98 return s && get_span_dir () == s->get_span_dir ();
101 Span_req::Span_req ()
107 Text_script_req::do_equal_b (Request const* r) const
109 Text_script_req const* t = dynamic_cast<Text_script_req const*> (r);
110 return t && gh_equal_p (get_mus_property ("text"),
111 t->get_mus_property ("text"));
116 Articulation_req::do_equal_b (Request const* r) const
118 Articulation_req const* a = dynamic_cast<Articulation_req const*> (r);
120 return a && articulation_str_ == a->articulation_str_;