]> git.donarmstrong.com Git - lilypond.git/blob - lily/midi-stream.cc
Use a `define-builtin-markup-command' macro for builtin markups, which
[lilypond.git] / lily / midi-stream.cc
1 /*
2   midi-stream.cc -- implement Midi_stream
3
4   source file of the GNU LilyPond music typesetter
5
6   (c) 1997--2006 Jan Nieuwenhuizen <janneke@gnu.org>
7 */
8
9 #include "midi-stream.hh"
10
11 #include <cerrno>
12 using namespace std;
13
14 #include "international.hh"
15 #include "main.hh"
16 #include "midi-item.hh"
17 #include "misc.hh"
18 #include "program-option.hh"
19 #include "stream.hh"
20 #include "string-convert.hh"
21 #include "warn.hh"
22
23 Midi_stream::Midi_stream (string file_name)
24 {
25   file_name_string_ = file_name;
26   out_file_ = fopen (file_name.c_str (), "wb");
27   if (!out_file_)
28     error (_f ("can't open for write: %s: %s", file_name, strerror (errno)));
29 }
30
31 Midi_stream::~Midi_stream ()
32 {
33   fclose (out_file_);
34 }
35
36 Midi_stream &
37 Midi_stream::operator << (string str)
38 {
39   size_t sz = sizeof (Byte);
40   size_t n = str.length ();
41   size_t written = fwrite (str.data (), sz, n, out_file_);
42
43   if (written != sz * n)
44     warning (_ ("can't write to file: `%s'"));
45
46   return *this;
47 }
48
49 Midi_stream &
50 Midi_stream::operator << (Midi_item const &midi_c_r)
51 {
52   string str = midi_c_r.to_string ();
53
54   // ugh, should have separate debugging output with Midi*::print routines
55   if (do_midi_debugging_global)
56     {
57       str = String_convert::bin2hex (str) + "\n";
58       for (ssize i = str.find ("0a"); i != NPOS; i = str.find ("0a"))
59         {
60           str[i] = '\n';
61           str[i + 1] = '\t';
62         }
63     }
64
65   return operator << (str);
66 }
67
68 Midi_stream &
69 Midi_stream::operator << (int i)
70 {
71   // output binary string ourselves
72   *this << Midi_item::i2varint_string (i);
73   return *this;
74 }
75