lilypond-1.3.130
[lilypond.git] / lily / text-spanner-engraver.cc
blob4f339eb92cf7e6238f943b788d17ff1b03c2bef2
1 /*
2 text-spanner-engraver.cc -- implement Text_spanner_engraver
4 source file of the GNU LilyPond music typesetter
6 (c) 2000 Jan Nieuwenhuizen <janneke@gnu.org>
7 */
9 #include "dimensions.hh"
10 #include "musical-request.hh"
11 #include "paper-column.hh"
12 #include "note-column.hh"
13 #include "item.hh"
14 #include "side-position-interface.hh"
15 #include "engraver.hh"
16 #include "group-interface.hh"
17 #include "directional-element-interface.hh"
18 #include "translator-group.hh"
19 #include "axis-group-interface.hh"
22 class Text_spanner_engraver : public Engraver
24 public:
25 VIRTUAL_COPY_CONS (Translator);
26 Text_spanner_engraver ();
28 protected:
29 virtual void finalize ();
30 virtual void acknowledge_grob (Grob_info);
31 virtual bool try_music (Music *);
32 virtual void stop_translation_timestep ();
33 virtual void start_translation_timestep ();
34 virtual void create_grobs ();
36 private:
37 Spanner *span_;
38 Spanner *finished_;
39 Span_req *current_req_;
40 Drul_array<Span_req*> req_drul_;
41 void typeset_all ();
44 ADD_THIS_TRANSLATOR (Text_spanner_engraver);
47 Text_spanner_engraver::Text_spanner_engraver ()
49 finished_ = 0;
50 current_req_ = 0;
51 span_ =0;
52 req_drul_[START] = 0;
53 req_drul_[STOP] = 0;
56 void
57 Text_spanner_engraver::start_translation_timestep ()
59 req_drul_[START] = 0;
60 req_drul_[STOP] = 0;
63 bool
64 Text_spanner_engraver::try_music (Music *m)
66 if (Span_req *s = dynamic_cast <Span_req*> (m))
68 String t = ly_scm2string (s->get_mus_property ("span-type"));
69 if (t == "abort")
71 req_drul_[LEFT] = 0;
72 req_drul_[RIGHT] = 0;
73 if (span_)
74 span_->suicide ();
75 span_ = 0;
77 else if (t == "text")
79 req_drul_[s->get_span_dir()] = s;
80 return true;
83 return false;
86 void
87 Text_spanner_engraver::create_grobs ()
89 if (req_drul_[STOP])
91 if (!span_)
93 req_drul_[STOP]->origin ()->warning
94 (_ ("can't find start of text spanner"));
96 else
98 assert (!finished_);
99 Grob* e = unsmob_grob (get_property ("currentMusicalColumn"));
100 span_->set_bound (RIGHT, e);
102 finished_ = span_;
103 span_ = 0;
104 current_req_ = 0;
105 req_drul_[STOP] = 0;
109 if (req_drul_[START])
111 if (current_req_)
113 req_drul_[START]->origin ()->warning
114 (_ ("already have a text spanner"));
116 else
118 current_req_ = req_drul_[START];
119 span_ = new Spanner (get_property ("TextSpanner"));
121 /* Ugh. Reset (de)cresc. specific properties */
122 span_->set_grob_property ("outer", SCM_BOOL_T);
123 span_->set_grob_property ("if-text-padding", gh_double2scm (0));
124 span_->set_grob_property ("width-correct", gh_double2scm (0));
126 Side_position::set_axis (span_, Y_AXIS);
127 Grob *e = unsmob_grob (get_property ("currentMusicalColumn"));
128 span_->set_bound (LEFT, e);
130 announce_grob (span_, req_drul_[START]);
131 req_drul_[START] = 0;
136 void
137 Text_spanner_engraver::acknowledge_grob (Grob_info info)
139 if (span_ && Note_column::has_interface (info.elem_l_))
141 Side_position::add_support (span_, info.elem_l_);
142 add_bound_item (span_, dynamic_cast<Item*> (info.elem_l_));
146 void
147 Text_spanner_engraver::typeset_all ()
149 if (finished_)
151 Side_position::add_staff_support (finished_);
152 typeset_grob (finished_);
153 finished_ = 0;
157 void
158 Text_spanner_engraver::stop_translation_timestep ()
160 typeset_all ();
163 void
164 Text_spanner_engraver::finalize ()
166 typeset_all ();
167 if (span_)
169 current_req_->origin ()->warning (_ ("unterminated text spanner"));
170 span_->suicide ();
171 span_ = 0;