Properly revert FormatSpec changes on "cancel"
[ardour.git] / gtk2_ardour / route_group_menu.h
index ba955f64a269f5cedf907ddd4176f94b3a2d6a05..b29114a14501acc2c47f9996d7869a8e4630c6a7 100644 (file)
 
 */
 
+#ifndef __ardour_gtk_route_group_menu_h__
+#define __ardour_gtk_route_group_menu_h__
+
 #include "ardour/route_group.h"
+#include "ardour/session_handle.h"
 
-namespace ARDOUR {
-       class Session;
-}
+class RouteGroupDialog;
 
-class RouteGroupMenu : public Gtk::Menu
+class RouteGroupMenu : public ARDOUR::SessionHandlePtr
 {
 public:
-       RouteGroupMenu (ARDOUR::Session &, ARDOUR::RouteGroup::Property);
-
-       void rebuild (ARDOUR::RouteGroup *);
+       RouteGroupMenu (ARDOUR::Session*, PBD::PropertyList*);
+       ~RouteGroupMenu();
 
-       sigc::signal<void, ARDOUR::RouteGroup*> GroupSelected;
+       Gtk::Menu* menu ();
+       void build (ARDOUR::WeakRouteList const &);
+       void detach ();
 
-private:
-       void add_item (ARDOUR::RouteGroup *, ARDOUR::RouteGroup *, Gtk::RadioMenuItem::Group*);
+  private:
+       void add_item (ARDOUR::RouteGroup *, std::set<ARDOUR::RouteGroup*> const &, Gtk::RadioMenuItem::Group*);
        void new_group ();
-       void set_group (ARDOUR::RouteGroup *);
+       void set_group (Gtk::RadioMenuItem*, ARDOUR::RouteGroup *);
+       void new_group_dialog_finished (int, RouteGroupDialog*);
 
-       ARDOUR::Session& _session;
-       ARDOUR::RouteGroup::Property _default_properties;
+       Gtk::Menu* _menu;
+
+       PBD::PropertyList* _default_properties;
+       bool _inhibit_group_selected;
+       ARDOUR::WeakRouteList _subject;
 };
+
+#endif /* __ardour_gtk_route_group_menu_h__ */