]> git.donarmstrong.com Git - lilypond.git/blob - lily/tuplet-engraver.cc
patch::: 1.3.18.jcn1
[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--1999 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 ADD_THIS_TRANSLATOR (Tuplet_engraver);
19
20 bool
21 Tuplet_engraver::do_try_music (Music *r)
22 {
23   if (Time_scaled_music * c = dynamic_cast<Time_scaled_music *> (r))
24     {
25       Music *el = c->element_l ();
26       if (!dynamic_cast<Request_chord*> (el))
27         {
28           time_scaled_music_arr_.push (c);
29           stop_moments_.push (now_mom () + c->length_mom ());
30         }
31       return true;
32     }
33   return false;
34 }
35
36 void
37 Tuplet_engraver::do_process_requests ()
38 {
39   int dir = 0;
40   SCM prop = get_property ("tupletDirection", 0);
41   if (isdir_b (prop))
42     dir = to_dir (prop);
43   int visibility = 3;
44   prop = get_property ("tupletVisibility", 0);
45   if (gh_number_p(prop))
46     visibility = gh_scm2int (prop);     // bool ?
47
48   for (int i= started_span_p_arr_.size ();
49        i < time_scaled_music_arr_.size (); i++)
50     {
51       Tuplet_spanner* glep = new Tuplet_spanner;
52       started_span_p_arr_.push (glep);
53       glep->set_elt_property ("text",
54                               ly_str02scm (to_str (time_scaled_music_arr_[i]->den_i_).ch_C()));
55       
56       glep->set_elt_property("tuplet-visibility",
57                              gh_int2scm (visibility));
58       if (dir != 0)
59         glep->set_elt_property("dir-forced", gh_int2scm (dir));
60       announce_element (Score_element_info (glep, time_scaled_music_arr_ [i]));
61     }
62 }
63
64 void
65 Tuplet_engraver::acknowledge_element (Score_element_info i)
66 {
67   bool grace= to_boolean (i.elem_l_->get_elt_property ("grace"));
68   SCM wg = get_property ("weAreGraceContext",0);
69   bool wgb = to_boolean (wg);
70   if (grace != wgb)
71     return;
72   
73   if (Note_column *nc = dynamic_cast<Note_column *> (i.elem_l_))
74     {
75       for (int j =0; j  <started_span_p_arr_.size (); j++)
76         started_span_p_arr_[j]->add_column (nc);
77     }
78   else if (Beam *b = dynamic_cast<Beam *> (i.elem_l_))
79     {
80       for (int j = 0; j < started_span_p_arr_.size (); j++)
81         started_span_p_arr_[j]->add_beam (b);
82     }
83 }
84
85 void
86 Tuplet_engraver::do_post_move_processing ()
87 {
88   Moment now = now_mom ();
89   for (int i= started_span_p_arr_.size (); i--; )
90     {
91       if (now >= stop_moments_[i])
92         {
93           typeset_element (started_span_p_arr_[i]);
94           started_span_p_arr_.del (i);
95           stop_moments_.del(i);
96           time_scaled_music_arr_.del(i);
97         }
98     }
99 }
100
101 void
102 Tuplet_engraver::do_removal_processing ()
103 {
104   for (int i=0; i < started_span_p_arr_.size (); i++)
105     {
106       typeset_element (started_span_p_arr_[i]);
107     }  
108 }
109