]> git.donarmstrong.com Git - lilypond.git/blob - lily/score.cc
release: 0.1.11
[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 "score.hh"
10 #include "debug.hh"
11 #include "music-output-def.hh"
12 #include "music-output.hh"
13 #include "main.hh"
14 #include "source.hh"
15 #include "source-file.hh"
16 #include "music-iterator.hh"
17 #include "music.hh"
18 #include "global-translator.hh"
19 #include "header.hh"
20
21 extern String default_out_fn;
22
23 Score::Score()
24 {
25   header_p_ = 0;
26   music_p_ = 0;
27   errorlevel_i_ = 0;
28 }
29
30 Score::Score (Score const &s)
31 {
32   music_p_ = s.music_p_->clone();
33   for (int i=0; i < s.def_p_arr_.size (); i++)
34     def_p_arr_.push(s.def_p_arr_[i]->clone());
35   header_p_ = new Header (*s.header_p_);
36 }
37
38 Score::~Score()
39 {
40   delete header_p_;
41   for (int i=0; i < def_p_arr_.size (); i++)
42     delete def_p_arr_[i];
43   delete music_p_;
44 }
45
46 void
47 Score::run_translator (Music_output_def *odef_l)
48 {
49   Global_translator * trans_p = odef_l->get_global_translator_p();
50   if (!trans_p)
51     return ;
52   
53   *mlog << "\nInterpreting music ...";
54   trans_p->last_mom_ = music_p_->time_int().max ();
55
56   Music_iterator * iter = Music_iterator::static_get_iterator_p (music_p_, 
57                                                                  trans_p);
58   iter->construct_children();
59
60   if (! iter->ok()) 
61     {
62       delete iter;
63       warning ("Need music in a score");
64       errorlevel_i_ =1;
65       return ;
66     }
67   
68   trans_p->start();
69   
70   while (iter->ok() || trans_p->moments_left_i ()) 
71     {
72       Moment w = infinity_mom;
73       if (iter->ok()) 
74         {
75           w = iter->next_moment();
76           DOUT << "proccing: " << w <<"\n";
77           iter->print();
78         }
79       trans_p->modify_next (w);
80       trans_p->prepare (w);
81       trans_p->print();
82
83       iter->process_and_next (w);
84       trans_p->process();
85     }
86   delete iter;
87   trans_p->finish();
88
89   
90   if (errorlevel_i_) 
91     {
92       // should we? hampers debugging. 
93       warning ("Errors found, /*not processing score*/");
94     }
95     
96   Music_output * output = trans_p->get_output_p();
97   delete trans_p;
98
99   output->header_l_ = header_p_;
100   output->default_out_str_ = default_out_fn;
101   output->origin_str_ =  location_str();
102   
103   *mlog << endl;
104   output->process();
105   delete output ;
106 }
107
108 void
109 Score::process()
110 {
111   if (!music_p_)
112     return;
113
114   print();
115   for (int i=0; i < def_p_arr_.size (); i++)
116     run_translator (def_p_arr_[i]);
117 }
118
119
120
121
122 void
123 Score::print() const
124 {
125 #ifndef NPRINT
126   DOUT << "score {\n"; 
127   for (int i=0; i < def_p_arr_.size (); i++)
128     def_p_arr_[i]->print();
129   DOUT << "}\n";
130 #endif
131 }
132
133 void
134 Score::add (Music_output_def *pap_p)
135 {
136   def_p_arr_.push(pap_p);
137 }
138
139
140