]> git.donarmstrong.com Git - lilypond.git/blob - lily/tuplet-engraver.cc
release: 1.3.19
[lilypond.git] / lily / tuplet-engraver.cc
1 /*   
2   auto-plet-engraver.cc --  implement Auto_plet_engraver
3   
4   source file of the GNU LilyPond music typesetter
5   
6   (c) 1998--2000 Han-Wen Nienhuys <hanwen@cs.uu.nl>
7   
8  */
9
10 #include "tuplet-engraver.hh"
11 #include "command-request.hh"
12 #include "tuplet-spanner.hh"
13 #include "note-column.hh"
14 #include "time-scaled-music.hh"
15 #include "beam.hh"
16 #include "music-list.hh"
17
18 bool
19 Tuplet_engraver::do_try_music (Music *r)
20 {
21   if (Time_scaled_music * c = dynamic_cast<Time_scaled_music *> (r))
22     {
23       Music *el = c->element_l ();
24       if (!dynamic_cast<Request_chord*> (el))
25         {
26           time_scaled_music_arr_.push (c);
27           stop_moments_.push (now_mom () + c->length_mom ());
28         }
29       return true;
30     }
31   return false;
32 }
33
34 void
35 Tuplet_engraver::do_process_requests ()
36 {
37   int dir = 0;
38   SCM prop = get_property ("tupletDirection", 0);
39   if (isdir_b (prop))
40     dir = to_dir (prop);
41   int visibility = 3;
42   prop = get_property ("tupletVisibility", 0);
43   if (gh_number_p(prop))
44     visibility = gh_scm2int (prop);     // bool ?
45
46   for (int i= started_span_p_arr_.size ();
47        i < time_scaled_music_arr_.size (); i++)
48     {
49       Tuplet_spanner* glep = new Tuplet_spanner;
50       started_span_p_arr_.push (glep);
51       glep->set_elt_property ("text",
52                               ly_str02scm (to_str (time_scaled_music_arr_[i]->den_i_).ch_C()));
53       
54       glep->set_elt_property("tuplet-visibility",
55                              gh_int2scm (visibility));
56       if (dir != 0)
57         glep->set_elt_property("dir-forced", gh_int2scm (dir));
58       announce_element (Score_element_info (glep, time_scaled_music_arr_ [i]));
59     }
60 }
61
62 void
63 Tuplet_engraver::acknowledge_element (Score_element_info i)
64 {
65   bool grace= to_boolean (i.elem_l_->get_elt_property ("grace"));
66   SCM wg = get_property ("weAreGraceContext",0);
67   bool wgb = to_boolean (wg);
68   if (grace != wgb)
69     return;
70   
71   if (Note_column *nc = dynamic_cast<Note_column *> (i.elem_l_))
72     {
73       for (int j =0; j  <started_span_p_arr_.size (); j++)
74         started_span_p_arr_[j]->add_column (nc);
75     }
76   else if (Beam *b = dynamic_cast<Beam *> (i.elem_l_))
77     {
78       for (int j = 0; j < started_span_p_arr_.size (); j++)
79         started_span_p_arr_[j]->add_beam (b);
80     }
81 }
82
83 void
84 Tuplet_engraver::do_post_move_processing ()
85 {
86   Moment now = now_mom ();
87   for (int i= started_span_p_arr_.size (); i--; )
88     {
89       if (now >= stop_moments_[i])
90         {
91           typeset_element (started_span_p_arr_[i]);
92           started_span_p_arr_.del (i);
93           stop_moments_.del(i);
94           time_scaled_music_arr_.del(i);
95         }
96     }
97 }
98
99 void
100 Tuplet_engraver::do_removal_processing ()
101 {
102   for (int i=0; i < started_span_p_arr_.size (); i++)
103     {
104       typeset_element (started_span_p_arr_[i]);
105     }  
106 }
107
108 ADD_THIS_TRANSLATOR(Tuplet_engraver);
109
110