]> git.donarmstrong.com Git - lilypond.git/blob - lily/performance.cc
patch::: 1.1.33.jcn3: silly midi fix
[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 Performance::Performance ()
25 {
26   midi_l_ =0;
27 }
28
29 void
30 Performance::add_column (Audio_column* p)
31 {
32   p->performance_l_ = this;
33   audio_column_p_list_.bottom().add (p);
34 }
35
36 void
37 Performance::output (Midi_stream& midi_stream_r)
38 {
39   int tracks_i = audio_staff_l_list_.size() + 1;
40   // ugh
41   int clocks_per_4_i = 384;
42   midi_stream_r << Midi_header (1, tracks_i, clocks_per_4_i);
43   output_header_track (midi_stream_r);
44   int n = 1;
45   for (PCursor<Audio_staff*> i (audio_staff_l_list_); i.ok(); i++)
46     {
47       /*
48         Aargh, let's hear it for the MIDI standard.
49         MIDI players tend to ignore instrument settings on
50         channel 10, the percussion channel by default.
51        */
52       if (n == 10)
53         n++;
54       i->output (midi_stream_r, n++);
55     }
56 }
57
58 void
59 Performance::output_header_track (Midi_stream& midi_stream_r)
60 {
61   Midi_track midi_track;
62
63   // perhaps multiple text events?
64   String str = String (_("Creator: "));
65   if (no_timestamps_global_b)
66     str += gnu_lilypond_str ();
67   else
68     str += gnu_lilypond_version_str();
69   str += "\n";
70
71   Midi_text creator (Midi_text::TEXT, str);
72   midi_track.add (Moment (0), &creator);
73
74   str = _("Automatically generated");
75   if (no_timestamps_global_b)
76     str += ".\n";
77   else
78     {
79       str += _(", at ");
80       time_t t (time (0));
81       str += ctime (&t);
82       str = str.left_str (str.length_i() - 1);
83     }
84   Midi_text generate (Midi_text::TEXT, str);
85   midi_track.add (Moment (0), &generate);
86
87   str = _f ("from musical definition: %s", origin_str_);
88
89   Midi_text from (Midi_text::TEXT, str);
90   midi_track.add (Moment (0), &from);
91
92   Midi_text track_name (Midi_text::TRACK_NAME, "Track "
93                         + String_convert::i2dec_str (0, 0, '0'));
94   midi_track.add (Moment (0), &track_name);
95
96   Midi_tempo tempo (midi_l_->get_tempo_i (Moment (1, 4)));
97   midi_track.add (Moment (0), &tempo);
98
99   midi_stream_r  << midi_track;
100 }
101
102 void
103 Performance::add_staff (Audio_staff* l)
104 {
105   audio_staff_l_list_.bottom().add (l);
106 }
107
108 void
109 Performance::add_element (Audio_element *p)
110 {
111   audio_elem_p_list_.bottom().add (p);
112 }
113
114 void
115 Performance::print() const
116 {
117 #ifndef NPRINT
118   DOUT << "Performance { ";
119   DOUT << "Items: ";
120   for (PCursor<Audio_element*> i (audio_elem_p_list_.top ()); i.ok (); i++)
121     i->print ();
122
123   DOUT << "\ncolumns: ";
124   for (PCursor<Audio_column*> i (audio_column_p_list_); i.ok(); i++)
125     i->print();
126   DOUT << "}\n";
127 #endif
128 }
129
130 void
131 Performance::process()
132 {
133   print ();
134
135   String out = midi_l_->get_default_output ();
136   if (out.empty_b ())
137     {
138       
139       out = default_outname_base_global;
140       if (out == "-")
141         out = "lelie";
142       int def = midi_l_->get_next_default_count ();
143       if (def)
144         {
145           out += "-" + to_str (def);
146         }
147
148       out += ".midi";
149     }
150   
151   Midi_stream midi_stream (out);
152   *mlog << _f ("MIDI output to %s...", out) << endl;
153   target_str_global_array.push (out);
154
155   output (midi_stream);
156   *mlog << endl;
157 }