X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Fengine_dialog.h;h=142e1fea18d0ae7ae4f5963401883963a2221ce3;hb=3346c69f2dd15968e164561850b647cf51bea900;hp=aa768bc890c87191e8fae1e122fce624b654b999;hpb=2529b9db963b1dba66cdfeda94d938cf09ab4873;p=ardour.git diff --git a/gtk2_ardour/engine_dialog.h b/gtk2_ardour/engine_dialog.h index aa768bc890..142e1fea18 100644 --- a/gtk2_ardour/engine_dialog.h +++ b/gtk2_ardour/engine_dialog.h @@ -49,6 +49,7 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { bool set_state (const XMLNode&); void set_desired_sample_rate (uint32_t); + bool try_autostart (); private: Gtk::Notebook notebook; @@ -70,6 +71,7 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { Gtk::ComboBoxText midi_option_combo; Gtk::ComboBoxText buffer_size_combo; Gtk::Label buffer_size_duration_label; + Gtk::ComboBoxText nperiods_combo; Gtk::Adjustment input_latency_adjustment; Gtk::SpinButton input_latency; Gtk::Adjustment output_latency_adjustment; @@ -86,6 +88,7 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { ArdourButton midi_devices_button; ArdourButton start_stop_button; ArdourButton update_devices_button; + ArdourButton use_buffered_io_button; Gtk::Button connect_disconnect_button; @@ -106,9 +109,6 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { bool have_lm_results; bool lm_running; - Gtk::Button* cancel_button; - Gtk::Button* ok_button; - /* MIDI Tab */ Gtk::VBox midi_vbox; @@ -119,7 +119,8 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { Gtk::CheckButton aj_button; - uint32_t ignore_changes; + uint32_t ignore_changes; // state save/load + uint32_t ignore_device_changes; // AudioEngine::DeviceListChanged uint32_t _desired_sample_rate; bool started_at_least_once; bool queue_device_changed; @@ -128,6 +129,7 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { void backend_changed (); void sample_rate_changed (); void buffer_size_changed (); + void nperiods_changed (); void parameter_changed (); void midi_option_changed (); @@ -137,7 +139,8 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { void update_midi_options (); - std::string bufsize_as_string (uint32_t); + std::string bufsize_as_string (uint32_t); + std::string nperiods_as_string (uint32_t); std::vector get_default_sample_rates (); std::vector get_default_buffer_sizes (); @@ -147,6 +150,7 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { float get_rate() const; uint32_t get_buffer_size() const; + uint32_t get_nperiods() const; uint32_t get_input_channels() const; uint32_t get_output_channels() const; uint32_t get_input_latency() const; @@ -157,6 +161,7 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { std::string get_driver() const; std::string get_backend() const; std::string get_midi_option () const; + bool get_use_buffered_io () const; std::string get_default_device (const std::string&, const std::vector&); @@ -170,6 +175,7 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { bool set_output_device_popdown_strings (); void set_samplerate_popdown_strings (); void set_buffersize_popdown_strings (); + void set_nperiods_popdown_strings (); void list_devices (); void show_buffer_duration (); @@ -210,11 +216,13 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { std::string output_device; float sample_rate; uint32_t buffer_size; + uint32_t n_periods; uint32_t input_latency; uint32_t output_latency; uint32_t input_channels; uint32_t output_channels; bool active; + bool use_buffered_io; std::string midi_option; std::vector midi_devices; time_t lru; @@ -227,6 +235,7 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { , input_channels (0) , output_channels (0) , active (false) + , use_buffered_io (false) , lru (0) {} }; @@ -284,6 +293,7 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { sigc::connection driver_combo_connection; sigc::connection sample_rate_combo_connection; sigc::connection buffer_size_combo_connection; + sigc::connection nperiods_combo_connection; sigc::connection device_combo_connection; sigc::connection input_device_combo_connection; sigc::connection output_device_combo_connection; @@ -294,10 +304,11 @@ class EngineControl : public ArdourDialog, public PBD::ScopedConnectionList { sigc::connection output_channels_connection; void on_show (); - void on_response (int); + void on_map (); void control_app_button_clicked (); void start_stop_button_clicked (); void update_devices_button_clicked (); + void use_buffered_io_button_clicked (); void use_latency_button_clicked (); void manage_control_app_sensitivity (); int push_state_to_backend (bool start);