]> git.donarmstrong.com Git - lilypond.git/blob - lily/performance.cc
release: 1.1.34
[lilypond.git] / lily / performance.cc
1 /*
2   performance.cc -- implement Performance
3
4   source file of the GNU LilyPond music typesetter
5
6   (c)  1997--1999 Jan Nieuwenhuizen <janneke@gnu.org>
7 */
8
9 #include <time.h>
10 #include "debug.hh"
11 #include "string.hh"
12 #include "string-convert.hh"
13 #include "main.hh"
14 #include "midi-def.hh"
15 #include "midi-item.hh"
16 #include "midi-stream.hh"
17 #include "audio-column.hh"
18 #include "audio-staff.hh"
19 #include "performance.hh"
20 #include "score.hh"
21 #include "file-results.hh"
22 #include "lily-version.hh"
23
24 #include "killing-cons.tcc"
25
26 Performance::Performance ()
27 {
28   midi_l_ =0;
29   audio_elem_p_list_ = 0;
30 }
31
32 void
33 Performance::add_column (Audio_column* p)
34 {
35   p->performance_l_ = this;
36   add_element (p);
37 }
38
39 Performance::~Performance()
40 {
41   delete audio_elem_p_list_;
42 }
43
44 void
45 Performance::output (Midi_stream& midi_stream)
46 {
47   int tracks_i = audio_staff_l_arr_.size() + 1;
48
49   // ugh
50   int clocks_per_4_i = 384;
51
52   midi_stream << Midi_header (1, tracks_i, clocks_per_4_i);
53   output_header_track (midi_stream);
54   int n = 1;
55   for (int i =0; i < audio_staff_l_arr_.size (); i++)
56     {
57       Audio_staff *s = audio_staff_l_arr_[i];
58       /*
59         Aargh, let's hear it for the MIDI standard.
60         MIDI players tend to ignore instrument settings on
61         channel 10, the percussion channel by default.
62        */
63       if (n == 10)
64         n++;
65       s->output (midi_stream, n++);
66     }
67 }
68
69 void
70 Performance::output_header_track (Midi_stream& midi_stream)
71 {
72   Midi_track midi_track;
73
74   // perhaps multiple text events?
75   String str = String (_("Creator: "));
76   if (no_timestamps_global_b)
77     str += gnu_lilypond_str ();
78   else
79     str += gnu_lilypond_version_str();
80   str += "\n";
81
82   Midi_text creator (Midi_text::TEXT, str);
83   midi_track.add (Moment (0), &creator);
84
85   str = _("Automatically generated");
86   if (no_timestamps_global_b)
87     str += ".\n";
88   else
89     {
90       str += _(", at ");
91       time_t t (time (0));
92       str += ctime (&t);
93       str = str.left_str (str.length_i() - 1);
94     }
95   Midi_text generate (Midi_text::TEXT, str);
96   midi_track.add (Moment (0), &generate);
97
98   str = _f ("from musical definition: %s", origin_str_);
99
100   Midi_text from (Midi_text::TEXT, str);
101   midi_track.add (Moment (0), &from);
102
103   Midi_text track_name (Midi_text::TRACK_NAME, "Track "
104                         + String_convert::i2dec_str (0, 0, '0'));
105   midi_track.add (Moment (0), &track_name);
106
107   Midi_tempo tempo (midi_l_->get_tempo_i (Moment (1, 4)));
108   midi_track.add (Moment (0), &tempo);
109
110   midi_stream << midi_track;
111 }
112
113 void
114 Performance::add_staff (Audio_staff* l)
115 {
116   audio_staff_l_arr_.push (l);
117 }
118
119 void
120 Performance::add_element (Audio_element *p)
121 {
122   audio_elem_p_list_ = new Killing_cons<Audio_element> (p, audio_elem_p_list_);
123 }
124
125 void
126 Performance::print() const
127 {
128 #ifndef NPRINT
129   DOUT << "Performance { ";
130   DOUT << "Items: ";
131   for (Cons<Audio_element>* i =audio_elem_p_list_; i; i = i->next_)
132     i->car_->print ();
133   DOUT << "}";
134 #endif
135 }
136
137 void
138 Performance::process()
139 {
140   print ();
141
142   String out = midi_l_->get_default_output ();
143   if (out.empty_b ())
144     {
145       
146       out = default_outname_base_global;
147       if (out == "-")
148         out = "lelie";
149       int def = midi_l_->get_next_default_count ();
150       if (def)
151         {
152           out += "-" + to_str (def);
153         }
154
155       out += ".midi";
156     }
157   
158   Midi_stream midi_stream (out);
159   *mlog << _f ("MIDI output to %s...", out) << endl;
160   target_str_global_array.push (out);
161
162   output (midi_stream);
163   *mlog << endl;
164 }