]> git.donarmstrong.com Git - lilypond.git/blob - lily/score.cc
729df8e0205bcbb6a680a304fed78f520becf41f
[lilypond.git] / lily / score.cc
1 /*
2   score.cc -- implement Score
3
4   source file of the GNU LilyPond music typesetter
5
6   (c) 1997 Han-Wen Nienhuys <hanwen@stack.nl>
7 */
8
9 #include "tex-stream.hh"
10 #include "score.hh"
11 #include "score-column.hh"
12 #include "p-score.hh"
13 #include "debug.hh"
14 #include "paper-def.hh"
15 #include "main.hh"
16 #include "source.hh"
17 #include "source-file.hh"
18 #include "midi-output.hh"
19 #include "midi-def.hh"
20 #include "audio-score.hh"
21 #include "p-col.hh"
22 #include "music-iterator.hh"
23 #include "music.hh"
24 #include "global-translator.hh"
25
26 extern String default_out_fn;
27
28 Score::Score()
29 {
30     pscore_p_=0;
31     audio_score_p_ = 0;
32     paper_p_ = 0;
33     midi_p_ = 0;
34     errorlevel_i_ = 0;
35 }
36
37 Score::Score(Score const &s)
38 {
39     assert(!pscore_p_);
40     music_p_ = s.music_p_->clone();
41     midi_p_ = new Midi_def(*s.midi_p_);
42     paper_p_ = new Paper_def(*s.paper_p_);
43 }
44
45 Score::~Score()
46 {
47     delete music_p_;
48     delete pscore_p_;
49     delete audio_score_p_;
50     delete paper_p_;
51     delete midi_p_;
52 }
53
54 void
55 Score::run_translator(Global_translator * trans_l)
56 {
57     trans_l->set_score (this);
58     Music_iterator * iter = Music_iterator::static_get_iterator_p(music_p_, 
59                                                                   trans_l);
60     iter->construct_children();
61
62     trans_l->start();
63     while ( iter->ok() || trans_l->moments_left_i() ) {
64         Moment w = infinity_mom;
65         if (iter->ok() ) {
66             w = iter->next_moment();
67             iter->print();
68         }
69         trans_l->modify_next( w );
70         trans_l->prepare(w);
71         trans_l->print();
72
73         iter->process_and_next( w );
74         trans_l->process();
75     }
76     delete iter;
77     trans_l->finish();
78 }
79
80 void
81 Score::process()
82 {
83     print();
84     paper();
85     midi();
86 }
87
88 void
89 Score::midi()
90 {
91     if ( !midi_p_ )
92         return;
93     
94     *mlog << "\nCreating MIDI elements ..." << flush;
95     audio_score_p_ = new Audio_score( midi_p_ );
96     
97     Global_translator* score_trans=  midi_p_->get_global_translator_p();
98     run_translator( score_trans );
99     delete score_trans;
100     
101     if( errorlevel_i_){
102         // should we? hampers debugging. 
103         warning( "Errors found, /*not processing score*/" );
104 //      return;
105     }
106     *mlog << endl;
107 }
108     
109 void
110 Score::paper()
111 {
112     if (!paper_p_)
113         return;
114     
115     *mlog << "\nCreating elements ..." << flush;
116     pscore_p_ = new PScore(paper_p_);
117     
118     Global_translator * score_trans=  paper_p_->get_global_translator_p();
119     run_translator( score_trans );
120     delete score_trans;
121     
122     if( errorlevel_i_) {
123         // should we? hampers debugging. 
124         warning("Errors found, /*not processing score*/");
125 //      return;
126     }
127     
128     // debugging
129     *mlog << endl;
130     pscore_p_->process();
131
132     // output
133     paper_output();
134 }
135
136
137 void
138 Score::set(Paper_def *pap_p)
139 {
140     delete paper_p_;
141     paper_p_ = pap_p;
142 }
143
144 void
145 Score::set(Midi_def* midi_p)
146 {    
147     delete midi_p_;
148     midi_p_ = midi_p;
149 }
150
151
152
153 void
154 Score::print() const
155 {
156 #ifndef NPRINT
157     mtor << "score {\n"; 
158     music_p_->print();
159     if (midi_p_)
160         midi_p_->print();
161     
162     mtor << "}\n";
163 #endif
164 }
165
166 void
167 Score::paper_output()
168 {
169     if (paper_p_->outfile_str_=="")
170         paper_p_->outfile_str_ = default_out_fn + ".out";
171
172     if ( errorlevel_i_ ) { 
173         *mlog << "lilypond: warning: no output to: " << paper_p_->outfile_str_ 
174         << " (errorlevel=" << errorlevel_i_ << ")" << endl;
175         return;
176     }
177
178     *mlog << "TeX output to " << paper_p_->outfile_str_ << " ...\n";
179     
180     Tex_stream the_output(paper_p_->outfile_str_);
181     
182     the_output << "% outputting Score, defined at: " <<
183         location_str() << "\n";
184     pscore_p_->output(the_output);
185     
186 }
187
188 void
189 Score::midi_output()
190 {
191 #if 0
192     if (!midi_p_)
193         return;
194
195     if (midi_p_->outfile_str_ == "")
196         midi_p_->outfile_str_ = default_out_fn + ".midi";
197     
198     *mlog << "midi output to " << midi_p_->outfile_str_ << " ...\n";    
199     Midi_output(this, midi_p_);
200 #endif
201 }
202