2 staff-side.cc -- implement Staff_side
4 source file of the GNU LilyPond music typesetter
6 (c) 1997 Han-Wen Nienhuys <hanwen@stack.nl>
9 #include "paper-def.hh"
11 #include "staff-side.hh"
12 #include "staff-sym.hh"
16 Staff_side::set_staffsym(Staff_symbol* s_l)
21 Staff_side::Staff_side()
26 inside_staff_b_ =false;
30 Staff_side::read_staff_sym()
34 staff_size_i_ = staff_sym_l_->steps_i();
39 Staff_side::support_height() const
43 for (int i=0; i < support_l_arr_.size(); i++)
44 r.unite(support_l_arr_[i]->height());
52 Staff_side::add_support(Score_elem*i)
54 support_l_arr_.push(i);
59 Staff_side::get_position_i()const
62 warning("Staff_side::get_position_i(): "
63 "somebody forgot to set my vertical direction, returning -20");
69 Real inter_f = paper()-> internote_f();
70 if (!inside_staff_b_) {
71 y = (dir_i_ > 0 && staff_sym_l_) ? staff_sym_l_->steps_i() + 2: -2;
73 Interval v= support_height();
76 y = y >? (v.max() + 2*inter_f);
77 } else if (dir_i_ < 0) {
78 y = y <? (v.min() - 2*inter_f);
81 Interval v= support_height();
82 y = v[dir_i_] + 2*dir_i_*inter_f; // ugh
84 return int(rint(Real(y)/inter_f)); // should ret a float?
88 Staff_side::get_position_i(Interval sym_dim) const
90 int i= get_position_i();
91 return i+ int(rint(- sym_dim[-dir_i_] / paper()->internote_f()));
96 Staff_side::do_substitute_dependency(Score_elem*o, Score_elem*n )
99 while ((i=support_l_arr_.find_i(o) ) >=0)
101 support_l_arr_[i] = n;
103 support_l_arr_.del(i);
105 if (staff_sym_l_ == o)
106 staff_sym_l_ = n ? (Staff_symbol*) n->spanner():0;