make GTKOSX button2 emulation actually work when clicking on redirect names
[ardour.git] / gtk2_ardour / ardour_ui.h
index 4d9da2044cf2adec369eba7a27767eede6377fbc..a0c84a18d840d37dd6c054057f17b8b46b5bd66b 100644 (file)
@@ -58,6 +58,7 @@
 #include <gtkmm2ext/bindable_button.h>
 #include <ardour/ardour.h>
 #include <ardour/session.h>
+#include <ardour/types.h>
 
 #include "audio_clock.h"
 #include "ardour_dialog.h"
@@ -73,6 +74,7 @@ class Mixer_UI;
 class ConnectionEditor;
 class RouteParams_UI;
 class About;
+class Splash;
 class AddRouteDialog;
 class LocationUI;
 class ThemeManager;
@@ -97,6 +99,7 @@ namespace ALSA {
 #define FRAME_NAME "BaseFrame"
 
 extern sigc::signal<void>  ColorsChanged;
+extern sigc::signal<void>  DPIReset;
 
 class ARDOUR_UI : public Gtkmm2ext::UI
 {
@@ -109,10 +112,16 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        
        void show_splash ();
        void hide_splash ();
+
+       void show_about ();
+       void hide_about ();
        
-       int load_session (const string & path, const string & snapshot, string* mix_template = 0);
+       void idle_load (const Glib::ustring& path);
+       void finish();
+
+       int load_session (const Glib::ustring& path, const Glib::ustring& snapshot, Glib::ustring mix_template = Glib::ustring());
        bool session_loaded;
-       int build_session (const string & path, const string & snapshot, 
+       int build_session (const Glib::ustring& path, const Glib::ustring& snapshot, 
                           uint32_t ctl_chns, 
                           uint32_t master_chns,
                           ARDOUR::AutoConnectOption input_connect,
@@ -132,14 +141,16 @@ class ARDOUR_UI : public Gtkmm2ext::UI
                _will_create_new_session_automatically = yn;
        }
 
-       bool get_session_parameters (Glib::ustring path, bool have_engine = false, bool should_be_new = false);
-       gint cmdline_new_session (string path);
+       bool get_session_parameters (bool have_engine = false, bool should_be_new = false);
+       void parse_cmdline_path (const Glib::ustring& cmdline_path, Glib::ustring& session_name, Glib::ustring& session_path, bool& existing_session);
+       int  load_cmdline_session (const Glib::ustring& session_name, const Glib::ustring& session_path, bool& existing_session);
+       int  build_session_from_nsd (const Glib::ustring& session_name, const Glib::ustring& session_path);
+       bool ask_about_loading_existing_session (const Glib::ustring& session_path);
        int  unload_session (bool hide_stuff = false);
        void close_session(); 
 
        int  save_state_canfail (string state_name = "");
        void save_state (const string & state_name = "");
-       void restore_state (string state_name = "");
 
        static double gain_to_slider_position (ARDOUR::gain_t g);
         static ARDOUR::gain_t slider_position_to_gain (double pos);
@@ -149,7 +160,9 @@ class ARDOUR_UI : public Gtkmm2ext::UI
 
        PublicEditor&     the_editor(){return *editor;}
        Mixer_UI* the_mixer() { return mixer; }
-       
+
+       ARDOUR::AudioEngine& the_engine() const { return *engine; }
+
        void toggle_key_editor ();
        void toggle_location_window ();
        void toggle_theme_manager ();
@@ -165,16 +178,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        static sigc::signal<void>      SuperRapidScreenUpdate;
        static sigc::signal<void,nframes_t, bool, nframes_t> Clock;
 
-       /* this is a helper function to centralize the (complex) logic for
-          blinking rec-enable buttons.
-       */
-
-       void rec_enable_button_blink (bool onoff, ARDOUR::AudioDiskstream *, Gtk::Widget *w);
-
        void name_io_setup (ARDOUR::AudioEngine&, string&, ARDOUR::IO& io, bool in);
 
-       static gint hide_and_quit (GdkEventAny *ev, ArdourDialog *);
-
        XMLNode* editor_settings() const;
        XMLNode* mixer_settings () const;
        XMLNode* keyboard_settings () const;
@@ -184,6 +189,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI
 
        void do_transport_locate (nframes_t position);
        void halt_on_xrun_message ();
+       void xrun_handler (nframes_t);
+       void create_xrun_marker (nframes_t);
 
        AudioClock primary_clock;
        AudioClock secondary_clock;
@@ -216,9 +223,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        void set_native_file_header_format (ARDOUR::HeaderFormat sf);
        void set_native_file_data_format (ARDOUR::SampleFormat sf);
 
-       void set_keybindings_path (std::string path);
-       void save_keybindings ();
-
        void setup_profile ();
        void setup_theme ();
 
@@ -230,6 +234,9 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        void toggle_clocking ();
        void toggle_auto_play ();
        void toggle_auto_input ();
+       void toggle_punch ();
+       void unset_dual_punch ();
+       bool ignore_dual_punch;
        void toggle_punch_in ();
        void toggle_punch_out ();
        void toggle_auto_return ();
@@ -267,16 +274,12 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        ARDOUR::AudioEngine                 *engine;
        ARDOUR::Session                     *session;
 
-       bool check_audioengine();
-
        Gtk::Tooltips          _tooltips;
 
-       void                     goto_editor_window ();
-       void                     goto_mixer_window ();
-       
-       Gtk::Table               adjuster_table;
-       Gtk::Frame               adjuster_frame;
-       Gtk::Fixed               adjuster_base;
+       void                goto_editor_window ();
+       void                goto_mixer_window ();
+       void                toggle_editor_mixer_on_top ();
+       bool                _mixer_on_top;
 
        GlobalClickBox     *online_control_button;
        vector<string>      online_control_strings;
@@ -287,9 +290,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        Gtk::ToggleButton   preroll_button;
        Gtk::ToggleButton   postroll_button;
 
-       Gtk::Table          transport_table;
-       Gtk::Table          option_table;
-
        int  setup_windows ();
        void setup_transport ();
        void setup_clock ();
@@ -300,9 +300,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        void startup ();
        void shutdown ();
 
-       void finish();
        int  ask_about_saving_session (const string & why);
-       int  save_the_session;
 
        /* periodic safety backup, to be precise */
        gint autosave_session();
@@ -340,9 +338,11 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        void manage_window (Gtk::Window&);
        
        AudioClock   big_clock;
-       Gtk::Frame   big_clock_frame;
        Gtk::Window* big_clock_window;
 
+       void float_big_clock (Gtk::Window* parent);
+       bool main_window_state_event_handler (GdkEventWindowState*, bool window_was_editor);
+
        void update_transport_clocks (nframes_t pos);
        void record_state_changed ();
 
@@ -470,6 +470,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        void solo_alert_toggle ();
        void audition_alert_toggle ();
 
+       void big_clock_value_changed ();
        void primary_clock_value_changed ();
        void secondary_clock_value_changed ();
 
@@ -564,9 +565,10 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        void transport_goto_zero ();
        void transport_goto_start ();
        void transport_goto_end ();
+       void transport_goto_wallclock ();
        void transport_stop ();
        void transport_stop_and_forget_capture ();
-       void transport_record ();
+       void transport_record (bool roll);
        void transport_roll ();
        void transport_play_selection(); 
        void transport_forward (int option);
@@ -583,10 +585,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        void connect_dependents_to_session (ARDOUR::Session *);
        void we_have_dependents ();
        
-       std::string keybindings_path;
-       std::string user_keybindings_path;
-
-       void setup_keybindings ();
        void setup_session_options ();
        
        guint32  last_key_press_time;
@@ -638,7 +636,10 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        void count_recenabled_streams (ARDOUR::Route&);
 
        About* about;
+       Splash* splash;
+       void pop_back_splash ();
        bool shown_flag;
+
        /* cleanup */
 
        Gtk::MenuItem *cleanup_item;
@@ -648,18 +649,22 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        void flush_trash ();
 
        bool have_configure_timeout;
-       struct timeval last_configure_time;
+       ARDOUR::microseconds_t last_configure_time;
        gint configure_timeout ();
 
-       struct timeval last_peak_grab;
-       struct timeval last_shuttle_request;
+       ARDOUR::microseconds_t last_peak_grab;
+       ARDOUR::microseconds_t last_shuttle_request;
 
        bool have_disk_speed_dialog_displayed;
        void disk_speed_dialog_gone (int ignored_response, Gtk::MessageDialog*);
        void disk_overrun_handler ();
        void disk_underrun_handler ();
+       
+       bool preset_file_exists_handler ();
 
+       void session_dialog (std::string);
        int pending_state_dialog ();
+       int sr_mismatch_dialog (nframes_t, nframes_t);
        
        void disconnect_from_jack ();
        void reconnect_to_jack ();
@@ -669,9 +674,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        Gtk::MenuItem* jack_reconnect_item;
        Gtk::Menu*     jack_bufsize_menu;
 
-       int make_session_clean ();
-       bool filter_ardour_session_dirs (const Gtk::FileFilter::Info&);
-
        Glib::RefPtr<Gtk::ActionGroup> common_actions;
 
        void editor_realized ();
@@ -695,21 +697,29 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        void set_denormal_model (ARDOUR::DenormalModel);
 
        void toggle_sync_order_keys ();
+       void toggle_new_plugins_active();
        void toggle_StopPluginsWithTransport();
        void toggle_DoNotRunPluginsWhileRecording();
        void toggle_VerifyRemoveLastCapture();
        void toggle_PeriodicSafetyBackups();
        void toggle_StopRecordingOnXrun();
+       void toggle_CreateXrunMarker();
        void toggle_StopTransportAtEndOfSession();
        void toggle_GainReduceFastTransport();
        void toggle_LatchedSolo();
        void toggle_ShowSoloMutes();
+       void toggle_SoloMuteOverride();
        void toggle_LatchedRecordEnable ();
        void toggle_RegionEquivalentsOverlap ();
        void toggle_PrimaryClockDeltaEditCursor ();
        void toggle_SecondaryClockDeltaEditCursor ();
        void toggle_only_copy_imported_files ();
        void toggle_ShowTrackMeters ();
+       void toggle_use_narrow_ms();
+       void toggle_NameNewMarkers ();
+       void toggle_rubberbanding_snaps_to_grid ();
+       void toggle_auto_analyse_audio ();
+       void toggle_TapeMachineMode();
 
        void mtc_port_changed ();
        void map_solo_model ();
@@ -732,21 +742,25 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        void toggle_control_protocol (ARDOUR::ControlProtocolInfo*);
        void toggle_control_protocol_feedback (ARDOUR::ControlProtocolInfo*, const char* group_name, std::string action_name);
 
-       bool can_save_keybindings;
        bool first_idle ();
 
        void no_memory_warning ();
        void check_memory_locking ();
 
+       bool check_audioengine();
        void audioengine_setup ();
 
        void display_message (const char *prefix, gint prefix_len, 
                              Glib::RefPtr<Gtk::TextBuffer::Tag> ptag, Glib::RefPtr<Gtk::TextBuffer::Tag> mtag, const char *msg);
        Gtk::Label status_bar_label;
        Gtk::ToggleButton error_log_button;
-       Gtk::MessageDialog* loading_dialog;
+       
+       void loading_message (const std::string& msg);
+       void end_loading_messages ();
 
        void platform_specific ();
+       void platform_setup ();
+       void fontconfig_dialog ();
 };
 
 #endif /* __ardour_gui_h__ */