]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/midi-item.cc
``slikken kreng''
[lilypond.git] / lily / midi-item.cc
index 22176a87aabe21785066420f73b38ae979983ce0..f13edbbd0a905ef2a331d67a480230cedd811d85 100644 (file)
 #include "killing-cons.tcc"
 
 Midi_item*
-Midi_item::midi_p (Audio_item* a)
+Midi_item::get_midi (Audio_item* a)
 {
   if (Audio_key* i = dynamic_cast<Audio_key*> (a))
     return new Midi_key (i);
   else if (Audio_instrument* i = dynamic_cast<Audio_instrument*> (a))
-    return i->str_.length_i () ? new Midi_instrument (i) : 0;
+    return i->str_.length () ? new Midi_instrument (i) : 0;
   else if (Audio_note* i = dynamic_cast<Audio_note*> (a))
     return new Midi_note (i);
   else if (Audio_dynamic* i = dynamic_cast<Audio_dynamic*> (a))
@@ -37,7 +37,7 @@ Midi_item::midi_p (Audio_item* a)
   else if (Audio_time_signature* i = dynamic_cast<Audio_time_signature*> (a))
     return new Midi_time_signature (i);
   else if (Audio_text* i = dynamic_cast<Audio_text*> (a))
-    //return i->text_str_.length_i () ? new Midi_text (i) : 0;
+    //return i->text_string_.length () ? new Midi_text (i) : 0;
     return new Midi_text (i);
   else
     assert (0);
@@ -47,64 +47,64 @@ Midi_item::midi_p (Audio_item* a)
 }
 
 void
-Midi_chunk::set (String header_str, String data_str, String footer_str)
+Midi_chunk::set (String header_string, String data_string, String footer_string)
 {
-  data_str_ = data_str;
-  footer_str_ = footer_str;
-  header_str_ = header_str;
+  data_string_ = data_string;
+  footer_string_ = footer_string;
+  header_string_ = header_string;
 }
   
 String
-Midi_chunk::data_str () const
+Midi_chunk::data_string () const
 {
-  return data_str_;
+  return data_string_;
 }
 
 String
-Midi_chunk::str () const
-{
-  String str = header_str_;
-  String dat = data_str ();
-  String length_str = String_convert::i2hex_str (dat.length_i () 
-    + footer_str_.length_i (), 8, '0');
-  length_str = String_convert::hex2bin_str (length_str);
-  str += length_str;
+Midi_chunk::string () const
+{
+  String str = header_string_;
+  String dat = data_string ();
+  String length_string = String_convert::int2hex (dat.length () 
+    + footer_string_.length (), 8, '0');
+  length_string = String_convert::hex2bin (length_string);
+  str += length_string;
   str += dat;
-  str += footer_str_;
+  str += footer_string_;
   return str;
 }
 
 Midi_duration::Midi_duration (Real seconds_f)
 {
-  seconds_f_ = seconds_f;
+  seconds_ = seconds_f;
 }
 
 String
-Midi_duration::str () const
+Midi_duration::string () const
 {
-  return String ("<duration: ") + to_str (seconds_f_) + ">";
+  return String ("<duration: ") + to_string (seconds_) + ">";
 }
 
-Midi_event::Midi_event (Moment delta_mom, Midi_item* midi_p)
+Midi_event::Midi_event (Moment delta_mom, Midi_item* midi)
 {
   delta_mom_ = delta_mom;
-  midi_p_ = midi_p;
+  midi_ = midi;
 }
 
 /*
   ugh. midi output badly broken since grace note hackage.
  */
 String
-Midi_event::str () const
+Midi_event::string () const
 {
   Rational rat_dt = (delta_mom_.main_part_ * Rational (384) +
     delta_mom_.grace_part_ * Rational (100))*Rational (4);
   int delta_i = int (rat_dt);
 
-  String delta_str = Midi_item::i2varint_str (delta_i);
-  String midi_str = midi_p_->str ();
-  assert (midi_str.length_i ());
-  return delta_str + midi_str;
+  String delta_string = Midi_item::i2varint_string (delta_i);
+  String midi_string = midi_->string ();
+  assert (midi_string.length ());
+  return delta_string + midi_string;
 }
 
 
@@ -112,45 +112,45 @@ Midi_header::Midi_header (int format_i, int tracks_i, int clocks_per_4_i)
 {
   String str;
        
-  String format_str = String_convert::i2hex_str (format_i, 4, '0');
-  str += String_convert::hex2bin_str (format_str);
+  String format_string = String_convert::int2hex (format_i, 4, '0');
+  str += String_convert::hex2bin (format_string);
        
-  String tracks_str = String_convert::i2hex_str (tracks_i, 4, '0');
-  str += String_convert::hex2bin_str (tracks_str);
+  String tracks_string = String_convert::int2hex (tracks_i, 4, '0');
+  str += String_convert::hex2bin (tracks_string);
 
-  String tempo_str = String_convert::i2hex_str (clocks_per_4_i, 4, '0');
-  str += String_convert::hex2bin_str (tempo_str);
+  String tempo_string = String_convert::int2hex (clocks_per_4_i, 4, '0');
+  str += String_convert::hex2bin (tempo_string);
 
   set ("MThd", str, "");
 }
 
 Midi_instrument::Midi_instrument (Audio_instrument* a)
 {
-  audio_l_ = a;
-  audio_l_->str_.to_lower ();
+  audio_ = a;
+  audio_->str_.to_lower ();
 }
 
 String
-Midi_instrument::str() const
+Midi_instrument::string () const
 {
   Byte program_byte = 0;
   bool found = false;
   SCM proc = scm_primitive_eval (ly_symbol2scm ("midi-program")); 
-  SCM program = gh_call1 (proc, ly_symbol2scm (audio_l_->str_.ch_C()));
+  SCM program = gh_call1 (proc, ly_symbol2scm (audio_->str_.to_str0 ()));
   found = (program != SCM_BOOL_F);
   if (found)
     program_byte = gh_scm2int(program);
   else
-      warning (_f ("no such instrument: `%s'", audio_l_->str_.ch_C ()));
+      warning (_f ("no such instrument: `%s'", audio_->str_.to_str0 ()));
 
-  String str = to_str ((char) (0xc0 + channel_i_)); //YIKES! FIXME: Should be track. -rz
-  str += to_str ((char)program_byte);
+  String str = to_string ((char) (0xc0 + channel_)); //YIKES! FIXME: Should be track. -rz
+  str += to_string ((char)program_byte);
   return str;
 }
 
 Midi_item::Midi_item ()
 {
-  channel_i_ = 0;
+  channel_ = 0;
 }
 
 Midi_item::~Midi_item ()
@@ -158,7 +158,7 @@ Midi_item::~Midi_item ()
 }
 
 String
