]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/include/midi-item.hh
release: 1.5.29
[lilypond.git] / lily / include / midi-item.hh
index 51996efa7ff60c384c7e2ca39ab77f11b00b8f08..cbf9a6740f6fdc4ace56e4a777687ba5db5b7bc0 100644 (file)
@@ -1,7 +1,7 @@
 /*
   midi-item.hh -- declare Midi items
 
-  (c)  1997--1999 Jan Nieuwenhuizen <janneke@gnu.org>
+  (c)  1997--2002 Jan Nieuwenhuizen <janneke@gnu.org>
  */
 
 #ifndef MIDI_ITEM_HH
 #include "cons.hh"
 #include "string.hh"
 #include "lily-proto.hh"
-#include "proto.hh"
 #include "moment.hh"
+#include "audio-item.hh"
 
 /**
   Any piece of midi information.
 
   Maybe use base classes for RIFF files?
  */
-struct Midi_item {
-  Midi_item (Audio_item* audio_item_l); 
+class Midi_item
+{
+public:
+  Midi_item ();
   virtual ~Midi_item ();
+
+  /// factory
+  static Midi_item* midi_p (Audio_item* a);
+
   static String i2varint_str (int i);
+
   virtual String str () const = 0;
 
-  Audio_item* audio_item_l_;
   int channel_i_;
-
-private:
-  Midi_item (Midi_item const&);
-  Midi_item& operator = ( Midi_item const&);
 };
 
 /**
   timed MIDI event
  */
-struct Midi_event
+class Midi_event
 {
-  Midi_event (Moment delta_mom, Midi_item* mitem_l);
-  ~Midi_event ();
+public:
+  Midi_event (Moment delta_mom, Midi_item* midi_l);
+
   Moment delta_mom_;
-  Midi_item* mitem_p_;
+  Midi_item* midi_p_;
   String str () const;
 };
 
 /**
   variable sized MIDI data
  */
-struct Midi_chunk : Midi_item {
-  
-  Midi_chunk ();
-
+class Midi_chunk : public Midi_item
+{
+public:
   void set (String header_str, String data_str, String footer_str);
   virtual String str () const;
   virtual String data_str () const;
@@ -61,105 +63,147 @@ private:
   String header_str_;
 };
 
-struct Midi_duration : public Midi_item {
+class Midi_duration : public Midi_item
+{
+public:
   Midi_duration (Real seconds_f);
 
   virtual String str () const;
   Real seconds_f_;
 };
 
-struct Midi_header : Midi_chunk {
+class Midi_header : public Midi_chunk
+{
+public:
   Midi_header (int format_i, int tracks_i, int clocks_per_4_i);
 };
 
 /**
   Change instrument event
  */
-struct Midi_instrument : public Midi_item {
-  Midi_instrument (int channel_i, String instrument_str);
+class Midi_instrument : public Midi_item
+{
+public:
+  Midi_instrument (Audio_instrument*);
 
   virtual String str () const;
-  String instrument_str_;
+
+  Audio_instrument* audio_l_;
 };
                                       
 
-struct Midi_key : public Midi_item {
-  Midi_key (Audio_item* audio_item_l);
+class Midi_key : public Midi_item
+{
+public:
+  Midi_key (Audio_key*);
        
   virtual String str () const;
+
+  Audio_key* audio_l_;
 };
 
-struct Midi_time_signature : Midi_item {
-  Midi_time_signature (Audio_item* audio_item_l); 
+class Midi_time_signature : public Midi_item
+{
+public:
+  Midi_time_signature (Audio_time_signature*);
   
   virtual String str () const;
+
+  Audio_time_signature* audio_l_;
   int clocks_per_1_i_;
 };
 
 /**
-  Turn a note on (blond).
+  Turn a note on.
  */
-struct Midi_note : public Midi_item {
-  Midi_note (Audio_item* audio_item_l); 
+class Midi_note : public Midi_item
+{
+public:
+  Midi_note (Audio_note*);
 
   Moment length_mom () const;
   int pitch_i () const;
   virtual String str () const;
 
+  Audio_note* audio_l_;
+
   static int const c0_pitch_i_c_ = 60;
   Byte dynamic_byte_;
 };
 
 /**
-  Turn a note off (dark).
+  Turn a note off 
  */
-struct Midi_note_off : public Midi_item {
+class Midi_note_off : public Midi_note
+{
+public:
   Midi_note_off (Midi_note*); 
 
-  int pitch_i () const;
   virtual String str () const;
 
+  Midi_note* on_l_;
   Byte aftertouch_byte_;
 };
 
-struct Midi_text : Midi_item {
-  
-    
+class Midi_text : public Midi_item
+{
+public:
   enum Type { 
     TEXT = 1, COPYRIGHT, TRACK_NAME, INSTRUMENT_NAME, LYRIC, 
     MARKER, CUE_POINT
   };
-  Midi_text (Midi_text::Type type, String text_str);
-  Midi_text (Audio_item* audio_item_l);
+
+  Midi_text (Audio_text*);
     
   virtual String str () const;
 
-  Type type_;
-  String text_str_;
+  Audio_text* audio_l_;
 };
 
-struct Midi_tempo : Midi_item {
-  Midi_tempo (int per_minute_4_i);
-  Midi_tempo (Audio_item* audio_item_l); 
+class Midi_dynamic : public Midi_item
+{
+public:
+  Midi_dynamic (Audio_dynamic*);
+  
+  virtual String str () const;
+
+  Audio_dynamic* audio_l_;
+};
+
+class Midi_piano_pedal : public Midi_item
+{
+public:
+  Midi_piano_pedal (Audio_piano_pedal*);
   
   virtual String str () const;
 
-  int per_minute_4_i_;
+  Audio_piano_pedal* audio_l_;
 };
 
-struct Midi_track : Midi_chunk {
+class Midi_tempo : public Midi_item
+{
+public:
+  Midi_tempo (Audio_tempo*);
+  
+  virtual String str () const;
+
+  Audio_tempo* audio_l_;
+};
+
+class Midi_track : public Midi_chunk
+{
+public:
   int number_i_;
+
+  /*
+    Compensate for starting grace notes.
+   */
   Cons_list<Midi_event> event_p_list_;
   
   Midi_track ();
-  ~Midi_track ();
 
-  void add (Moment delta_time_mom, Midi_item* mitem_l);
+  void add (Moment delta_time_mom, Midi_item* midi_l);
   virtual String data_str () const;
-
-private:
-  // copy trap
-  Midi_track (Midi_track const&);
 };
 
 #endif // MIDI_ITEM_HH