]> git.donarmstrong.com Git - lilypond.git/blob - lily/span-bar-engraver.cc
a4e19592d0a468007f8db55ac7cf50c422a29aa5
[lilypond.git] / lily / span-bar-engraver.cc
1 /*
2   span-bar-grav.cc -- implement Span_bar_engraver
3
4   source file of the GNU LilyPond music typesetter
5
6   (c)  1997--2001 Han-Wen Nienhuys <hanwen@cs.uu.nl>
7 */
8
9
10 #include "lily-guile.hh"
11 #include "bar.hh"
12 #include "item.hh"
13 #include "span-bar.hh"
14 #include "engraver.hh"
15
16
17 /** 
18
19   Make bars that span multiple "staffs". Catch bars, and span a
20   Span_bar over them if we find more than 2 bars.  Vertical alignment
21   of staffs changes the appearance of spanbars.  It is up to the
22   aligner (Vertical_align_engraver, in this case, to add extra
23   dependencies to the spanbars.
24
25   */
26 class Span_bar_engraver : public Engraver
27 {
28   Item * spanbar_p_;
29   Link_array<Item> bar_l_arr_;
30
31 public:
32   VIRTUAL_COPY_CONS (Translator);
33   Span_bar_engraver ();
34 protected:
35   virtual void acknowledge_grob (Grob_info);
36   virtual void stop_translation_timestep ();
37
38 };
39
40
41 Span_bar_engraver::Span_bar_engraver ()
42 {
43   spanbar_p_ =0;
44 }
45
46
47
48 void
49 Span_bar_engraver::acknowledge_grob (Grob_info i)
50 {
51   int depth = i.origin_trans_l_arr (this).size ();
52   if (depth > 1
53       && Bar::has_interface (i.elem_l_))
54     {
55       Item * it = dynamic_cast<Item*> (i.elem_l_);
56       bar_l_arr_.push (it);
57
58       if (bar_l_arr_.size () >= 2 && !spanbar_p_) 
59         {
60           spanbar_p_ = new Item (get_property ("SpanBar"));
61           Span_bar::set_interface (spanbar_p_);
62                 
63           spanbar_p_->set_parent (bar_l_arr_[0], Y_AXIS);
64           spanbar_p_->set_parent (bar_l_arr_[0], X_AXIS);
65
66           announce_grob (spanbar_p_,0);
67         }
68     }
69 }
70 void
71 Span_bar_engraver::stop_translation_timestep ()
72 {
73   if (spanbar_p_) 
74     {
75       for (int i=0; i < bar_l_arr_.size () ; i++)
76         Span_bar::add_bar (spanbar_p_,bar_l_arr_[i]);
77
78       SCM vissym =ly_symbol2scm ("visibility-lambda");
79       SCM vis = bar_l_arr_[0]->get_grob_property (vissym);        
80       if (scm_equal_p (spanbar_p_->get_grob_property (vissym), vis) != SCM_BOOL_T)
81         spanbar_p_->set_grob_property (vissym, vis);
82
83       typeset_grob (spanbar_p_);
84       spanbar_p_ =0;
85     }
86   bar_l_arr_.set_size (0);
87 }
88
89
90
91 ADD_THIS_TRANSLATOR (Span_bar_engraver);
92
93
94