-Midi_item::i2varint_str (int i)
+Midi_item::i2varint_string (int i)
 {
   int buffer_i = i & 0x7f;
   while ((i >>= 7) > 0) 
@@ -171,7 +171,7 @@ Midi_item::i2varint_str (int i)
   String str;
   while (1) 
     {
-      str += to_str ((char)buffer_i);
+      str += to_string ((char)buffer_i);
       if (buffer_i & 0x80)
        buffer_i >>= 8;
       else
@@ -182,51 +182,51 @@ Midi_item::i2varint_str (int i)
 
 Midi_key::Midi_key (Audio_key*a)
 {
-  audio_l_ = a;
+  audio_ = a;
 }
 
 String
-Midi_key::str () const
+Midi_key::string () const
 {
   String str = "ff5902";
-  str += String_convert::i2hex_str (audio_l_->accidentals_, 2, '0');
-  if (audio_l_->major_)
-    str += String_convert::i2hex_str (0, 2, '0');
+  str += String_convert::int2hex (audio_->accidentals_, 2, '0');
+  if (audio_->major_)
+    str += String_convert::int2hex (0, 2, '0');
   else
-    str += String_convert::i2hex_str (1, 2, '0');
-  return String_convert::hex2bin_str (str);
+    str += String_convert::int2hex (1, 2, '0');
+  return String_convert::hex2bin (str);
 }
 
 Midi_time_signature::Midi_time_signature (Audio_time_signature* a)
 {
-  audio_l_ = a;
-  clocks_per_1_i_ = 18;
+  audio_ = a;
+  clocks_per_1_ = 18;
 }
 
 String
-Midi_time_signature::str () const
+Midi_time_signature::string () const
 {
-  int num = audio_l_->beats_i_;
-  int den = audio_l_->one_beat_i_;
+  int num = audio_->beats_;
+  int den = audio_->one_beat_;
 
   String str = "ff5804";
-  str += String_convert::i2hex_str (num, 2, '0');
-  str += String_convert::i2hex_str (intlog2 (den) , 2, '0');
-  str += String_convert::i2hex_str (clocks_per_1_i_, 2, '0');
-  str += String_convert::i2hex_str (8, 2, '0');
-  return String_convert::hex2bin_str (str);
+  str += String_convert::int2hex (num, 2, '0');
+  str += String_convert::int2hex (intlog2 (den) , 2, '0');
+  str += String_convert::int2hex (clocks_per_1_, 2, '0');
+  str += String_convert::int2hex (8, 2, '0');
+  return String_convert::hex2bin (str);
 }
 
 Midi_note::Midi_note (Audio_note* a)
 {
-  audio_l_ = a;
+  audio_ = a;
   dynamic_byte_ = 0x7f;
 }
 
 Moment
 Midi_note::length_mom () const
 {
-  Moment m = audio_l_->length_mom_;
+  Moment m = audio_->length_mom_;
 #if 0
   //junkme?
   if (m < Moment (Rational (1, 1000)))
@@ -239,9 +239,9 @@ Midi_note::length_mom () const
 }
 
 int
-Midi_note::pitch_i () const
+Midi_note::get_pitch () const
 {
-  int p = audio_l_->pitch_.semitone_pitch () + audio_l_->transposing_i_;
+  int p = audio_->pitch_.semitone_pitch () + audio_->transposing_;
   if (p == INT_MAX)
     {
       warning (_ ("silly pitch"));
@@ -251,22 +251,22 @@ Midi_note::pitch_i () const
 }
 
 String
-Midi_note::str () const
+Midi_note::string () const
 {
-  Byte status_byte = (char) (0x90 + channel_i_);
+  Byte status_byte = (char) (0x90 + channel_);
 
-  String str = to_str ((char)status_byte);
-  str += to_str ((char) (pitch_i () + c0_pitch_i_c_));
+  String str = to_string ((char)status_byte);
+  str += to_string ((char) (get_pitch () + c0_pitch_i_));
 
-  str += to_str ((char)dynamic_byte_);
+  str += to_string ((char)dynamic_byte_);
   return str;
 }
 
 Midi_note_off::Midi_note_off (Midi_note* n)
-  : Midi_note (n->audio_l_)
+  : Midi_note (n->audio_)
 {
-  on_l_ = n;
-  channel_i_ = n->channel_i_;
+  on_ = n;
+  channel_ = n->channel_;
 
   // Anybody who hears any difference, or knows how this works?
   //  0 should definitely be avoided, notes stick on some sound cards.
@@ -276,26 +276,26 @@ Midi_note_off::Midi_note_off (Midi_note* n)
 }
 
 String
-Midi_note_off::str () const
+Midi_note_off::string () const
 {
-  Byte status_byte = (char) (0x80 + channel_i_);
+  Byte status_byte = (char) (0x80 + channel_);
 
-  String str = to_str ((char)status_byte);
-  str += to_str ((char) (pitch_i () + Midi_note::c0_pitch_i_c_));
-  str += to_str ((char)aftertouch_byte_);
+  String str = to_string ((char)status_byte);
+  str += to_string ((char) (get_pitch () + Midi_note::c0_pitch_i_));
+  str += to_string ((char)aftertouch_byte_);
   return str;
 }
 
 Midi_dynamic::Midi_dynamic (Audio_dynamic* a)
 {
-  audio_l_ = a;
+  audio_ = a;
 }
 
 String
-Midi_dynamic::str () const
+Midi_dynamic::string () const
 {
-  Byte status_byte = (char) (0xB0 + channel_i_);
-  String str = to_str ((char)status_byte);
+  Byte status_byte = (char) (0xB0 + channel_);
+  String str = to_string ((char)status_byte);
 
   /*
     Main volume controller (per channel):
@@ -304,66 +304,66 @@ Midi_dynamic::str () const
    */
   static Real const full_scale = 127;
   
-  int volume = (int) (audio_l_->volume_*full_scale);
+  int volume = (int) (audio_->volume_*full_scale);
   if (volume <= 0)
     volume = 1;
   if (volume > full_scale)
     volume = (int)full_scale;
 
-  str += to_str ((char)0x07);
-  str += to_str ((char)volume);
+  str += to_string ((char)0x07);
+  str += to_string ((char)volume);
   return str;
 }
 
 Midi_piano_pedal::Midi_piano_pedal (Audio_piano_pedal* a)
 {
-  audio_l_ = a;
+  audio_ = a;
 }
 
 String
-Midi_piano_pedal::str () const
+Midi_piano_pedal::string () const
 {
-  Byte status_byte = (char) (0xB0 + channel_i_);
-  String str = to_str ((char)status_byte);
+  Byte status_byte = (char) (0xB0 + channel_);
+  String str = to_string ((char)status_byte);
 
-  if (audio_l_->type_str_ == "Sostenuto")
-    str += to_str ((char)0x42);
-  else if (audio_l_->type_str_ == "Sustain")
-    str += to_str ((char)0x40);
-  else if (audio_l_->type_str_ == "UnaCorda")
-    str += to_str ((char)0x43);
+  if (audio_->type_string_ == "Sostenuto")
+    str += to_string ((char)0x42);
+  else if (audio_->type_string_ == "Sustain")
+    str += to_string ((char)0x40);
+  else if (audio_->type_string_ == "UnaCorda")
+    str += to_string ((char)0x43);
 
-  int pedal = ((1 - audio_l_->dir_) / 2) * 0x7f;
-  str += to_str ((char)pedal);
+  int pedal = ((1 - audio_->dir_) / 2) * 0x7f;
+  str += to_string ((char)pedal);
   return str;
 }
 
 Midi_tempo::Midi_tempo (Audio_tempo* a)
 {
-  audio_l_ = a;
+  audio_ = a;
 }
 
 String
-Midi_tempo::str () const
+Midi_tempo::string () const
 {
-  int useconds_per_4_i = 60 * (int)1e6 / audio_l_->per_minute_4_i_;
+  int useconds_per_4_i = 60 * (int)1e6 / audio_->per_minute_4_;
   String str = "ff5103";
-  str += String_convert::i2hex_str (useconds_per_4_i, 6, '0');
-  return String_convert::hex2bin_str (str);
+  str += String_convert::int2hex (useconds_per_4_i, 6, '0');
+  return String_convert::hex2bin (str);
 }
 
 Midi_text::Midi_text (Audio_text* a)
 {
-  audio_l_ = a;
+  audio_ = a;
 }
 
 String
-Midi_text::str () const
+Midi_text::string () const
 {
-  String str = "ff" + String_convert::i2hex_str (audio_l_->type_, 2, '0');
-  str = String_convert::hex2bin_str (str);
-  str += i2varint_str (audio_l_->text_str_.length_i ());
-  str += audio_l_->text_str_;
+  String str = "ff" + String_convert::int2hex (audio_->type_, 2, '0');
+  str = String_convert::hex2bin (str);
+  str += i2varint_string (audio_->text_string_.length ());
+  str += audio_->text_string_;
   return str;
 }
 
@@ -384,9 +384,9 @@ Midi_track::Midi_track ()
 //         mi = 0:  major key
 //         mi = 1:  minor key
 
-  number_i_ = 0;
+  number_ = 0;
        
-  char const* data_ch_C = ""
+  char const* data_str0 = ""
     //        "00" "ff58" "0404" "0218" "08"
     // "00" "ff51" "0307" "a120"
     // why a key at all, in midi?
@@ -396,34 +396,34 @@ Midi_track::Midi_track ()
     //                           "00" "ff59" "02" "ff" "00"
        ;
 
-  String data_str;
+  String data_string;
   // only for format 0 (currently using format 1)?
-  data_str += String_convert::hex2bin_str (data_ch_C);
+  data_string += String_convert::hex2bin (data_str0);
 
-  char const* footer_ch_C = "00" "ff2f" "00";
-  String footer_str = String_convert::hex2bin_str (footer_ch_C);
+  char const* footer_str0 = "00" "ff2f" "00";
+  String footer_string = String_convert::hex2bin (footer_str0);
 
-  set ("MTrk", data_str, footer_str);
+  set ("MTrk", data_string, footer_string);
 }
 
 void 
-Midi_track::add (Moment delta_time_mom, Midi_item* midi_p)
+Midi_track::add (Moment delta_time_mom, Midi_item* midi)
 {
   assert (delta_time_mom >= Moment (0));
 
-  Midi_event * e = new Midi_event (delta_time_mom, midi_p);
+  Midi_event * e = new Midi_event (delta_time_mom, midi);
   event_p_list_.append (new Killing_cons<Midi_event> (e, 0));
 }
 
 String
-Midi_track::data_str () const
+Midi_track::data_string () const
 {
-  String str = Midi_chunk::data_str ();
+  String str = Midi_chunk::data_string ();
   if (midi_debug_global_b)
     str += "\n";
   for (Cons<Midi_event> *i=event_p_list_.head_; i; i = i->next_) 
     {
-      str += i->car_->str ();
+      str += i->car_->string ();
       if (midi_debug_global_b)
         str += "\n";
     }