]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/midi-stream.cc
Run `make grand-replace'.
[lilypond.git] / lily / midi-stream.cc
index 1bd6b7ddb3acffda2212ebadf0ad1a51af8daebb..4c1aa564235ccc4365ea751949d0414353e015fd 100644 (file)
@@ -3,24 +3,29 @@
 
   source file of the GNU LilyPond music typesetter
 
-  (c)  1997--2003 Jan Nieuwenhuizen <janneke@gnu.org>
+  (c) 1997--2008 Jan Nieuwenhuizen <janneke@gnu.org>
 */
 
+#include "midi-stream.hh"
 
-#include "stream.hh"
-#include "string.hh"
-#include "string-convert.hh"
+#include <cerrno>
+using namespace std;
+
+#include "international.hh"
 #include "main.hh"
+#include "midi-chunk.hh"
 #include "misc.hh"
-#include "midi-item.hh"
-#include "midi-stream.hh"
+#include "program-option.hh"
+#include "stream.hh"
+#include "string-convert.hh"
 #include "warn.hh"
-#include "scm-option.hh"
 
-Midi_stream::Midi_stream (String filename)
+Midi_stream::Midi_stream (string file_name)
 {
-  filename_string_ = filename;
-  out_file_ = fopen (filename.to_str0(), "wb");
+  file_name_string_ = file_name;
+  out_file_ = fopen (file_name.c_str (), "wb");
+  if (!out_file_)
+    error (_f ("cannot open for write: %s: %s", file_name, strerror (errno)));
 }
 
 Midi_stream::~Midi_stream ()
@@ -28,54 +33,22 @@ Midi_stream::~Midi_stream ()
   fclose (out_file_);
 }
 
-Midi_stream&
-Midi_stream::operator << (String str)
-{
-  Byte * b = str.get_bytes ();
-  for (int sz = str.length (); sz--;)
-    {
-      fputc (*b, out_file_);
-      b++;
-    }
-  return *this;
-}
-
-Midi_stream&
-Midi_stream::operator << (Midi_item const& midi_c_r)
+void
+Midi_stream::write (string str)
 {
-  String str = midi_c_r.string ();
-
+  size_t sz = sizeof (Byte);
+  size_t n = str.length ();
+  size_t written = fwrite (str.data (), sz, n, out_file_);
 
-  if (midi_debug_global_b)
-    {
-     str = String_convert::bin2hex (str) + "\n";
-    // ugh, should have separate debugging output with Midi*::print routines
-    int i = str.index ("0a");
-    while (i >= 0)
-      {
-        str[i] = '\n';
-        str[i + 1] = '\t';
-       i = str.index ("0a");
-      }
-    }
-  else
-    {
-      Byte * b = str.get_bytes ();
-      for (int sz = str.length (); sz--;)
-       {
-         fputc (*b, out_file_);
-         b++;
-       }
-    }
-  
-  return *this;
+  if (written != sz * n)
+    warning (_f ("cannot write to file: `%s'", str.data ()));
 }
 
-Midi_stream&
-Midi_stream::operator << (int i)
+void
+Midi_stream::write (Midi_chunk const &midi)
 {
-  // output binary string ourselves
-  *this << Midi_item::i2varint_string (i);
-  return *this;
+  string str = midi.to_string ();
+
+  return write (str);
 }