+ PluginPinWindowProxy (std::string const &, boost::weak_ptr<ARDOUR::Processor>);
+ ~PluginPinWindowProxy();
+
+ Gtk::Window* get (bool create = false);
+ ARDOUR::SessionHandlePtr* session_handle();
+
+ private:
+ boost::weak_ptr<ARDOUR::Processor> _processor;
+
+ void processor_going_away ();
+ PBD::ScopedConnection going_away_connection;
+};
+
+
+
+class ProcessorEntry : public Gtkmm2ext::DnDVBoxChild, public sigc::trackable
+{
+public:
+ ProcessorEntry (ProcessorBox *, boost::shared_ptr<ARDOUR::Processor>, Width);
+ ~ProcessorEntry ();
+
+ Gtk::EventBox& action_widget ();
+ Gtk::Widget& widget ();
+ std::string drag_text () const;
+ void set_visual_state (Gtkmm2ext::VisualState, bool);
+
+ bool is_selectable() const {return _selectable;}
+ void set_selectable(bool s) { _selectable = s; }
+
+ bool drag_data_get (Glib::RefPtr<Gdk::DragContext> const, Gtk::SelectionData &);
+ bool can_copy_state (Gtkmm2ext::DnDVBoxChild*) const;
+
+ enum Position {
+ PreFader,
+ Fader,
+ PostFader
+ };
+
+ void set_position (Position, uint32_t);
+ bool unknown_processor () const { return _unknown_processor; } ;
+ boost::shared_ptr<ARDOUR::Processor> processor () const;
+ void set_enum_width (Width);
+
+ /** Hide any widgets that should be hidden */
+ virtual void hide_things ();
+
+ void toggle_inline_display_visibility ();
+ void show_all_controls ();
+ void hide_all_controls ();
+ void add_control_state (XMLNode *) const;
+ void set_control_state (XMLNode const *);
+ std::string state_id () const;
+ Gtk::Menu* build_controls_menu ();
+ Gtk::Menu* build_send_options_menu ();
+
+protected:
+ ArdourWidgets::ArdourButton _button;
+ Gtk::VBox _vbox;
+ Position _position;
+ uint32_t _position_num;
+ ProcessorBox* _parent;
+
+ virtual void setup_visuals ();
+
+private:
+ bool _selectable;
+ bool _unknown_processor;
+ void led_clicked(GdkEventButton *);
+ void processor_active_changed ();
+ void processor_property_changed (const PBD::PropertyChange&);
+ void processor_configuration_changed (const ARDOUR::ChanCount in, const ARDOUR::ChanCount out);
+ std::string name (Width) const;
+ void setup_tooltip ();
+
+ boost::shared_ptr<ARDOUR::Processor> _processor;
+ Width _width;
+ PBD::ScopedConnection active_connection;
+ PBD::ScopedConnection name_connection;
+ PBD::ScopedConnection config_connection;
+ ARDOUR::PluginPresetPtr _plugin_preset_pointer;
+
+ class Control : public sigc::trackable {
+ public:
+ Control (boost::shared_ptr<ARDOUR::AutomationControl>, std::string const &);
+ ~Control ();
+
+ void set_visible (bool);
+ void add_state (XMLNode *) const;
+ void set_state (XMLNode const *);
+ void hide_things ();
+
+ bool visible () const {
+ return _visible;
+ }
+
+ std::string name () const {
+ return _name;
+ }
+
+ Gtk::Alignment box;
+
+ private:
+ void slider_adjusted ();
+ void button_clicked ();
+ void button_clicked_event (GdkEventButton *);
+ void control_changed ();
+ void control_automation_state_changed ();
+ std::string state_id () const;
+ void set_tooltip ();
+
+ void start_touch ();
+ void end_touch ();
+
+ boost::weak_ptr<ARDOUR::AutomationControl> _control;
+ /* things for a slider */
+ Gtk::Adjustment _adjustment;
+ ArdourWidgets::HSliderController _slider;
+ Gtkmm2ext::PersistentTooltip _slider_persistant_tooltip;
+ /* things for a button */
+ ArdourWidgets::ArdourButton _button;
+ bool _ignore_ui_adjustment;
+ PBD::ScopedConnectionList _connections;
+ bool _visible;
+ std::string _name;
+ };
+
+ std::list<Control*> _controls;
+
+ void toggle_control_visibility (Control *);
+ void toggle_panner_link ();
+ void toggle_allow_feedback ();
+
+ class PluginInlineDisplay : public PluginDisplay {
+ public:
+ PluginInlineDisplay(ProcessorEntry&, boost::shared_ptr<ARDOUR::Plugin>, uint32_t max_height = 80);
+ ~PluginInlineDisplay() {}
+ protected:
+ void on_size_request (Gtk::Requisition* req);
+ bool on_button_press_event (GdkEventButton *ev);
+ void update_height_alloc (uint32_t inline_height);
+
+ void display_sample (cairo_t* cr, double w, double h);
+
+ ProcessorEntry& _entry;
+ bool _scroll;
+ const uint32_t _given_max_height;
+ };
+
+ class LuaPluginDisplay : public PluginInlineDisplay {
+ public:
+ LuaPluginDisplay(ProcessorEntry&, boost::shared_ptr<ARDOUR::LuaProc>, uint32_t max_height = 80);
+ ~LuaPluginDisplay();
+ protected:
+ virtual uint32_t render_inline (cairo_t *, uint32_t width);
+ private:
+ boost::shared_ptr<ARDOUR::LuaProc> _luaproc;
+ LuaState lua_gui;
+ luabridge::LuaRef * _lua_render_inline;
+ };
+
+ class PortIcon : public Gtk::DrawingArea {
+ public:
+ PortIcon(bool input);
+ void set_ports(ARDOUR::ChanCount const ports) { _ports = ports; }
+ private:
+ bool on_expose_event (GdkEventExpose *);
+ bool _input;
+ ARDOUR::ChanCount _ports;
+ };
+
+ class RoutingIcon : public Gtk::DrawingArea {
+ public:
+ RoutingIcon(bool inputrouting = true);
+ void set (
+ const ARDOUR::ChanCount&,
+ const ARDOUR::ChanCount&,
+ const ARDOUR::ChanCount&,
+ const ARDOUR::ChanCount&,
+ const ARDOUR::ChanMapping&,
+ const ARDOUR::ChanMapping&,
+ const ARDOUR::ChanMapping&);
+ void set_fed_by (
+ const ARDOUR::ChanCount&,
+ const ARDOUR::ChanCount&,
+ const ARDOUR::ChanMapping&,
+ const ARDOUR::ChanMapping&);
+
+ void set_feeding (
+ const ARDOUR::ChanCount&,
+ const ARDOUR::ChanCount&,
+ const ARDOUR::ChanMapping&,
+ const ARDOUR::ChanMapping&);
+
+ void set_terminal (bool b);
+
+ void copy_state (const RoutingIcon& other) {
+ _in = other._in;
+ _out = other._out;
+ _sources = other._sources;
+ _sinks = other._sinks;
+ _in_map = other._in_map;
+ _out_map = other._out_map;
+ _thru_map = other._thru_map;
+ _f_out = other._f_out;
+ _f_out_map = other._f_out_map;
+ _f_thru_map = other._f_thru_map;
+ _f_sources = other._f_sources;
+ _i_in = other._i_in;
+ _i_in_map = other._i_in_map;
+ _i_thru_map = other._i_thru_map;
+ _i_sinks = other._i_sinks;
+ _fed_by = other._fed_by;
+ _feeding = other._feeding;
+ }
+
+ void unset_fed_by () { _fed_by = false ; }
+ void unset_feeding () { _feeding = false ; }
+ bool in_identity () const;
+ bool out_identity () const;
+ bool can_coalesce () const;
+
+ static double pin_x_pos (uint32_t, double, uint32_t, uint32_t, bool);
+ static void draw_connection (cairo_t*, double, double, double, double, bool, bool dashed = false);
+ static void draw_gnd (cairo_t*, double, double, double, bool);
+ static void draw_sidechain (cairo_t*, double, double, double, bool);
+ static void draw_thru_src (cairo_t*, double, double, double, bool);
+ static void draw_thru_sink (cairo_t*, double, double, double, bool);
+
+ private:
+ bool on_expose_event (GdkEventExpose *);
+ void expose_input_map (cairo_t*, const double, const double);
+ void expose_coalesced_input_map (cairo_t*, const double, const double);
+ void expose_output_map (cairo_t*, const double, const double);
+
+ ARDOUR::ChanCount _in;
+ ARDOUR::ChanCount _out;
+ ARDOUR::ChanCount _sources;
+ ARDOUR::ChanCount _sinks;
+ ARDOUR::ChanMapping _in_map;
+ ARDOUR::ChanMapping _out_map;
+ ARDOUR::ChanMapping _thru_map;
+ ARDOUR::ChanCount _f_out;
+ ARDOUR::ChanMapping _f_out_map;
+ ARDOUR::ChanMapping _f_thru_map;
+ ARDOUR::ChanCount _f_sources;
+ ARDOUR::ChanCount _i_in;
+ ARDOUR::ChanMapping _i_in_map;
+ ARDOUR::ChanMapping _i_thru_map;
+ ARDOUR::ChanCount _i_sinks;
+ bool _fed_by;
+ bool _feeding;
+ bool _input;
+ bool _terminal;
+ };
+
+public:
+ PortIcon input_icon;
+ PortIcon output_icon;
+ RoutingIcon routing_icon; // sits on top of every processor (input routing)
+ RoutingIcon output_routing_icon; // only used by last processor in the chain
+
+protected:
+ PluginDisplay *_plugin_display ;
+};
+
+class PluginInsertProcessorEntry : public ProcessorEntry
+{
+public:
+ PluginInsertProcessorEntry (ProcessorBox *, boost::shared_ptr<ARDOUR::PluginInsert>, Width);
+
+ void hide_things ();
+
+private:
+ void iomap_changed ();
+ boost::shared_ptr<ARDOUR::PluginInsert> _plugin_insert;
+
+ PBD::ScopedConnectionList _iomap_connection;
+};
+
+class ProcessorBox : public Gtk::HBox, public PluginInterestedObject, public ARDOUR::SessionHandlePtr
+{
+public:
+ enum ProcessorOperation {
+ ProcessorsCut,
+ ProcessorsCopy,
+ ProcessorsPaste,
+ ProcessorsDelete,
+ ProcessorsSelectAll,
+ ProcessorsSelectNone,
+ ProcessorsToggleActive,
+ ProcessorsAB,
+ };
+
+ ProcessorBox (ARDOUR::Session*, boost::function<PluginSelector*()> get_plugin_selector,
+ ProcessorSelection&, MixerStrip* parent, bool owner_is_mixer = false);