/* Copyright (C) 1998 Paul Barton-Davis 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 the Free Software Foundation; either version 2 of the License, or (at your option) any later version. This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #ifndef __midi_manager_h__ #define __midi_manager_h__ #include #include #include "midi++/types.h" #include "midi++/port.h" namespace MIDI { class Manager { public: ~Manager (); /** Signal the start of an audio cycle. * This MUST be called before any reading/writing for this cycle. * Realtime safe. */ void cycle_start(nframes_t nframes); /** Signal the end of an audio cycle. * This signifies that the cycle began with @ref cycle_start has ended. * This MUST be called at the end of each cycle. * Realtime safe. */ void cycle_end(); Port* add_port (Port *); Port* port (std::string const &); typedef std::list PortList; const PortList& get_midi_ports() const { return _ports; } static Manager *instance () { if (theManager == 0) { theManager = new Manager; } return theManager; } void reestablish (void *); void reconnect (); PBD::Signal0 PortsChanged; private: /* This is a SINGLETON pattern */ Manager (); static Manager *theManager; std::list _ports; }; } // namespace MIDI #endif // __midi_manager_h__