the "final" (??) fixes for transport state stuff before 2.8.4. y'all let me know...
[ardour.git] / gtk2_ardour / ardour_ui.h
index 599debaf1eaf64ca40cdbba52b5d6e03c1c30bba..d732a208b56715f8e81ff2528e4418ffb7d4cd33 100644 (file)
@@ -20,6 +20,8 @@
 #ifndef __ardour_gui_h__
 #define __ardour_gui_h__
 
+#include <time.h>
+
 /* need _BSD_SOURCE to get timersub macros */
 
 #ifdef _BSD_SOURCE
@@ -31,7 +33,6 @@
 #endif
 
 #include <list>
-
 #include <cmath>
 
 #include <libgnomecanvasmm/canvas.h>
@@ -50,6 +51,7 @@
 #include <gtkmm/togglebutton.h>
 #include <gtkmm/treeview.h>
 #include <gtkmm/menubar.h>
+#include <gtkmm/textbuffer.h>
 #include <gtkmm/adjustment.h>
 #include <gtkmm2ext/gtk_ui.h>
 #include <gtkmm2ext/click_box.h>
 #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"
 #include "editing.h"
+#include "ui_config.h"
 
 class AudioClock;
 class PublicEditor;
 class Keyboard;
-class MeterBridge;
 class OptionEditor;
+class KeyEditor;
 class Mixer_UI;
 class ConnectionEditor;
 class RouteParams_UI;
 class About;
+class Splash;
 class AddRouteDialog;
-class NewSessionDialog;
 class LocationUI;
-class ColorManager;
+class ThemeManager;
+class NewSessionDialog;
 
 namespace Gtkmm2ext {
        class TearOff;
@@ -94,10 +99,13 @@ namespace ALSA {
 
 #define FRAME_NAME "BaseFrame"
 
+extern sigc::signal<void>  ColorsChanged;
+extern sigc::signal<void>  DPIReset;
+
 class ARDOUR_UI : public Gtkmm2ext::UI
 {
   public:
-       ARDOUR_UI (int *argcp, char **argvp[], string rcfile);
+       ARDOUR_UI (int *argcp, char **argvp[]);
        ~ARDOUR_UI();
 
        void show ();
@@ -105,10 +113,17 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        
        void show_splash ();
        void hide_splash ();
+
+       void launch_chat ();
+       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,
@@ -128,25 +143,31 @@ class ARDOUR_UI : public Gtkmm2ext::UI
                _will_create_new_session_automatically = yn;
        }
 
-        void new_session(std::string path = string());
-       gint cmdline_new_session (string path);
-       int  unload_session ();
+       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);
 
        static ARDOUR_UI *instance () { return theArdourUI; }
+       static UIConfiguration *config () { return ui_config; }
 
        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_color_manager ();
+       void toggle_theme_manager ();
        void toggle_big_clock_window ();
        void toggle_connection_editor ();
        void toggle_route_params_window ();
@@ -156,20 +177,11 @@ class ARDOUR_UI : public Gtkmm2ext::UI
 
        static sigc::signal<void,bool> Blink;
        static sigc::signal<void>      RapidScreenUpdate;
-       static sigc::signal<void>      MidRapidScreenUpdate;
        static sigc::signal<void>      SuperRapidScreenUpdate;
-       static sigc::signal<void,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);
+       static sigc::signal<void,nframes_t, bool, nframes_t> Clock;
 
        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;
@@ -179,6 +191,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;
@@ -200,8 +214,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI
 
        void session_add_midi_track ();
 
-       void set_engine (ARDOUR::AudioEngine&);
-       gint start_engine ();
+       int  create_engine ();
+       void post_engine ();
 
        gint exit_on_main_window_close (GdkEventAny *);
 
@@ -211,8 +225,10 @@ 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 ();
+
+       void set_shuttle_fract (double);
 
   protected:
        friend class PublicEditor;
@@ -220,8 +236,13 @@ 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 show_loop_punch_ruler_and_disallow_hide ();
+       void reenable_hide_loop_punch_ruler_if_appropriate ();
        void toggle_auto_return ();
        void toggle_click ();
 
@@ -259,12 +280,10 @@ class ARDOUR_UI : public Gtkmm2ext::UI
 
        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;
@@ -275,21 +294,22 @@ 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 ();
 
        static ARDOUR_UI *theArdourUI;
 
+       void backend_audio_error (bool we_set_params, Gtk::Window* toplevel = 0);
        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();
+       void update_autosave();
+       sigc::connection _autosave_connection;
 
        void queue_transport_change ();
        void map_transport_state ();
