X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fardour_ui.h;h=3a7e3d77517a7190acfd2e5815550eb66b860acc;hb=f7bff95fbce75cb0d4c717b1400677edd814f7be;hp=343b94078166736e01e505e9796a632a8765b661;hpb=f0bf3a0c190ced488d1520435df8234ef50971d6;p=ardour.git diff --git a/gtk2_ardour/ardour_ui.h b/gtk2_ardour/ardour_ui.h index 343b940781..3a7e3d7751 100644 --- a/gtk2_ardour/ardour_ui.h +++ b/gtk2_ardour/ardour_ui.h @@ -59,52 +59,55 @@ #include #include #include "ardour/ardour.h" -#include "ardour/session.h" #include "ardour/types.h" +#include "ardour/utils.h" +#include "ardour/session_handle.h" #include "audio_clock.h" #include "ardour_dialog.h" #include "editing.h" #include "ui_config.h" +class About; +class AddRouteDialog; +class ArdourStartup; +class ArdourKeyboard; class AudioClock; -class PublicEditor; -class Keyboard; -class RCOptionEditor; -class SessionOptionEditor; +class BundleManager; +class ConnectionEditor; class KeyEditor; +class LocationUIWindow; class Mixer_UI; -class ConnectionEditor; +class PublicEditor; +class RCOptionEditor; class RouteParams_UI; -class About; +class SessionOptionEditor; class Splash; -class AddRouteDialog; -class LocationUI; class ThemeManager; -class BundleManager; -class ArdourStartup; namespace Gtkmm2ext { class TearOff; } namespace ARDOUR { - class Route; - class Port; - class IO; class ControlProtocolInfo; + class IO; + class Port; + class Route; + class RouteGroup; + class Location; } extern sigc::signal ColorsChanged; extern sigc::signal DPIReset; -class ARDOUR_UI : public Gtkmm2ext::UI +class ARDOUR_UI : public Gtkmm2ext::UI, public ARDOUR::SessionHandlePtr { public: ARDOUR_UI (int *argcp, char **argvp[]); ~ARDOUR_UI(); - void run_startup (bool should_be_new); + bool run_startup (bool should_be_new); void show (); bool shown() { return shown_flag; } @@ -112,24 +115,19 @@ class ARDOUR_UI : public Gtkmm2ext::UI void show_splash (); void hide_splash (); + void launch_chat (); void show_about (); void hide_about (); + 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 Glib::ustring& path, const Glib::ustring& snapshot, - uint32_t ctl_chns, - uint32_t master_chns, - ARDOUR::AutoConnectOption input_connect, - ARDOUR::AutoConnectOption output_connect, - uint32_t nphysin, - uint32_t nphysout, - nframes_t initial_length); + int build_session (const Glib::ustring& path, const Glib::ustring& snapshot, ARDOUR::BusProfile&); bool session_is_new() const { return _session_is_new; } - ARDOUR::Session* the_session() { return session; } + ARDOUR::Session* the_session() { return _session; } bool will_create_new_session_automatically() const { return _will_create_new_session_automatically; @@ -138,8 +136,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI void set_will_create_new_session_automatically (bool yn) { _will_create_new_session_automatically = yn; } - - int get_session_parameters (bool should_be_new = false); + + int get_session_parameters (bool quit_on_cancel, 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); @@ -149,8 +147,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI int unload_session (bool hide_stuff = false); void close_session(); - int save_state_canfail (std::string state_name = ""); - void save_state (const std::string & state_name = ""); + int save_state_canfail (std::string state_name = "", bool switch_to_it = false); + void save_state (const std::string & state_name = "", bool switch_to_it = false); static double gain_to_slider_position (ARDOUR::gain_t g); static ARDOUR::gain_t slider_position_to_gain (double pos); @@ -179,6 +177,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI XMLNode* editor_settings() const; XMLNode* mixer_settings () const; XMLNode* keyboard_settings () const; + XMLNode* tearoff_settings (const char*) const; void save_ardour_state (); gboolean configure_handler (GdkEventConfigure* conf); @@ -195,19 +194,20 @@ class ARDOUR_UI : public Gtkmm2ext::UI void store_clock_modes (); void restore_clock_modes (); + void reset_main_clocks (); void add_route (Gtk::Window* float_window); - void session_add_audio_track (int input_channels, int32_t output_channels, ARDOUR::TrackMode mode, ARDOUR::RouteGroup* edit_group, uint32_t how_many) { - session_add_audio_route (true, input_channels, output_channels, mode, edit_group, how_many); + void session_add_audio_track (int input_channels, int32_t output_channels, ARDOUR::TrackMode mode, ARDOUR::RouteGroup* route_group, uint32_t how_many) { + session_add_audio_route (true, false, input_channels, output_channels, mode, route_group, how_many); } - void session_add_audio_bus (int input_channels, int32_t output_channels, ARDOUR::RouteGroup* edit_group, uint32_t how_many) { - session_add_audio_route (false, input_channels, output_channels, ARDOUR::Normal, edit_group, how_many); + void session_add_audio_bus (bool aux, int input_channels, int32_t output_channels, ARDOUR::RouteGroup* route_group, uint32_t how_many) { + session_add_audio_route (false, aux, input_channels, output_channels, ARDOUR::Normal, route_group, how_many); } - void session_add_midi_track (ARDOUR::RouteGroup* edit_group, uint32_t how_many) { - session_add_midi_route (true, edit_group, how_many); + void session_add_midi_track (ARDOUR::RouteGroup* route_group, uint32_t how_many) { + session_add_midi_route (true, route_group, how_many); } /*void session_add_midi_bus () { @@ -224,6 +224,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI void setup_profile (); void setup_theme (); + void setup_tooltips (); void set_shuttle_fract (double); @@ -238,6 +239,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI 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 (); @@ -249,7 +252,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI private: ArdourStartup* _startup; ARDOUR::AudioEngine *engine; - ARDOUR::Session *session; Gtk::Tooltips _tooltips; void goto_editor_window (); @@ -277,11 +279,10 @@ class ARDOUR_UI : public Gtkmm2ext::UI void update_autosave(); sigc::connection _autosave_connection; - void queue_transport_change (); void map_transport_state (); int32_t do_engine_start (); - void engine_halted (); + void engine_halted (const char* reason, bool free_reason); void engine_stopped (); void engine_running (); @@ -308,6 +309,15 @@ class ARDOUR_UI : public Gtkmm2ext::UI AudioClock big_clock; Gtk::Window* big_clock_window; + int original_big_clock_width; + int original_big_clock_height; + double original_big_clock_font_size; + + void big_clock_size_allocate (Gtk::Allocation&); + bool idle_big_clock_text_resizer (int width, int height); + void big_clock_realized (); + bool big_clock_resize_in_progress; + int big_clock_height; void float_big_clock (Gtk::Window* parent); bool main_window_state_event_handler (GdkEventWindowState*, bool window_was_editor); @@ -323,6 +333,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI Gtkmm2ext::TearOff* transport_tearoff; Gtk::Frame transport_frame; Gtk::HBox transport_tearoff_hbox; + Gtk::HBox play_range_hbox; + Gtk::VBox play_range_vbox; Gtk::HBox transport_hbox; Gtk::Fixed transport_base; Gtk::Fixed transport_button_base; @@ -380,10 +392,9 @@ class ARDOUR_UI : public Gtkmm2ext::UI BindableButton auto_loop_button; BindableButton play_selection_button; BindableButton rec_button; + Gtk::ToggleButton join_play_range_button; - Gtk::ComboBoxText sync_option_combo; - - void sync_option_changed (); + void toggle_external_sync (); void toggle_time_master (); void toggle_video_sync (); @@ -423,6 +434,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI Gtkmm2ext::StatefulToggleButton auto_input_button; Gtkmm2ext::StatefulToggleButton click_button; Gtkmm2ext::StatefulToggleButton time_master_button; + Gtkmm2ext::StatefulToggleButton sync_button; Gtk::ToggleButton auditioning_alert_button; Gtk::ToggleButton solo_alert_button; @@ -430,14 +442,15 @@ class ARDOUR_UI : public Gtkmm2ext::UI Gtk::VBox alert_box; void solo_blink (bool); + void sync_blink (bool); void audition_blink (bool); void soloing_changed (bool); void auditioning_changed (bool); void _auditioning_changed (bool); - void solo_alert_toggle (); - void audition_alert_toggle (); + bool solo_alert_press (GdkEventButton* ev); + bool audition_alert_press (GdkEventButton* ev); void big_clock_value_changed (); void primary_clock_value_changed (); @@ -520,11 +533,11 @@ class ARDOUR_UI : public Gtkmm2ext::UI void open_session (); void open_recent_session (); void save_template (); - + void edit_metadata (); void import_metadata (); - void session_add_audio_route (bool disk, int32_t input_channels, int32_t output_channels, ARDOUR::TrackMode mode, ARDOUR::RouteGroup *, uint32_t how_many); + void session_add_audio_route (bool disk, bool aux, int32_t input_channels, int32_t output_channels, ARDOUR::TrackMode mode, ARDOUR::RouteGroup *, uint32_t how_many); void session_add_midi_route (bool disk, ARDOUR::RouteGroup *, uint32_t how_many); void set_transport_sensitivity (bool); @@ -543,14 +556,10 @@ class ARDOUR_UI : public Gtkmm2ext::UI 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 set_session (ARDOUR::Session *); void connect_dependents_to_session (ARDOUR::Session *); void we_have_dependents (); @@ -558,7 +567,7 @@ class ARDOUR_UI : public Gtkmm2ext::UI guint32 last_key_press_time; - void snapshot_session (); + void snapshot_session (bool switch_to_it); Mixer_UI *mixer; int create_mixer (); @@ -572,9 +581,9 @@ class ARDOUR_UI : public Gtkmm2ext::UI BundleManager *bundle_manager; void create_bundle_manager (); - LocationUI *location_ui; - int create_location_ui (); - void handle_locations_change (ARDOUR::Location*); + LocationUIWindow *location_ui; + int create_location_ui (); + void handle_locations_change (ARDOUR::Location*); static UIConfiguration *ui_config; ThemeManager *theme_manager; @@ -595,8 +604,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI /* Keyboard Handling */ - Keyboard* keyboard; - + ArdourKeyboard* keyboard; + /* Keymap handling */ void install_actions (); @@ -615,7 +624,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI Gtk::MenuItem *cleanup_item; - void display_cleanup_results (ARDOUR::Session::cleanup_report& rep, const gchar* list_title, const std::string & msg); + void display_cleanup_results (ARDOUR::CleanupReport& rep, const gchar* list_title, + const std::string& plural_msg, const std::string& singular_msg); void cleanup (); void flush_trash (); @@ -626,19 +636,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI 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 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 (); @@ -670,7 +667,6 @@ class ARDOUR_UI : public Gtkmm2ext::UI void toggle_use_osc (); - void mtc_port_changed (); void parameter_changed (std::string); bool first_idle (); @@ -682,8 +678,10 @@ class ARDOUR_UI : public Gtkmm2ext::UI void audioengine_setup (); void display_message (const char *prefix, gint prefix_len, - Glib::RefPtr ptag, Glib::RefPtr mtag, const char *msg); + 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); @@ -692,6 +690,8 @@ class ARDOUR_UI : public Gtkmm2ext::UI void platform_specific (); void platform_setup (); void fontconfig_dialog (); + + PBD::ScopedConnectionList forever_connections; }; #endif /* __ardour_gui_h__ */