/*
midi-item.hh -- declare Midi items
- (c) 1997--2000 Jan Nieuwenhuizen <janneke@gnu.org>
+ (c) 1997--2003 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.
virtual ~Midi_item ();
/// factory
- static Midi_item* midi_p (Audio_item* a);
+ static Midi_item* get_midi (Audio_item* a);
- static String i2varint_str (int i);
+ static String i2varint_string (int i);
- virtual String str () const = 0;
+ virtual String to_string () const = 0;
- int channel_i_;
+ int channel_;
};
/**
class Midi_event
{
public:
- Midi_event (Moment delta_mom, Midi_item* midi_l);
+ Midi_event (Moment delta_mom, Midi_item* midi);
Moment delta_mom_;
- Midi_item* midi_p_;
- String str () const;
+ Midi_item* midi_;
+ String to_string () const;
};
/**
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;
+ void set (String header_string, String data_string, String footer_string);
+ virtual String to_string () const;
+ virtual String data_string () const;
private:
- String data_str_;
- String footer_str_;
- String header_str_;
+ String data_string_;
+ String footer_string_;
+ String header_string_;
};
class Midi_duration : public Midi_item
public:
Midi_duration (Real seconds_f);
- virtual String str () const;
- Real seconds_f_;
+ virtual String to_string () const;
+ Real seconds_;
};
class Midi_header : public Midi_chunk
public:
Midi_instrument (Audio_instrument*);
- virtual String str () const;
+ virtual String to_string () const;
- Audio_instrument* audio_l_;
+ Audio_instrument* audio_;
};
public:
Midi_key (Audio_key*);
- virtual String str () const;
+ virtual String to_string () const;
- Audio_key* audio_l_;
+ Audio_key* audio_;
};
class Midi_time_signature : public Midi_item
public:
Midi_time_signature (Audio_time_signature*);
- virtual String str () const;
+ virtual String to_string () const;
- Audio_time_signature* audio_l_;
- int clocks_per_1_i_;
+ Audio_time_signature* audio_;
+ int clocks_per_1_;
};
/**
public:
Midi_note (Audio_note*);
- Moment length_mom () const;
- int pitch_i () const;
- virtual String str () const;
+ Moment get_length () const;
+ int get_pitch () const;
+ virtual String to_string () const;
- Audio_note* audio_l_;
+ Audio_note* audio_;
- static int const c0_pitch_i_c_ = 60;
+ static int const c0_pitch_i_ = 60;
Byte dynamic_byte_;
};
public:
Midi_note_off (Midi_note*);
- virtual String str () const;
+ virtual String to_string () const;
- Midi_note* on_l_;
+ Midi_note* on_;
Byte aftertouch_byte_;
};
Midi_text (Audio_text*);
- virtual String str () const;
+ virtual String to_string () const;
- Audio_text* audio_l_;
+ Audio_text* audio_;
};
class Midi_dynamic : public Midi_item
public:
Midi_dynamic (Audio_dynamic*);
- virtual String str () const;
+ virtual String to_string () const;
- Audio_dynamic* audio_l_;
+ Audio_dynamic* audio_;
+};
+
+class Midi_piano_pedal : public Midi_item
+{
+public:
+ Midi_piano_pedal (Audio_piano_pedal*);
+
+ virtual String to_string () const;
+
+ Audio_piano_pedal* audio_;
};
class Midi_tempo : public Midi_item
public:
Midi_tempo (Audio_tempo*);
- virtual String str () const;
+ virtual String to_string () const;
- Audio_tempo* audio_l_;
+ Audio_tempo* audio_;
};
class Midi_track : public Midi_chunk
{
public:
- int number_i_;
+ int number_;
+
+ /*
+ Compensate for starting grace notes.
+ */
Cons_list<Midi_event> event_p_list_;
Midi_track ();
- void add (Moment delta_time_mom, Midi_item* midi_l);
- virtual String data_str () const;
+ void add (Moment delta_time_mom, Midi_item* midi);
+ virtual String data_string () const;
};
#endif // MIDI_ITEM_HH