@@ -310,6 +330,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI
 
        void about_signal_response(int response);
 
+
   private:
        Gtk::VBox     top_packer;
 
@@ -321,9 +342,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 ();
 
@@ -424,7 +447,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        gint shuttle_box_expose (GdkEventExpose*);
        gint mouse_shuttle (double x, bool force);
        void use_shuttle_fract (bool force);
-       void set_shuttle_fract (double);
 
        bool   shuttle_grabbed;
        double shuttle_fract;
@@ -452,6 +474,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 ();
 
@@ -493,6 +516,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        Gtk::EventBox menu_bar_base;
        Gtk::HBox     menu_hbox;
 
+       void use_menubar_as_top_menubar ();
+
        void build_menu_bar ();
        void build_control_surface_menu ();
 
@@ -518,7 +543,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI
 
        gint every_second ();
        gint every_point_one_seconds ();
-       gint every_point_oh_five_seconds ();
        gint every_point_zero_one_seconds ();
 
        sigc::connection second_connection;
@@ -545,28 +569,22 @@ 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);
        void transport_rewind (int option);
        void transport_loop ();
-
-       void transport_rolling ();
-       void transport_rewinding ();
-       void transport_forwarding ();
-       void transport_stopped ();
+       void toggle_roll (bool with_abort, bool roll_out_of_bounded_mode);
 
        bool _session_is_new;
        void connect_to_session (ARDOUR::Session *);
        void connect_dependents_to_session (ARDOUR::Session *);
        void we_have_dependents ();
        
-       std::string keybindings_path;
-
-       void setup_keybindings ();
        void setup_session_options ();
        
        guint32  last_key_press_time;
@@ -589,7 +607,12 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        int         create_location_ui ();
        void        handle_locations_change (ARDOUR::Location*);
 
-       ColorManager* color_manager;
+       static UIConfiguration *ui_config;
+       ThemeManager *theme_manager;
+
+       /* Key bindings editor */
+
+       KeyEditor *key_editor;
 
        /* Options window */
        
@@ -613,28 +636,49 @@ 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;
 
-       void display_cleanup_results (ARDOUR::Session::cleanup_report& rep, const gchar* list_title, const string & msg);
+       void display_cleanup_results (ARDOUR::Session::cleanup_report& rep, const gchar* list_title, 
+                                     const string& plural_msg, const string& singular_msg);
        void cleanup ();
        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;
+
+       struct DiskBufferStat {
+           time_t when;
+           uint32_t capture;
+           uint32_t playback;
+
+           DiskBufferStat (time_t w, uint32_t c, uint32_t p) 
+           : when (w), capture (c), playback (p) {}
+       };
+       
+       std::list<DiskBufferStat> disk_buffer_stats;
+       void push_buffer_stats (uint32_t, uint32_t);
+       void write_buffer_stats ();
 
        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 ();
@@ -644,9 +688,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 ();
@@ -656,34 +697,56 @@ class ARDOUR_UI : public Gtkmm2ext::UI
        void toggle_send_midi_feedback ();
        void toggle_use_mmc ();
        void toggle_send_mmc ();
-       void toggle_use_midi_control();
        void toggle_send_mtc ();
 
+       void toggle_use_osc ();
+
+       void toggle_denormal_protection ();
+
        void set_input_auto_connect (ARDOUR::AutoConnectOption);
        void set_output_auto_connect (ARDOUR::AutoConnectOption);
        void set_solo_model (ARDOUR::SoloModel);
        void set_monitor_model (ARDOUR::MonitorModel);
        void set_remote_model (ARDOUR::RemoteModel);
+       void set_denormal_model (ARDOUR::DenormalModel);
 
+       void toggle_seamless_loop ();
+       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 ();
        void map_monitor_model ();
+       void map_denormal_model ();
+       void map_denormal_protection ();
        void map_remote_model ();
        void map_file_header_format ();
        void map_file_data_format ();
        void map_input_auto_connect ();
        void map_output_auto_connect ();
+       void map_only_copy_imported_files ();
        void parameter_changed (const char*);
 
        void set_meter_hold (ARDOUR::MeterHold);
@@ -694,11 +757,26 @@ 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;
+       bool status_bar_button_press (GdkEventButton*);
+       Gtk::ToggleButton error_log_button;
+       
+       void loading_message (const std::string& msg);
+       void end_loading_messages ();
+
+       void platform_specific ();
+       void platform_setup ();
+       void fontconfig_dialog ();
 };
 
 #endif /* __ardour_gui_h__ */