X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fmidi-stream.cc;h=0d30c41a95b33e907052da2c9951417072acf03b;hb=30a3f4df5e028bcf2bcabd29c23dda61f6057592;hp=afce7e3b5402ff426b22efa3c4ce3eddacebe5ab;hpb=91ad96d55a9848ab482d0946987aaa68af76d357;p=lilypond.git diff --git a/lily/midi-stream.cc b/lily/midi-stream.cc index afce7e3b54..0d30c41a95 100644 --- a/lily/midi-stream.cc +++ b/lily/midi-stream.cc @@ -3,7 +3,7 @@ source file of the GNU LilyPond music typesetter - (c) 1997--2002 Jan Nieuwenhuizen + (c) 1997--2003 Jan Nieuwenhuizen */ @@ -14,62 +14,58 @@ #include "misc.hh" #include "midi-item.hh" #include "midi-stream.hh" -#include "debug.hh" +#include "warn.hh" #include "scm-option.hh" Midi_stream::Midi_stream (String filename) { - filename_str_ = filename; - os_p_ = open_file_stream (filename, std::ios::out|std::ios::binary); + filename_string_ = filename; + out_file_ = fopen (filename.to_str0(), "wb"); } Midi_stream::~Midi_stream () { - close_file_stream (os_p_); + fclose (out_file_); } Midi_stream& Midi_stream::operator << (String str) { - Byte * b = str.byte_l(); - for (int sz = str.length_i (); sz--;) - *os_p_ << *b ++; + size_t sz = sizeof (Byte); + size_t n = str.length (); + size_t written = fwrite (str.get_bytes (), + sz, n, out_file_); + + if (written != sz * n) + warning (_ ("Could not write file. Disk full?")); + return *this; } Midi_stream& Midi_stream::operator << (Midi_item const& midi_c_r) { - String str = midi_c_r.str (); - + String str = midi_c_r.to_string (); + // ugh, should have separate debugging output with Midi*::print routines if (midi_debug_global_b) { - str = String_convert::bin2hex_str (str) + "\n"; - // ugh, should have separate debugging output with Midi*::print routines - int i = str.index_i ("0a"); - while (i >= 0) - { - str[i] = '\n'; - str[i + 1] = '\t'; - i = str.index_i ("0a"); - } + str = String_convert::bin2hex (str) + "\n"; + for (int i = str.index ("0a"); i >= 0; i = str.index ("0a")) + { + str[i] = '\n'; + str[i + 1] = '\t'; + } } - else - { - Byte * b = str.byte_l(); - for (int sz = str.length_i (); sz--;) - *os_p_ << *b++; - } - - return *this; + + return operator << (str); } Midi_stream& Midi_stream::operator << (int i) { // output binary string ourselves - *this << Midi_item::i2varint_str (i); + *this << Midi_item::i2varint_string (i); return *this; }