X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fardour_dialog.h;h=bd74afc47d21a6e013834b69a0ec5e18c4a20e96;hb=157c2a866c166b94b65da442b8c54f5ffa8d6a53;hp=069768c1436b245e66cc69f6cf15f9bfadd77d61;hpb=433d9a5fc3538aa170d3ad1cb11929c0e5e94567;p=ardour.git diff --git a/gtk2_ardour/ardour_dialog.h b/gtk2_ardour/ardour_dialog.h index 069768c143..bd74afc47d 100644 --- a/gtk2_ardour/ardour_dialog.h +++ b/gtk2_ardour/ardour_dialog.h @@ -20,38 +20,43 @@ #ifndef __ardour_dialog_h__ #define __ardour_dialog_h__ -#include #include #include +#include "ardour/ardour.h" +#include "ardour/session_handle.h" + namespace ARDOUR { class Session; } /* * This virtual parent class is so that each dialog box uses the - * same mechanism to declare its closing, and to have a common - * method of connecting and disconnecting from a Session. + * same mechanism to declare its closing. It shares a common + * method of connecting and disconnecting from a Session with + * all other objects that have a handle on a Session. */ -class ArdourDialog : public Gtk::Dialog +class ArdourDialog : public Gtk::Dialog, public ARDOUR::SessionHandlePtr { public: ArdourDialog (std::string title, bool modal = false, bool use_separator = false); + ArdourDialog (Gtk::Window& parent, std::string title, bool modal = false, bool use_separator = false); ~ArdourDialog(); + static int close_all_current_dialogs (int response); + + bool on_key_press_event (GdkEventKey *); bool on_enter_notify_event (GdkEventCrossing*); bool on_leave_notify_event (GdkEventCrossing*); void on_unmap (); + void on_show (); - ARDOUR::Session *session; + static void close_all_dialogs () { CloseAllDialogs(); } - virtual void set_session (ARDOUR::Session* s) { - session = s; - } + private: + void init (); - virtual void session_gone () { - set_session (0); - } + static sigc::signal CloseAllDialogs; }; #endif // __ardour_dialog_h__