void process ();
void operator ++ (int);
bool ok () const;
-
+ void finalize ();
private:
void do_start_note (Midi_note *note);
void do_stop_notes (int);
void output_event (int, Midi_item *l);
-
+ Midi_item *get_midi (Audio_item*);
int channel_;
Midi_track *track_;
Audio_staff *staff_;
PQueue<Midi_note_event> stop_note_queue;
int last_tick_;
+ vector<Midi_item*> midi_events_;
};
#endif // MIDI_WALKER_HH
Midi_walker::~Midi_walker ()
{
- do_stop_notes (INT_MAX);
+ junk_pointers (midi_events_);
}
+void
+Midi_walker::finalize ()
+{
+ do_stop_notes (INT_MAX);
+}
/**
Find out if start_note event is needed, and do it if needed.
{
/* skip this stopnote,
don't play the start note */
- delete note;
note = 0;
break;
}
Midi_note_event e = stop_note_queue.get ();
if (e.ignore_)
{
- delete e.val;
continue;
}
Audio_item *audio = items_[index_];
do_stop_notes (audio->audio_column_->ticks ());
- if (Midi_item *midi = Midi_item::get_midi (audio))
+ if (Midi_item *midi = get_midi (audio))
{
if (Midi_channel_item *mci = dynamic_cast<Midi_channel_item*> (midi))
mci->channel_ = channel_;
}
}
+Midi_item*
+Midi_walker::get_midi (Audio_item *i)
+{
+ Midi_item *mi = Midi_item::get_midi (i);
+ midi_events_.push_back (mi);
+ return mi;
+}
+
bool
Midi_walker::ok () const
{