use syntactic sugar
[ardour.git] / gtk2_ardour / group_tabs.h
index 0d83a553c177ae2a29337d62c2756034e43bd765..f6acf67301a17025ee594a074a134b4026e17e88 100644 (file)
@@ -17,6 +17,9 @@
 
 */
 
+#ifndef __gtk_ardour_group_tabs_h__
+#define __gtk_ardour_group_tabs_h__
+
 #include <gtkmm/menu.h>
 #include "editor_component.h"
 #include "gtkmm2ext/cairo_widget.h"
@@ -27,6 +30,7 @@ namespace ARDOUR {
 }
 
 class Editor;
+class RouteGroupDialog;
 
 /** Parent class for tabs which represent route groups as colored tabs;
  *  Currently used on the left-hand side of the editor and at the top of the mixer.
@@ -44,15 +48,15 @@ public:
        void set_session (ARDOUR::Session *);
 
        /** @param g Route group, or 0.
-         *  @return Menu to be popped up on right-click over the given route group.
+        *  @return Menu to be popped up on right-click over the given route group.
         */
-       Gtk::Menu* get_menu (ARDOUR::RouteGroup* g);
+       Gtk::Menu* get_menu (ARDOUR::RouteGroup* g, bool tabArea = false);
 
-       void run_new_group_dialog (ARDOUR::RouteList const &);
+       void run_new_group_dialog (ARDOUR::RouteList const *, bool with_master);
 
-       static void set_group_color (ARDOUR::RouteGroup *, Gdk::Color);
+       static void set_group_color (ARDOUR::RouteGroup *, uint32_t);
        static std::string group_gui_id (ARDOUR::RouteGroup *);
-       static Gdk::Color group_color (ARDOUR::RouteGroup *);
+       static uint32_t group_color (ARDOUR::RouteGroup *);
 
 protected:
 
@@ -61,13 +65,13 @@ protected:
 
                double from;
                double to;
-               Gdk::Color color; ///< color
+               uint32_t color; ///< color
                ARDOUR::RouteGroup* group; ///< route group
        };
 
 private:
-       static void emit_gui_changed_for_members (ARDOUR::RouteGroup *);
-       
+       static void emit_gui_changed_for_members (boost::shared_ptr<ARDOUR::RouteList>);
+
        /** Compute all the tabs for this widget.
         *  @return Tabs.
         */
@@ -77,7 +81,7 @@ private:
         *  @param cr Cairo context.
         *  @param t Tab.
         */
-       virtual void draw_tab (cairo_t* cr, Tab const & t) const = 0;
+       virtual void draw_tab (cairo_t* cr, Tab const & t) = 0;
 
        /** @param x x coordinate
         *  @param y y coordinate
@@ -91,24 +95,27 @@ private:
        virtual double extent () const = 0;
 
        virtual void add_menu_items (Gtk::Menu *, ARDOUR::RouteGroup *) {}
-       virtual PBD::PropertyList default_properties () const = 0;
        virtual ARDOUR::RouteList selected_routes () const = 0;
-       virtual void sync_order_keys () = 0;
 
-       void new_from_selection ();
-       void new_from_rec_enabled ();
-       void new_from_soloed ();
-       ARDOUR::RouteGroup* create_and_add_group () const;
+       void add_new_from_items (Gtk::Menu_Helpers::MenuList&);
+
+       void new_from_selection (bool with_master);
+       void new_from_rec_enabled (bool with_master);
+       void new_from_soloed (bool with_master);
+
+       void new_group_dialog_finished (int, RouteGroupDialog*, ARDOUR::RouteList const *, bool with_master) const;
+       void edit_group_dialog_finished (int, RouteGroupDialog*) const;
+
        void collect (ARDOUR::RouteGroup *);
        void set_activation (ARDOUR::RouteGroup *, bool);
        void edit_group (ARDOUR::RouteGroup *);
        void subgroup (ARDOUR::RouteGroup *, bool, ARDOUR::Placement);
-        void un_subgroup (ARDOUR::RouteGroup *);
+       void un_subgroup (ARDOUR::RouteGroup *);
        void activate_all ();
        void disable_all ();
        void remove_group (ARDOUR::RouteGroup *);
 
-       void render (cairo_t *, cairo_rectangle_t*);
+       void render (Cairo::RefPtr<Cairo::Context> const&, cairo_rectangle_t*);
        void on_size_request (Gtk::Requisition *);
        bool on_button_press_event (GdkEventButton *);
        bool on_motion_notify_event (GdkEventMotion *);
@@ -120,6 +127,16 @@ private:
        void route_added_to_route_group (ARDOUR::RouteGroup *, boost::weak_ptr<ARDOUR::Route>);
        void route_removed_from_route_group (ARDOUR::RouteGroup *, boost::weak_ptr<ARDOUR::Route>);
 
+       void assign_group_to_master (uint32_t which, ARDOUR::RouteGroup*, bool rename_master) const;
+       void unassign_group_to_master (uint32_t which, ARDOUR::RouteGroup*) const;
+       void assign_selection_to_master (uint32_t which);
+       void assign_recenabled_to_master (uint32_t which);
+       void assign_soloed_to_master (uint32_t which);
+       void assign_some_to_master (uint32_t which, ARDOUR::RouteList, std::string vcaname = "");
+
+       ARDOUR::RouteList get_soloed ();
+       ARDOUR::RouteList get_rec_enabled ();
+
        Gtk::Menu* _menu;
        std::list<Tab> _tabs; ///< current list of tabs
        Tab* _dragging; ///< tab being dragged, or 0
@@ -137,3 +154,5 @@ private:
        /** colors that have been used for new route group tabs */
        static std::list<Gdk::Color> _used_colors;
 };
+
+#endif // __gtk_ardour_group_tabs_h__