]> git.donarmstrong.com Git - lilypond.git/blob - lily/clef-grav.cc
release: 0.0.77.jcn1
[lilypond.git] / lily / clef-grav.cc
1 /*
2   clef.cc -- implement  Clef_engraver
3
4   source file of the GNU LilyPond music typesetter
5
6   (c) 1997 Han-Wen Nienhuys <hanwen@stack.nl>,
7   Mats Bengtsson <matsb@s3.kth.se>
8 */
9
10 #include "bar.hh"
11 #include "clef-grav.hh"
12 #include "clef-item.hh"
13 #include "debug.hh"
14 #include "command-request.hh"
15 #include "time-description.hh"
16
17 Clef_engraver::Clef_engraver()
18 {
19     clef_p_ = 0;
20     clef_req_l_ =0;
21     
22     set_type("violin");
23 }
24
25 bool
26 Clef_engraver::set_type(String s)
27 {
28     clef_type_str_  = s;
29     if (clef_type_str_ == "violin") {
30         c0_position_i_= -2;
31     } else if (clef_type_str_ == "alto") {
32         c0_position_i_= 4;
33     } else if (clef_type_str_ == "tenor") {
34         c0_position_i_= 6;
35     } else if (clef_type_str_ == "bass") {
36         c0_position_i_= 10;
37     } else 
38         return false;
39     
40     return true;
41 }
42
43 void
44 Clef_engraver::fill_staff_info(Staff_info &i)
45 {
46     i.c0_position_i_l_ = &c0_position_i_;
47 }
48
49 void 
50 Clef_engraver::read_req(Clef_change_req*c_l)
51 {
52     if (!set_type(c_l->clef_str_))
53         c_l->error("unknown clef type ");
54 }
55 void
56 Clef_engraver::acknowledge_element(Score_elem_info info)
57 {
58     if (info.elem_l_->name() == Bar::static_name() ) {
59         create_clef();
60         if ( !clef_req_l_ )
61             clef_p_->default_b_ = true;
62     }
63 }
64
65 void
66 Clef_engraver::do_creation_processing()
67 {
68     create_clef();
69     clef_p_->default_b_ = false;
70 }
71
72 bool
73 Clef_engraver::do_try_request(Request * r_l)
74 {
75     Command_req* creq_l= r_l->command();
76     if (!creq_l || !creq_l->clefchange())
77         return false;
78
79     clef_req_l_ = creq_l->clefchange();
80     
81     read_req(clef_req_l_); 
82     return true;
83 }
84
85 void 
86 Clef_engraver::create_clef()
87 {
88     if (!clef_p_) {
89         clef_p_ = new Clef_item;
90         announce_element(Score_elem_info(clef_p_,clef_req_l_));
91     }
92     clef_p_->read(*this);
93 }
94
95 void
96 Clef_engraver::do_process_requests()
97 {
98     if (clef_req_l_) {
99         create_clef();
100         clef_p_->default_b_ = false;
101     }
102 }
103
104 void
105 Clef_engraver::do_pre_move_processing()
106 {
107     if (!clef_p_)
108         return;
109     typeset_breakable_item(clef_p_);
110     clef_p_ = 0;
111 }
112     
113 void
114 Clef_engraver::do_post_move_processing()
115 {
116     clef_req_l_ = 0;
117 }
118
119 void
120 Clef_engraver::do_removal_processing()
121 {
122     delete clef_p_;
123     clef_p_ =0;
124 }
125
126
127 IMPLEMENT_IS_TYPE_B1(Clef_engraver,Engraver);
128 ADD_THIS_ENGRAVER(Clef_engraver);