X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fardour_dialog.h;h=bd74afc47d21a6e013834b69a0ec5e18c4a20e96;hb=c78528dcea03a61685ad0586eaa6302847af6fe9;hp=d2665c0ed8797c9eb319061b1e5f11d86529f49c;hpb=08d33fcb0d35b6448ac1b5a4bcc54095cacbfccd;p=ardour.git diff --git a/gtk2_ardour/ardour_dialog.h b/gtk2_ardour/ardour_dialog.h index d2665c0ed8..bd74afc47d 100644 --- a/gtk2_ardour/ardour_dialog.h +++ b/gtk2_ardour/ardour_dialog.h @@ -20,57 +20,44 @@ #ifndef __ardour_dialog_h__ #define __ardour_dialog_h__ -#include #include #include -#include "keyboard_target.h" +#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, public KeyboardTarget +class ArdourDialog : public Gtk::Dialog, public ARDOUR::SessionHandlePtr { public: - ArdourDialog (string name); + 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(); - bool within_hiding() const { return _within_hiding; } - - void run (); - void stop (int); - void set_keyboard_input (bool yn); - void set_hide_on_stop (bool yn); - int run_status(); + 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; - - virtual void set_session (ARDOUR::Session* s) { - session = s; - } - - virtual void session_gone () { - set_session (0); - } - - void quit (); + static void close_all_dialogs () { CloseAllDialogs(); } private: - int _run_status; - bool _within_hiding; - bool kbd_input; - bool running; - bool hide_on_stop; + void init (); + + static sigc::signal CloseAllDialogs; }; #endif // __ardour_dialog_h__ +