2 part-combine-music.cc -- implement Part_combine_music
4 source file of the GNU LilyPond music typesetter
6 (c) 2000 Jan Nieuwenhuizen <janneke@gnu.org>
10 #include "part-combine-music.hh"
11 #include "musical-pitch.hh"
13 Part_combine_music::Part_combine_music (SCM what, Music * f, Music * s)
15 assert (gh_string_p (what));
16 set_mus_property ("what", what);
17 set_mus_property ("one", f->self_scm ());
18 set_mus_property ("two", s->self_scm ());
20 scm_unprotect_object (f->self_scm());
21 scm_unprotect_object (s->self_scm());
23 set_mus_property ("type", ly_symbol2scm ("part-combined-music"));
27 Part_combine_music::transpose (Musical_pitch p)
29 first_l ()->transpose (p);
30 second_l () ->transpose (p);
36 Part_combine_music::length_mom () const
38 return first_l ()->length_mom ();
42 Part_combine_music::to_relative_octave (Musical_pitch p)
44 p = first_l ()->to_relative_octave (p);
45 return second_l ()->to_relative_octave (p);
49 Part_combine_music::compress (Moment m)
51 first_l ()->compress (m);
52 second_l ()->compress (m);
56 Part_combine_music::first_l () const
58 return unsmob_music (get_mus_property ("one"));
62 Part_combine_music::second_l () const
64 return unsmob_music (get_mus_property ("two"));