]> git.donarmstrong.com Git - lilypond.git/blob - lily/bar-engraver.cc
release: 1.0.8
[lilypond.git] / lily / bar-engraver.cc
1 /*
2   bar-reg.cc -- implement Bar_engraver
3
4   source file of the GNU LilyPond music typesetter
5
6   (c)  1997--1998 Han-Wen Nienhuys <hanwen@cs.uu.nl>
7 */
8
9 #include "bar-engraver.hh"
10 #include "bar.hh"
11 #include "musical-request.hh"
12 #include "multi-measure-rest.hh"
13 #include "command-request.hh"
14 #include "time-description.hh"
15 #include "engraver-group.hh"
16
17 Bar_engraver::Bar_engraver()
18 {
19   bar_p_ =0;
20   do_post_move_processing();
21 }
22
23 bool
24 Bar_engraver::do_try_request (Request*r_l)
25 {
26   Command_req* c_l = r_l->access_Command_req ();
27   if (!c_l|| !c_l->access_Bar_req ()) 
28     return false;
29   Bar_req  * b= c_l->access_Bar_req ();
30   if (bar_req_l_ && bar_req_l_->equal_b (b))
31     return false;
32   
33   bar_req_l_ = b;
34
35   return true;
36 }
37
38 void
39 Bar_engraver::create_bar ()
40 {
41   if (!bar_p_)
42     {
43       bar_p_ = new Bar;
44       bar_p_->break_priority_i_  = 0;
45       String default_type = get_property ("defaultBarType");
46       if (default_type.length_i ())
47         {
48           bar_p_->type_str_ = default_type;
49         }
50       announce_element (Score_element_info (bar_p_, bar_req_l_));
51     }
52 }
53
54
55 void 
56 Bar_engraver::do_creation_processing ()
57 {
58   create_bar ();
59   bar_p_->type_str_ = "";
60 }
61
62 void
63 Bar_engraver::do_removal_processing ()
64 {
65   if (bar_p_) 
66     {
67       typeset_element (bar_p_);
68       bar_p_ =0;
69     }
70 }
71
72 void
73 Bar_engraver::do_process_requests()
74 {  
75   if (bar_req_l_) 
76     {
77       if (!bar_p_)
78         create_bar ();    
79
80       bar_p_->type_str_ = bar_req_l_->type_str_;
81     }
82   else 
83     {
84       Time_description const *time = get_staff_info().time_C_;
85       String always = get_property ("barAlways");
86       if ((time && !time->whole_in_measure_) || always.length_i ()) 
87         create_bar ();
88     }
89
90   
91   
92   if (!bar_p_)
93     {
94       Break_req r;
95       r.penalty_i_ = Break_req::DISALLOW;
96       daddy_grav_l ()->try_request (&r);
97     }
98 }
99
100
101 void 
102 Bar_engraver::do_pre_move_processing()
103 {
104   if (bar_p_) 
105     {
106       typeset_element (bar_p_);
107       bar_p_ =0;
108     }
109 }
110
111 void
112 Bar_engraver::do_post_move_processing()
113 {
114   bar_req_l_ = 0;
115 }
116
117
118 IMPLEMENT_IS_TYPE_B1(Bar_engraver,Engraver);
119 ADD_THIS_TRANSLATOR(Bar_engraver);
120
121