X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fardour_ui.h;h=d732a208b56715f8e81ff2528e4418ffb7d4cd33;hb=862cb478a2b9dfa3822c581241396582050bfa44;hp=b676faed1138532d1dad860bf17b4707ceb255a9;hpb=a505e1469d362cc32acb01252d192c73729fbc43;p=ardour.git diff --git a/gtk2_ardour/ardour_ui.h b/gtk2_ardour/ardour_ui.h index b676faed11..d732a208b5 100644 --- a/gtk2_ardour/ardour_ui.h +++ b/gtk2_ardour/ardour_ui.h @@ -15,12 +15,13 @@ along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - $Id$ */ #ifndef __ardour_gui_h__ #define __ardour_gui_h__ +#include + /* need _BSD_SOURCE to get timersub macros */ #ifdef _BSD_SOURCE @@ -32,7 +33,6 @@ #endif #include - #include #include @@ -51,54 +51,61 @@ #include #include #include +#include #include #include #include #include +#include #include #include +#include #include "audio_clock.h" #include "ardour_dialog.h" #include "editing.h" -#include "glade_factory.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 SoundFileBrowser; class About; +class Splash; class AddRouteDialog; -class NewSessionDialog; class LocationUI; -class ColorManager; +class ThemeManager; +class NewSessionDialog; namespace Gtkmm2ext { class TearOff; -}; +} namespace ARDOUR { class AudioEngine; class Route; class Port; class IO; -}; + class ControlProtocolInfo; +} namespace ALSA { class MultiChannelDevice; -}; +} #define FRAME_NAME "BaseFrame" +extern sigc::signal ColorsChanged; +extern sigc::signal 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 (); @@ -106,17 +113,24 @@ 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::Session::AutoConnectOption input_connect, - ARDOUR::Session::AutoConnectOption output_connect, + ARDOUR::AutoConnectOption input_connect, + ARDOUR::AutoConnectOption output_connect, uint32_t nphysin, uint32_t nphysout, - jack_nframes_t initial_length); + nframes_t initial_length); bool session_is_new() const { return _session_is_new; } ARDOUR::Session* the_session() { return session; } @@ -129,50 +143,44 @@ class ARDOUR_UI : public Gtkmm2ext::UI _will_create_new_session_automatically = yn; } - void new_session(bool startup = false, std::string path = string()); - gint cmdline_new_session (string path); - int unload_session (); - void close_session() { 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 (); - void toggle_tempo_window (); void toggle_editing_space(); - gint32 select_diskstream (GdkEventButton *ev); - Gtk::Tooltips& tooltips() { return _tooltips; } static sigc::signal Blink; static sigc::signal RapidScreenUpdate; static sigc::signal SuperRapidScreenUpdate; - static sigc::signal Clock; - - /* this is a helper function to centralize the (complex) logic for - blinking rec-enable buttons. - */ - - void rec_enable_button_blink (bool onoff, ARDOUR::DiskStream *, Gtk::Widget *w); + static sigc::signal Clock; void name_io_setup (ARDOUR::AudioEngine&, string&, ARDOUR::IO& io, bool in); - void choose_io (ARDOUR::IO&, bool input); - - static gint hide_and_quit (GdkEventAny *ev, ArdourDialog *); XMLNode* editor_settings() const; XMLNode* mixer_settings () const; @@ -181,46 +189,64 @@ class ARDOUR_UI : public Gtkmm2ext::UI void save_ardour_state (); gboolean configure_handler (GdkEventConfigure* conf); - void do_transport_locate (jack_nframes_t position); + 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; AudioClock preroll_clock; AudioClock postroll_clock; - void add_route (); + void store_clock_modes (); + void restore_clock_modes (); + + void add_route (Gtk::Window* float_window); - void session_add_audio_track (int input_channels, int32_t output_channels, ARDOUR::TrackMode mode) { - session_add_audio_route (true, input_channels, output_channels, mode); + void session_add_audio_track (int input_channels, int32_t output_channels, ARDOUR::TrackMode mode, uint32_t how_many) { + session_add_audio_route (true, input_channels, output_channels, mode, how_many); } - void session_add_audio_bus (int input_channels, int32_t output_channels) { - session_add_audio_route (false, input_channels, output_channels, ARDOUR::Normal); + void session_add_audio_bus (int input_channels, int32_t output_channels, uint32_t how_many) { + session_add_audio_route (false, input_channels, output_channels, ARDOUR::Normal, how_many); } void session_add_midi_track (); - void set_engine (ARDOUR::AudioEngine&); + int create_engine (); + void post_engine (); gint exit_on_main_window_close (GdkEventAny *); void maximise_editing_space (); void restore_editing_space (); + void set_native_file_header_format (ARDOUR::HeaderFormat sf); + void set_native_file_data_format (ARDOUR::SampleFormat sf); + + void setup_profile (); + void setup_theme (); + + void set_shuttle_fract (double); + protected: friend class PublicEditor; 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 (); void toggle_session_auto_loop (); - void toggle_session_punch_in (); void toggle_options_window (); @@ -254,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 online_control_strings; @@ -267,45 +291,35 @@ class ARDOUR_UI : public Gtkmm2ext::UI GlobalClickBox *crossfade_time_button; vector crossfade_time_strings; - GlobalClickBox *mmc_id_button; - vector mmc_id_strings; - Gtk::ToggleButton preroll_button; Gtk::ToggleButton postroll_button; - Gtk::Table transport_table; - Gtk::Table option_table; - int setup_windows (); - void setup_session_menu (); void setup_transport (); void setup_clock (); - void setup_session_info (); - void setup_adjustables (); - Gtk::MenuBar* make_menubar (); - 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); - gint ask_about_save_deleted (GdkEventAny*); - void save_session_choice_made (int); - 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 (); int32_t do_engine_start (); - gint start_engine (); void engine_halted (); void engine_stopped (); void engine_running (); - void clear_meters (); + void use_config (); static gint _blink (void *); void blink (); @@ -314,8 +328,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI void start_blinking (); void stop_blinking (); - void control_methods_adjusted (); - void mmc_device_id_adjusted (); + void about_signal_response(int response); + private: Gtk::VBox top_packer; @@ -328,9 +342,14 @@ 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 (); + /* Transport Control */ void detach_tearoff (Gtk::Box* parent, Gtk::Widget* contents); @@ -352,32 +371,56 @@ class ARDOUR_UI : public Gtkmm2ext::UI Gtk::HBox primary_clock_hbox; Gtk::HBox secondary_clock_hbox; - Gtkmm2ext::StatefulButton roll_button; - Gtkmm2ext::StatefulButton stop_button; - Gtkmm2ext::StatefulButton rewind_button; - Gtkmm2ext::StatefulButton forward_button; - Gtkmm2ext::StatefulButton goto_start_button; - Gtkmm2ext::StatefulButton goto_end_button; - Gtkmm2ext::StatefulButton auto_loop_button; - Gtkmm2ext::StatefulButton play_selection_button; - Gtkmm2ext::StatefulButton rec_button; + struct TransportControllable : public PBD::Controllable { + enum ToggleType { + Roll = 0, + Stop, + RecordEnable, + GotoStart, + GotoEnd, + AutoLoop, + PlaySelection, + ShuttleControl + + }; + + TransportControllable (std::string name, ARDOUR_UI&, ToggleType); + void set_value (float); + float get_value (void) const; + + void set_id (const std::string&); + + ARDOUR_UI& ui; + ToggleType type; + }; + + TransportControllable roll_controllable; + TransportControllable stop_controllable; + TransportControllable goto_start_controllable; + TransportControllable goto_end_controllable; + TransportControllable auto_loop_controllable; + TransportControllable play_selection_controllable; + TransportControllable rec_controllable; + TransportControllable shuttle_controllable; + BindingProxy shuttle_controller_binding_proxy; + + void set_transport_controllable_state (const XMLNode&); + XMLNode& get_transport_controllable_state (); + + BindableButton roll_button; + BindableButton stop_button; + BindableButton goto_start_button; + BindableButton goto_end_button; + BindableButton auto_loop_button; + BindableButton play_selection_button; + BindableButton rec_button; - Gtk::ToggleButton time_master_button; Gtk::ComboBoxText sync_option_combo; void sync_option_changed (); void toggle_time_master (); - - enum ShuttleBehaviour { - Sprung, - Wheel - }; - - enum ShuttleUnits { - Percentage, - Semitones - }; + void toggle_video_sync (); Gtk::DrawingArea shuttle_box; Gtk::EventBox speed_display_box; @@ -386,8 +429,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI Gtk::ComboBoxText shuttle_style_button; Gtk::Menu* shuttle_unit_menu; Gtk::Menu* shuttle_style_menu; - ShuttleBehaviour shuttle_behaviour; - ShuttleUnits shuttle_units; float shuttle_max_speed; Gtk::Menu* shuttle_context_menu; @@ -395,14 +436,13 @@ class ARDOUR_UI : public Gtkmm2ext::UI void show_shuttle_context_menu (); void shuttle_style_changed(); void shuttle_unit_clicked (); - void set_shuttle_behaviour (ShuttleBehaviour); - void set_shuttle_units (ShuttleUnits); void set_shuttle_max_speed (float); void update_speed_display (); float last_speed_displayed; gint shuttle_box_button_press (GdkEventButton*); gint shuttle_box_button_release (GdkEventButton*); + gint shuttle_box_scroll (GdkEventScroll*); gint shuttle_box_motion (GdkEventMotion*); gint shuttle_box_expose (GdkEventExpose*); gint mouse_shuttle (double x, bool force); @@ -411,12 +451,14 @@ class ARDOUR_UI : public Gtkmm2ext::UI bool shuttle_grabbed; double shuttle_fract; - Gtk::ToggleButton punch_in_button; - Gtk::ToggleButton punch_out_button; - Gtk::ToggleButton auto_return_button; - Gtk::ToggleButton auto_play_button; - Gtk::ToggleButton auto_input_button; - Gtk::ToggleButton click_button; + Gtkmm2ext::StatefulToggleButton punch_in_button; + Gtkmm2ext::StatefulToggleButton punch_out_button; + Gtkmm2ext::StatefulToggleButton auto_return_button; + Gtkmm2ext::StatefulToggleButton auto_play_button; + Gtkmm2ext::StatefulToggleButton auto_input_button; + Gtkmm2ext::StatefulToggleButton click_button; + Gtkmm2ext::StatefulToggleButton time_master_button; + Gtk::ToggleButton auditioning_alert_button; Gtk::ToggleButton solo_alert_button; @@ -432,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 (); @@ -439,16 +482,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI void transport_rec_enable_blink (bool onoff); - /* These change where we accept control from: - MMC, X (local) or both. - */ - - void allow_mmc_only (); - void allow_mmc_and_local (); - void allow_local_only (); - - static void rate_printer (char buf[32], Gtk::Adjustment &, void *); - Gtk::Menu* session_popup_menu; struct RecentSessionModelColumns : public Gtk::TreeModel::ColumnRecord { @@ -468,8 +501,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI Gtk::FileChooserDialog* open_session_selector; void build_session_selector(); - void recent_session_selection_changed (); void redisplay_recent_sessions(); + void recent_session_row_activated (const Gtk::TreePath& path, Gtk::TreeViewColumn* col); struct RecentSessionsSorter { bool operator() (std::pair a, std::pair b) const { @@ -483,8 +516,10 @@ 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 pack_toplevel_controls(); + void build_control_surface_menu (); Gtk::Label wall_clock_label; Gtk::EventBox wall_clock_box; @@ -498,17 +533,13 @@ class ARDOUR_UI : public Gtkmm2ext::UI Gtk::EventBox cpu_load_box; void update_cpu_load (); - Gtk::Label disk_rate_label; - Gtk::EventBox disk_rate_box; - void update_disk_rate(); - Gtk::Label buffer_load_label; Gtk::EventBox buffer_load_box; void update_buffer_load (); Gtk::Label sample_rate_label; Gtk::EventBox sample_rate_box; - void update_sample_rate (jack_nframes_t); + void update_sample_rate (nframes_t); gint every_second (); gint every_point_one_seconds (); @@ -516,31 +547,21 @@ class ARDOUR_UI : public Gtkmm2ext::UI sigc::connection second_connection; sigc::connection point_one_second_connection; + sigc::connection point_oh_five_second_connection; sigc::connection point_zero_one_second_connection; - void diskstream_added (ARDOUR::DiskStream*); - gint session_menu (GdkEventButton *); bool _will_create_new_session_automatically; - GladeRef m_new_session_dialog_ref; - NewSessionDialog* m_new_session_dialog; + NewSessionDialog* new_session_dialog; void open_session (); void open_recent_session (); - void open_ok_clicked (); - void save_template (); + void session_add_audio_route (bool disk, int32_t input_channels, int32_t output_channels, ARDOUR::TrackMode mode, uint32_t how_many); - void session_add_audio_route (bool disk, int32_t input_channels, int32_t output_channels, ARDOUR::TrackMode mode); - - void add_diskstream_to_menu (ARDOUR::DiskStream&); - void diskstream_selected (gint32); - Gtk::Menu *diskstream_menu; - gint32 selected_dstream; - void set_transport_sensitivity (bool); void remove_last_capture (); @@ -548,37 +569,28 @@ 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 toggle_roll (bool with_abort, bool roll_out_of_bounded_mode); - void transport_locating (); - void transport_rolling (); - void transport_rewinding (); - void transport_forwarding (); - void transport_stopped (); - - void send_all_midi_feedback (); - bool _session_is_new; void connect_to_session (ARDOUR::Session *); void connect_dependents_to_session (ARDOUR::Session *); void we_have_dependents (); - void setup_keybindings (); - void setup_options (); + + void setup_session_options (); guint32 last_key_press_time; void snapshot_session (); - void map_record_state (); - void queue_map_record_state (); - Mixer_UI *mixer; int create_mixer (); @@ -595,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 */ @@ -604,12 +621,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI /* route dialog */ AddRouteDialog *add_route_dialog; - void add_route_dialog_done (int status); - - /* SoundFile Browser */ - SoundFileBrowser *sfdb; - void toggle_sound_file_browser (); - int create_sound_file_browser (); /* Keyboard Handling */ @@ -617,102 +628,156 @@ class ARDOUR_UI : public Gtkmm2ext::UI /* Keymap handling */ - void install_keybindings (); - Glib::RefPtr get_common_actions(); void install_actions (); - void test_binding_action (const char *); - void start_keyboard_prefix(); - void toggle_record_enable (guint32); - void toggle_monitor_enable (guint32); + void toggle_record_enable (uint32_t); - uint32_t rec_enabled_diskstreams; - void count_recenabled_diskstreams (ARDOUR::DiskStream&); + uint32_t rec_enabled_streams; + 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; - void cannot_record_no_input (ARDOUR::DiskStream*); + struct DiskBufferStat { + time_t when; + uint32_t capture; + uint32_t playback; - void delete_sources_in_the_right_thread (list*); - - void editor_display_control_changed (Editing::DisplayControl c); - - bool have_disk_overrun_displayed; - bool have_disk_underrun_displayed; + DiskBufferStat (time_t w, uint32_t c, uint32_t p) + : when (w), capture (c), playback (p) {} + }; + + std::list disk_buffer_stats; + void push_buffer_stats (uint32_t, uint32_t); + void write_buffer_stats (); - void disk_overrun_message_gone (); - void disk_underrun_message_gone (); + 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 (); - void set_jack_buffer_size (jack_nframes_t); + void set_jack_buffer_size (nframes_t); Gtk::MenuItem* jack_disconnect_item; 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 common_actions; void editor_realized (); std::vector positional_sync_strings; - void toggle_config_state (const char* group, const char* action, void (ARDOUR::Configuration::*set)(bool)); - void toggle_session_state (const char* group, const char* action, void (ARDOUR::Session::*set)(bool), bool (ARDOUR::Session::*get)(void) const); - void toggle_session_state (const char* group, const char* action, sigc::slot theSlot); void toggle_send_midi_feedback (); void toggle_use_mmc (); void toggle_send_mmc (); - void toggle_use_midi_control(); void toggle_send_mtc (); - void toggle_AutoConnectNewTrackInputsToHardware(); - void toggle_AutoConnectNewTrackOutputsToHardware(); - void toggle_AutoConnectNewTrackOutputsToMaster(); - void toggle_ManuallyConnectNewTrackOutputs(); - void toggle_UseHardwareMonitoring(); - void toggle_UseSoftwareMonitoring(); - void toggle_UseExternalMonitoring(); + 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_SoloViaBus(); - void toggle_AutomaticallyCreateCrossfades(); - void toggle_UnmuteNewFullCrossfades(); + 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_some_session_state (const char* group, const char* action, bool (ARDOUR::Session::*get)() const); - void queue_session_control_changed (ARDOUR::Session::ControlType t); - void session_control_changed (ARDOUR::Session::ControlType t); + 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); + void set_meter_falloff (ARDOUR::MeterFalloff); + void map_meter_hold (); + void map_meter_falloff (); + + void toggle_control_protocol (ARDOUR::ControlProtocolInfo*); + void toggle_control_protocol_feedback (ARDOUR::ControlProtocolInfo*, const char* group_name, std::string action_name); + + 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 ptag, Glib::RefPtr 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__ */ +