me->flush_extent_cache (X_AXIS);
me->set_property ("X-extent", scm_width);
- for (vsize i = apes.size (); i--;)
- delete apes[i];
-
+ junk_pointers (apes);
+ delete head_ape;
+
return SCM_BOOL_T;
}
{
Midi_track midi_track;
midi_track.number_ = channel;
-
- for (Midi_walker i (this, &midi_track, channel); i.ok (); i++)
+ Midi_walker i (this, &midi_track, channel);
+ for (; i.ok (); i++)
i.process ();
+
+ i.finalize ();
midi_stream << midi_track;
}
virtual ~Midi_item ();
virtual char const *name () const;
- /// factory
static Midi_item *get_midi (Audio_item *a);
static string i2varint_string (int i);
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_;
vector<Audio_item*> items_;
PQueue<Midi_note_event> stop_note_queue;
int last_tick_;
+
+ vector<Midi_item*> midi_events_;
};
#endif // MIDI_WALKER_HH
Midi_track::~Midi_track ()
{
- junk_pointers (events_);
}
Midi_walker::~Midi_walker ()
{
- do_stop_notes (last_tick_ + 384);
+ junk_pointers (midi_events_);
+}
+
+void
+Midi_walker::finalize ()
+{
+ do_stop_notes (INT_MAX);
}
/**
{
/* 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_b_)
{
- 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
{