extend strict-i/o to include route outputs.
[ardour.git] / gtk2_ardour / mixer_ui.h
index 7431c030b60ce8b985312413e919f5174cea9097..916ef5aa21bea6255d05eaf4992686f0be8b0538 100644 (file)
 #include "ardour/plugin.h"
 #include "ardour/plugin_manager.h"
 
-#include "gtkmm2ext/visibility_tracker.h"
+
 #include "gtkmm2ext/dndtreeview.h"
 #include "gtkmm2ext/treeutils.h"
 
+#include "gtkmm2ext/tabbable.h"
+
 #include "enums.h"
 #include "mixer_actor.h"
 
@@ -59,12 +61,28 @@ class PluginSelector;
 class MixerGroupTabs;
 class MonitorSection;
 
-class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public ARDOUR::SessionHandlePtr, public MixerActor, public Gtkmm2ext::VisibilityTracker
+class PluginTreeStore : public Gtk::TreeStore
+{
+public:
+       static Glib::RefPtr<PluginTreeStore> create(const Gtk::TreeModelColumnRecord& columns) {
+               return Glib::RefPtr<PluginTreeStore> (new PluginTreeStore (columns));
+       }
+
+protected:
+       PluginTreeStore (const Gtk::TreeModelColumnRecord& columns) : Gtk::TreeStore (columns) {}
+       virtual bool row_draggable_vfunc (const Gtk::TreeModel::Path&) const { return true; }
+       virtual bool row_drop_possible_vfunc (const Gtk::TreeModel::Path&, const Gtk::SelectionData&) const;
+};
+
+class Mixer_UI : public Gtkmm2ext::Tabbable, public PBD::ScopedConnectionList, public ARDOUR::SessionHandlePtr, public MixerActor
 {
   public:
        static Mixer_UI* instance();
        ~Mixer_UI();
 
+       Gtk::Window* use_own_window (bool and_fill_it);
+       void show_window ();
+
        void set_session (ARDOUR::Session *);
        void track_editor_selection ();
 
@@ -76,22 +94,18 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR
        void unselect_strip_in_display (MixerStrip*);
        void select_strip_in_display (MixerStrip*);
 
-       XMLNode& get_state (void);
-       int set_state (const XMLNode& );
+       XMLNode& get_state ();
+       int set_state (const XMLNode&, int /* version */);
 
        void show_mixer_list (bool yn);
        void show_monitor_section (bool);
-       
-       void show_window ();
-       bool hide_window (GdkEventAny *ev);
+
        void show_strip (MixerStrip *);
        void hide_strip (MixerStrip *);
 
        void maximise_mixer_space();
        void restore_mixer_space();
 
-       void ensure_float (Gtk::Window&);
-
         MonitorSection* monitor_section() const { return _monitor_section; }
 
        void deselect_all_strip_processors();
@@ -99,22 +113,22 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR
 
        void select_none ();
 
+       bool window_not_visible () const;
+
   protected:
        void set_route_targets_for_operation ();
 
   private:
        Mixer_UI ();
-       static Mixer_UI* _instance;
-
-       bool                                    _visible;
-
-       Gtk::HBox                               global_hpacker;
-       Gtk::VBox                               global_vpacker;
-       Gtk::ScrolledWindow             scroller;
-       Gtk::EventBox                   scroller_base;
-       Gtk::HBox                               scroller_hpacker;
-       Gtk::VBox                               mixer_scroller_vpacker;
-       Gtk::VBox                               list_vpacker;
+       static Mixer_UI*     _instance;
+       Gtk::VBox            _content;
+       Gtk::HBox             global_hpacker;
+       Gtk::VBox             global_vpacker;
+       Gtk::ScrolledWindow   scroller;
+       Gtk::EventBox         scroller_base;
+       Gtk::HBox             scroller_hpacker;
+       Gtk::VBox             mixer_scroller_vpacker;
+       Gtk::VBox             list_vpacker;
        Gtk::Label                              group_display_button_label;
        Gtk::Button                             group_display_button;
        Gtk::ScrolledWindow             track_display_scroller;
@@ -138,8 +152,6 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR
        void set_window_pos_and_size ();
        void get_window_pos_and_size ();
 
-       bool on_key_press_event (GdkEventKey*);
-       bool on_key_release_event (GdkEventKey*);
        bool on_scroll_event (GdkEventScroll*);
 
        void pane_allocation_handler (Gtk::Allocation&, Gtk::Paned*);
@@ -185,6 +197,24 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR
        void track_list_delete (const Gtk::TreeModel::Path&);
        void track_list_reorder (const Gtk::TreeModel::Path& path, const Gtk::TreeModel::iterator& iter, int* new_order);
 
+       void plugin_row_activated (const Gtk::TreeModel::Path& path, Gtk::TreeViewColumn* column);
+       bool plugin_row_button_press (GdkEventButton*);
+       void popup_note_context_menu (GdkEventButton*);
+       void plugin_drop (const Glib::RefPtr<Gdk::DragContext>&, const Gtk::SelectionData& data);
+
+       enum ProcessorPosition {
+               AddTop,
+               AddPreFader,
+               AddPostFader,
+               AddBottom
+       };
+
+       void add_selected_processor (ProcessorPosition);
+       void add_favorite_processor (ARDOUR::PluginPresetPtr, ProcessorPosition);
+       void remove_selected_from_favorites ();
+       void delete_selected_preset ();
+       ARDOUR::PluginPresetPtr selected_plugin ();
+
        void initial_track_display ();
        void show_track_list_menu ();
 
@@ -259,9 +289,11 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR
                    add (plugin);
            }
            Gtk::TreeModelColumn<std::string> name;
