/* This file is part of Ingen. * Copyright (C) 2007 Dave Robillard <http://drobilla.net> * * Ingen 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. * * Ingen 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 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., * 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA */ #ifndef MIDICONTROLNODE_H #define MIDICONTROLNODE_H #include <string> #include "NodeBase.h" #include "InternalNode.h" using std::string; namespace Ingen { class MidiLearnResponseEvent; class MidiMessage; template <typename T> class InputPort; template <typename T> class OutputPort; /** MIDI control input node. * * Creating one of these nodes is how a user makes "MIDI Bindings". Note that * this node will always be monophonic, the poly parameter is ignored. * * \ingroup engine */ class MidiControlNode : public InternalNode { public: MidiControlNode(const string& path, size_t poly, Patch* parent, SampleRate srate, size_t buffer_size); void process(SampleCount nframes, FrameTime start, FrameTime end); void control(uchar control_num, uchar val, SampleCount offset); void learn(MidiLearnResponseEvent* ev) { _learning = true; _learn_event = ev; } private: bool _learning; InputPort<MidiMessage>* _midi_in_port; InputPort<Sample>* _param_port; InputPort<Sample>* _log_port; InputPort<Sample>* _min_port; InputPort<Sample>* _max_port; OutputPort<Sample>* _control_port; OutputPort<Sample>* _audio_port; MidiLearnResponseEvent* _learn_event; }; } // namespace Ingen #endif // MIDICONTROLNODE_H