live signal analysis is for the processor -- not the plugin(s) inside
[ardour.git] / gtk2_ardour / route_ui.h
index 28d0f77d1bbe69ee0a002cf9b54d51058972b458..331429a00c3758041ef479b90311df957e268e8a 100644 (file)
@@ -39,6 +39,7 @@
 
 #include "axis_view.h"
 #include "selectable.h"
+#include "window_manager.h"
 
 namespace ARDOUR {
        class AudioTrack;
@@ -55,6 +56,22 @@ class ArdourButton;
 class ArdourWindow;
 class IOSelectorWindow;
 
+class RoutePinWindowProxy : public WM::ProxyBase
+{
+  public:
+       RoutePinWindowProxy (std::string const &, boost::shared_ptr<ARDOUR::Route>);
+       ~RoutePinWindowProxy();
+
+       Gtk::Window* get (bool create = false);
+       ARDOUR::SessionHandlePtr* session_handle();
+
+  private:
+       boost::weak_ptr<ARDOUR::Route> _route;
+
+       void route_going_away ();
+       PBD::ScopedConnection going_away_connection;
+};
+
 class RouteUI : public virtual AxisView
 {
   public:
@@ -115,6 +132,8 @@ class RouteUI : public virtual AxisView
        void send_blink (bool);
        sigc::connection send_blink_connection;
 
+       sigc::connection rec_blink_connection;
+
        Gtk::Menu* mute_menu;
        Gtk::Menu* solo_menu;
        Gtk::Menu* sends_menu;
@@ -155,7 +174,6 @@ class RouteUI : public virtual AxisView
 
        void solo_changed(bool, void*);
        void solo_changed_so_update_mute ();
-       void mute_changed(void*);
        void listen_changed(void*);
        virtual void processors_changed (ARDOUR::RouteProcessorChange) {}
        void route_rec_enable_changed();
@@ -186,16 +204,17 @@ class RouteUI : public virtual AxisView
 
        int  set_color_from_route ();
 
-       void remove_this_route (bool apply_to_selection = false);
-       static gint idle_remove_this_route (RouteUI *);
-
        void route_rename();
 
+       void manage_pins ();
+       void maybe_add_route_print_mgr ();
+
        virtual void property_changed (const PBD::PropertyChange&);
        void route_removed ();
 
        virtual void route_active_changed () {}
        void set_route_active (bool, bool);
+       void duplicate_selected_routes ();
 
         Gtk::Menu* record_menu;
         void build_record_menu ();
@@ -213,7 +232,7 @@ class RouteUI : public virtual AxisView
        void disconnect_input ();
        void disconnect_output ();
 
-       virtual void update_rec_display ();
+       virtual void blink_rec_display (bool onoff);
        void update_mute_display ();
 
        void update_solo_display ();
@@ -221,6 +240,7 @@ class RouteUI : public virtual AxisView
        virtual void map_frozen ();
 
        void adjust_latency ();
+       bool process_save_template_prompter (ArdourPrompter& prompter, const std::string& dir);
        void save_as_template ();
        void open_remote_control_id_dialog ();
 
@@ -241,7 +261,7 @@ class RouteUI : public virtual AxisView
        void toggle_comment_editor ();
 
        gint comment_key_release_handler (GdkEventKey*);
-       void comment_changed (void *src);
+       void comment_changed ();
        void comment_edited ();
        bool ignore_comment_edit;
 
@@ -270,13 +290,17 @@ class RouteUI : public virtual AxisView
 
        virtual void bus_send_display_changed (boost::shared_ptr<ARDOUR::Route>);
 
+       static std::string program_port_prefix;
+
   private:
        void check_rec_enable_sensitivity ();
        void parameter_changed (std::string const &);
        void relabel_solo_button ();
+       void track_mode_changed ();
 
        std::string route_state_id () const;
 
+protected:
        struct SoloMuteRelease {
            SoloMuteRelease (bool was_active)
            : active (was_active)
@@ -293,6 +317,7 @@ class RouteUI : public virtual AxisView
        SoloMuteRelease* _solo_release;
        SoloMuteRelease* _mute_release;
 
+private:
        void setup_invert_buttons ();
        void set_invert_button_state ();
        void invert_menu_toggled (uint32_t);
@@ -305,7 +330,7 @@ class RouteUI : public virtual AxisView
 
        static void set_showing_sends_to (boost::shared_ptr<ARDOUR::Route>);
        static boost::weak_ptr<ARDOUR::Route> _showing_sends_to;
-       
+
        static uint32_t _max_invert_buttons;
 };