-                       Gtk::TreeModelColumn<ARDOUR::PluginInfoPtr> plugin;
+                       Gtk::TreeModelColumn<ARDOUR::PluginPresetPtr> plugin;
        };
 
+       ARDOUR::PluginInfoList favorite_order;
+       std::map<std::string, bool> favorite_ui_state;
 
        TrackDisplayModelColumns    track_columns;
        GroupDisplayModelColumns    group_columns;
@@ -269,11 +301,11 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR
 
        Gtk::TreeView track_display;
        Gtk::TreeView group_display;
-       Gtkmm2ext::DnDTreeView<ARDOUR::PluginInfoPtr> favorite_plugins_display;
+       Gtkmm2ext::DnDTreeView<ARDOUR::PluginPresetPtr> favorite_plugins_display;
 
        Glib::RefPtr<Gtk::ListStore> track_model;
        Glib::RefPtr<Gtk::ListStore> group_model;
-       Glib::RefPtr<Gtk::ListStore> favorite_plugins_model;
+       Glib::RefPtr<PluginTreeStore> favorite_plugins_model;
 
        bool group_display_button_press (GdkEventButton*);
        void group_display_selection_changed ();
@@ -317,8 +349,12 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR
        void monitor_section_attached ();
        void monitor_section_detached ();
 
-       void refiller (ARDOUR::PluginManager& manager, const ARDOUR::PluginInfoList& plugs);
+       void store_current_favorite_order();
+       void refiller (ARDOUR::PluginInfoList& result, const ARDOUR::PluginInfoList& plugs);
        void refill_favorite_plugins ();
+       void sync_treeview_from_favorite_order ();
+       void sync_treeview_favorite_ui_state (const Gtk::TreeModel::Path&, const Gtk::TreeModel::iterator&);
+       void save_favorite_ui_state (const Gtk::TreeModel::iterator& iter, const Gtk::TreeModel::Path& path);
 
        /// true if we are in fullscreen mode
        bool _maximised;
@@ -328,5 +364,3 @@ class Mixer_UI : public Gtk::Window, public PBD::ScopedConnectionList, public AR
 };
 
 #endif /* __ardour_mixer_ui_h__ */
-
-