]> git.donarmstrong.com Git - lilypond.git/blob - lily/score.cc
release: 0.1.14
[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 "source.hh"
14 #include "source-file.hh"
15 #include "music-iterator.hh"
16 #include "music.hh"
17 #include "global-translator.hh"
18 #include "header.hh"
19 #include "cpu-timer.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   Cpu_timer timer;
50   Global_translator * trans_p = odef_l->get_global_translator_p();
51   if (!trans_p)
52     return ;
53   
54   *mlog << "\nInterpreting music ...";
55   trans_p->last_mom_ = music_p_->time_int().max ();
56
57   Music_iterator * iter = Music_iterator::static_get_iterator_p (music_p_, 
58                                                                  trans_p);
59   iter->construct_children();
60
61   if (! iter->ok()) 
62     {
63       delete iter;
64       warning ("Need music in a score");
65       errorlevel_i_ =1;
66       return ;
67     }
68   
69   trans_p->start();
70   
71   while (iter->ok() || trans_p->moments_left_i ()) 
72     {
73       Moment w = infinity_mom;
74       if (iter->ok()) 
75         {
76           w = iter->next_moment();
77           DOUT << "proccing: " << w <<"\n";
78           iter->print();
79         }
80       trans_p->modify_next (w);
81       trans_p->prepare (w);
82       trans_p->print();
83
84       iter->process_and_next (w);
85       trans_p->process();
86     }
87   delete iter;
88   trans_p->finish();
89
90   
91   if (errorlevel_i_) 
92     {
93       // should we? hampers debugging. 
94       warning ("Errors found, /*not processing score*/");
95     }
96     
97   Music_output * output = trans_p->get_output_p();
98   delete trans_p;
99   *mlog << " (time: " << String(timer.read (), "%.2f") << " seconds)";
100
101   
102   output->header_l_ = header_p_;
103   output->default_out_str_ = default_out_fn;
104   output->origin_str_ =  location_str();
105   
106   *mlog << endl;
107   output->process();
108   delete output ;
109 }
110
111 void
112 Score::process()
113 {
114   if (!music_p_)
115     return;
116
117   print();
118   for (int i=0; i < def_p_arr_.size (); i++)
119     run_translator (def_p_arr_[i]);
120 }
121
122
123
124
125 void
126 Score::print() const
127 {
128 #ifndef NPRINT
129   DOUT << "score {\n"; 
130   music_p_ -> print ();
131   for (int i=0; i < def_p_arr_.size (); i++)
132     def_p_arr_[i]->print();
133   DOUT << "}\n";
134 #endif
135 }
136
137 void
138 Score::add (Music_output_def *pap_p)
139 {
140   def_p_arr_.push(pap_p);
141 }
142
143
144