/* Copyright (C) 2000,2007 Paul 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 __ardour_plugin_insert_h__ #define __ardour_plugin_insert_h__ #include #include #include #include "ardour/ardour.h" #include "ardour/types.h" #include "ardour/processor.h" #include "ardour/automation_control.h" class XMLNode; namespace ARDOUR { class Session; class Route; class Plugin; /** Plugin inserts: send data through a plugin */ class PluginInsert : public Processor { public: PluginInsert (Session&, boost::shared_ptr); PluginInsert (Session&, const XMLNode&); ~PluginInsert (); static const std::string port_automation_node_name; XMLNode& state(bool); XMLNode& get_state(void); int set_state(const XMLNode&, int version); void run (BufferSet& in, sframes_t start_frame, sframes_t end_frame, nframes_t nframes, bool); void silence (nframes_t nframes); void activate (); void deactivate (); void set_block_size (nframes_t nframes); ChanCount output_streams() const; ChanCount input_streams() const; ChanCount natural_output_streams() const; ChanCount natural_input_streams() const; bool set_count (uint32_t num); uint32_t get_count () const { return _plugins.size(); } bool can_support_io_configuration (const ChanCount& in, ChanCount& out) const; bool configure_io (ChanCount in, ChanCount out); bool is_generator() const; struct PluginControl : public AutomationControl { PluginControl (PluginInsert* p, const Evoral::Parameter ¶m, boost::shared_ptr list = boost::shared_ptr()); void set_value (float val); float get_value (void) const; private: PluginInsert* _plugin; bool _logarithmic; bool _toggled; }; boost::shared_ptr plugin(uint32_t num=0) const { if (num < _plugins.size()) { return _plugins[num]; } else { return _plugins[0]; // we always have one } } PluginType type (); std::string describe_parameter (Evoral::Parameter param); nframes_t signal_latency() const; boost::shared_ptr get_impulse_analysis_plugin(); void collect_signal_for_analysis(nframes_t nframes); PBD::Signal2 AnalysisDataGathered; private: /* disallow copy construction */ PluginInsert (const PluginInsert&); void parameter_changed (Evoral::Parameter, float); void set_parameter (Evoral::Parameter param, float val); float get_parameter (Evoral::Parameter param); float default_parameter_value (const Evoral::Parameter& param); typedef std::vector > Plugins; Plugins _plugins; boost::weak_ptr _impulseAnalysisPlugin; nframes_t _signal_analysis_collected_nframes; nframes_t _signal_analysis_collect_nframes_max; BufferSet _signal_analysis_inputs; BufferSet _signal_analysis_outputs; void automation_run (BufferSet& bufs, nframes_t nframes); void connect_and_run (BufferSet& bufs, nframes_t nframes, nframes_t offset, bool with_auto, nframes_t now = 0); void set_automatable (); void auto_state_changed (Evoral::Parameter which); void set_parameter_state (const XMLNode& node, int version); void set_parameter_state_2X (const XMLNode& node, int version); int32_t count_for_configuration (ChanCount in, ChanCount out) const; boost::shared_ptr plugin_factory (boost::shared_ptr); }; } // namespace ARDOUR #endif /* __ardour_plugin_insert_h__ */