lilypond-1.3.67
[lilypond.git] / lily / score.cc
blobb9027e9288c6ecff777a30c9b9f05412f5bf1b75
1 /*
2 score.cc -- implement Score
4 source file of the GNU LilyPond music typesetter
6 (c) 1997--2000 Han-Wen Nienhuys <hanwen@cs.uu.nl>
7 */
9 #include <iostream.h>
11 #include "score.hh"
12 #include "debug.hh"
13 #include "music-output-def.hh"
14 #include "music-output.hh"
15 #include "source.hh"
16 #include "source-file.hh"
17 #include "music-iterator.hh"
18 #include "music.hh"
19 #include "global-translator.hh"
20 #include "scope.hh"
21 #include "cpu-timer.hh"
22 #include "main.hh"
23 #include "paper-def.hh"
27 TODO: junkme.
30 Score::Score()
31 : Input()
33 header_p_ = 0;
34 music_p_ = 0;
35 errorlevel_i_ = 0;
38 Score::Score (Score const &s)
39 : Input (s)
41 music_p_ = (s.music_p_) ? s.music_p_->clone() : 0;
42 for (int i=0; i < s.def_p_arr_.size (); i++)
43 def_p_arr_.push(s.def_p_arr_[i]->clone());
44 errorlevel_i_ = s.errorlevel_i_;
45 header_p_ = (s.header_p_) ? new Scope (*s.header_p_): 0;
48 Score::~Score()
50 delete header_p_;
51 junk_pointer_array (def_p_arr_);
52 delete music_p_;
55 void
56 Score::run_translator (Music_output_def *odef_l)
58 Cpu_timer timer;
61 Global_translator * trans_p = odef_l->get_global_translator_p();
62 if (!trans_p)
64 non_fatal_error (_("no toplevel translator"));
65 return ;
67 progress_indication ("\n" + _("Interpreting music..."));
68 trans_p->final_mom_ = music_p_->length_mom ();
71 Music_iterator * iter = Music_iterator::static_get_iterator_p (music_p_);
72 iter->init_translator(music_p_, trans_p);
74 iter->construct_children();
76 if (! iter->ok())
78 delete iter;
79 warning (_("Need music in a score"));
80 errorlevel_i_ =1;
81 return ;
84 trans_p->start ();
85 trans_p->run_iterator_on_me (iter);
86 delete iter;
87 trans_p->finish ();
89 if (errorlevel_i_)
91 // should we? hampers debugging.
92 warning (_ ("Errors found/*, not processing score*/"));
95 Music_output * output = trans_p->get_output_p();
96 delete trans_p;
97 if(verbose_global_b)
98 progress_indication (_f ("elapsed time: %.2f seconds", timer.read ()));
100 output->header_l_ = header_p_;
101 output->origin_str_ = location_str();
103 progress_indication ("\n");
104 output->process();
105 delete output ;
108 force GC. At this point, GUILE may give back mallocated area to
109 the system.
112 scm_gc();
115 void
116 Score::process()
118 if (!music_p_)
119 return;
121 print();
122 for (int i=0; i < def_p_arr_.size (); i++)
124 if (no_paper_global_b
125 && dynamic_cast<Paper_def*>(def_p_arr_[i]))
126 continue;
127 run_translator (def_p_arr_[i]);
133 void
134 Score::print() const
136 #ifndef NPRINT
137 DEBUG_OUT << "score {\n";
138 music_p_ -> print ();
139 for (int i=0; i < def_p_arr_.size (); i++)
140 def_p_arr_[i]->print();
141 DEBUG_OUT << "}\n";
142 #endif
145 void
146 Score::add_output (Music_output_def *pap_p)
148 def_p_arr_.push(pap_p);