X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fmidi_playlist.cc;h=84bcc70d0b860e62cc06de9c1cf9543b6df8547b;hb=d345d446883c0425f8312149d04abc62076e36fc;hp=d8b07d33428f198a9c1515558c0aaa36ddd9e202;hpb=de5e463904de7b58218a5bb1e9080ba5353bb985;p=ardour.git diff --git a/libs/ardour/midi_playlist.cc b/libs/ardour/midi_playlist.cc index d8b07d3342..84bcc70d0b 100644 --- a/libs/ardour/midi_playlist.cc +++ b/libs/ardour/midi_playlist.cc @@ -1,6 +1,6 @@ /* Copyright (C) 2006 Paul Davis - Written by Dave Robillard, 2006 + Author: David Robillard This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -23,140 +23,135 @@ #include #include -#include + +#include "pbd/error.h" #include "evoral/EventList.hpp" -#include "ardour/debug.h" -#include "ardour/types.h" #include "ardour/configuration.h" +#include "ardour/debug.h" +#include "ardour/midi_model.h" #include "ardour/midi_playlist.h" #include "ardour/midi_region.h" -#include "ardour/session.h" #include "ardour/midi_ring_buffer.h" - -#include "pbd/error.h" +#include "ardour/session.h" +#include "ardour/types.h" #include "i18n.h" using namespace ARDOUR; -using namespace sigc; +using namespace PBD; using namespace std; MidiPlaylist::MidiPlaylist (Session& session, const XMLNode& node, bool hidden) : Playlist (session, node, DataType::MIDI, hidden) , _note_mode(Sustained) { +#ifndef NDEBUG const XMLProperty* prop = node.property("type"); assert(prop && DataType(prop->value()) == DataType::MIDI); +#endif in_set_state++; - set_state (node, Stateful::loading_state_version); + if (set_state (node, Stateful::loading_state_version)) { + throw failed_constructor (); + } in_set_state--; + + relayer (); } MidiPlaylist::MidiPlaylist (Session& session, string name, bool hidden) : Playlist (session, name, DataType::MIDI, hidden) + , _note_mode(Sustained) { } MidiPlaylist::MidiPlaylist (boost::shared_ptr other, string name, bool hidden) : Playlist (other, name, hidden) + , _note_mode(other->_note_mode) { } -MidiPlaylist::MidiPlaylist (boost::shared_ptr other, nframes_t start, nframes_t dur, string name, bool hidden) - : Playlist (other, start, dur, name, hidden) +MidiPlaylist::MidiPlaylist (boost::shared_ptr other, framepos_t start, framecnt_t dur, string name, bool hidden) + : Playlist (other, start, dur, name, hidden) + , _note_mode(other->_note_mode) { /* this constructor does NOT notify others (session) */ } MidiPlaylist::~MidiPlaylist () { - GoingAway (); /* EMIT SIGNAL */ - - /* drop connections to signals */ - - notify_callbacks (); } -struct RegionSortByLayer { - bool operator() (boost::shared_ptr a, boost::shared_ptr b) { - return a->layer() < b->layer(); - } -}; - template -struct EventsSortByTime { +struct EventsSortByTimeAndType { bool operator() (Evoral::Event