Clean up RouteUI header
* Consolidate access modifiers * Remove all public member variables * Only expose required functions, use private whenever possible * Rename private members, prefix underscore * Remove cruft
This commit is contained in:
parent
003be3d87e
commit
ac5bca4a92
|
@ -7676,10 +7676,10 @@ Editor::toggle_tracks_active ()
|
|||
|
||||
if (rtv) {
|
||||
if (first) {
|
||||
target = !rtv->_route->active();
|
||||
target = !rtv->route()->active();
|
||||
first = false;
|
||||
}
|
||||
rtv->_route->set_active (target, this);
|
||||
rtv->route()->set_active (target, this);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -7743,7 +7743,7 @@ Editor::_remove_tracks ()
|
|||
} else {
|
||||
++nbusses;
|
||||
}
|
||||
routes.push_back (rtv->_route);
|
||||
routes.push_back (rtv->route());
|
||||
|
||||
if (rtv->route()->is_master() || rtv->route()->is_monitor()) {
|
||||
special_bus = true;
|
||||
|
|
|
@ -370,8 +370,6 @@ FoldbackStrip::FoldbackStrip (Mixer_UI& mx, Session* sess, boost::shared_ptr<Rou
|
|||
void
|
||||
FoldbackStrip::init ()
|
||||
{
|
||||
comment_area = 0;
|
||||
|
||||
_previous_button.set_name ("mixer strip button");
|
||||
_previous_button.set_icon (ArdourIcon::ScrollLeft);
|
||||
_previous_button.set_tweaks (ArdourButton::Square);
|
||||
|
@ -469,7 +467,7 @@ FoldbackStrip::init ()
|
|||
global_vpacker.pack_start (prev_next_box, Gtk::PACK_SHRINK);
|
||||
global_vpacker.pack_start (name_button, Gtk::PACK_SHRINK);
|
||||
global_vpacker.pack_start (*show_sends_button, Gtk::PACK_SHRINK);
|
||||
global_vpacker.pack_start (_invert_button_box, Gtk::PACK_SHRINK);
|
||||
global_vpacker.pack_start (invert_button_box, Gtk::PACK_SHRINK);
|
||||
global_vpacker.pack_start (send_scroller, true, true);
|
||||
#ifndef MIXBUS
|
||||
//add a spacer underneath the foldback bus;
|
||||
|
|
|
@ -179,7 +179,6 @@ MixerStrip::init ()
|
|||
_entered_mixer_strip= 0;
|
||||
group_menu = 0;
|
||||
route_ops_menu = 0;
|
||||
comment_area = 0;
|
||||
_width_owner = 0;
|
||||
|
||||
/* the length of this string determines the width of the mixer strip when it is set to `wide' */
|
||||
|
@ -322,7 +321,7 @@ MixerStrip::init ()
|
|||
global_vpacker.pack_start (width_hide_box, Gtk::PACK_SHRINK);
|
||||
global_vpacker.pack_start (name_button, Gtk::PACK_SHRINK);
|
||||
global_vpacker.pack_start (input_button_box, Gtk::PACK_SHRINK);
|
||||
global_vpacker.pack_start (_invert_button_box, Gtk::PACK_SHRINK);
|
||||
global_vpacker.pack_start (invert_button_box, Gtk::PACK_SHRINK);
|
||||
global_vpacker.pack_start (processor_box, true, true);
|
||||
global_vpacker.pack_start (panners, Gtk::PACK_SHRINK);
|
||||
global_vpacker.pack_start (rec_mon_table, Gtk::PACK_SHRINK);
|
||||
|
@ -394,7 +393,7 @@ MixerStrip::init ()
|
|||
are recognised when they occur.
|
||||
*/
|
||||
_visibility.add (&input_button_box, X_("Input"), _("Input"), false);
|
||||
_visibility.add (&_invert_button_box, X_("PhaseInvert"), _("Phase Invert"), false);
|
||||
_visibility.add (&invert_button_box, X_("PhaseInvert"), _("Phase Invert"), false);
|
||||
_visibility.add (&rec_mon_table, X_("RecMon"), _("Record & Monitor"), false, boost::bind (&MixerStrip::override_rec_mon_visibility, this));
|
||||
_visibility.add (&solo_iso_table, X_("SoloIsoLock"), _("Solo Iso / Lock"), false);
|
||||
_visibility.add (&output_button, X_("Output"), _("Output"), false);
|
||||
|
|
|
@ -128,12 +128,11 @@ RouteUI::RouteUI (ARDOUR::Session* sess)
|
|||
, mute_menu(0)
|
||||
, solo_menu(0)
|
||||
, sends_menu(0)
|
||||
, record_menu(0)
|
||||
, comment_window(0)
|
||||
, comment_area(0)
|
||||
, playlist_action_menu (0)
|
||||
, _record_menu(0)
|
||||
, _comment_window(0)
|
||||
, _comment_area(0)
|
||||
, _invert_menu(0)
|
||||
, _ignore_comment_edit (false)
|
||||
{
|
||||
if (program_port_prefix.empty()) {
|
||||
// compare to gtk2_ardour/port_group.cc
|
||||
|
@ -164,11 +163,11 @@ RouteUI::~RouteUI()
|
|||
delete solo_menu;
|
||||
delete mute_menu;
|
||||
delete sends_menu;
|
||||
delete record_menu;
|
||||
delete comment_window;
|
||||
delete monitor_input_button;
|
||||
delete monitor_disk_button;
|
||||
delete playlist_action_menu;
|
||||
delete _record_menu;
|
||||
delete _comment_window;
|
||||
delete _invert_menu;
|
||||
|
||||
send_blink_connection.disconnect ();
|
||||
|
@ -182,7 +181,7 @@ RouteUI::init ()
|
|||
mute_menu = 0;
|
||||
solo_menu = 0;
|
||||
sends_menu = 0;
|
||||
record_menu = 0;
|
||||
_record_menu = 0;
|
||||
_invert_menu = 0;
|
||||
pre_fader_mute_check = 0;
|
||||
post_fader_mute_check = 0;
|
||||
|
@ -195,10 +194,9 @@ RouteUI::init ()
|
|||
_solo_release = 0;
|
||||
_mute_release = 0;
|
||||
denormal_menu_item = 0;
|
||||
step_edit_item = 0;
|
||||
rec_safe_item = 0;
|
||||
multiple_mute_change = false;
|
||||
multiple_solo_change = false;
|
||||
_step_edit_item = 0;
|
||||
_rec_safe_item = 0;
|
||||
_ignore_comment_edit = false;
|
||||
_i_am_the_modifier = 0;
|
||||
_n_polarity_invert = 0;
|
||||
|
||||
|
@ -462,8 +460,6 @@ RouteUI::mute_press (GdkEventButton* ev)
|
|||
if (BindingProxy::is_bind_action(ev) )
|
||||
return false;
|
||||
|
||||
multiple_mute_change = false;
|
||||
|
||||
if (Keyboard::is_context_menu_event (ev)) {
|
||||
|
||||
if (mute_menu == 0){
|
||||
|
@ -634,8 +630,6 @@ RouteUI::solo_press(GdkEventButton* ev)
|
|||
if (BindingProxy::is_bind_action(ev) )
|
||||
return false;
|
||||
|
||||
multiple_solo_change = false;
|
||||
|
||||
if (Keyboard::is_context_menu_event (ev)) {
|
||||
|
||||
if (! (solo_isolated_led && solo_isolated_led->is_visible()) ||
|
||||
|
@ -932,31 +926,31 @@ RouteUI::monitor_release (GdkEventButton* ev, MonitorChoice monitor_choice)
|
|||
void
|
||||
RouteUI::build_record_menu ()
|
||||
{
|
||||
if (!record_menu) {
|
||||
record_menu = new Menu;
|
||||
record_menu->set_name ("ArdourContextMenu");
|
||||
if (!_record_menu) {
|
||||
_record_menu = new Menu;
|
||||
_record_menu->set_name ("ArdourContextMenu");
|
||||
using namespace Menu_Helpers;
|
||||
MenuList& items = record_menu->items();
|
||||
MenuList& items = _record_menu->items();
|
||||
|
||||
items.push_back (CheckMenuElem (_("Rec-Safe"), sigc::mem_fun (*this, &RouteUI::toggle_rec_safe)));
|
||||
rec_safe_item = dynamic_cast<Gtk::CheckMenuItem*> (&items.back());
|
||||
_rec_safe_item = dynamic_cast<Gtk::CheckMenuItem*> (&items.back());
|
||||
|
||||
if (is_midi_track()) {
|
||||
items.push_back (SeparatorElem());
|
||||
items.push_back (CheckMenuElem (_("Step Entry"), sigc::mem_fun (*this, &RouteUI::toggle_step_edit)));
|
||||
step_edit_item = dynamic_cast<Gtk::CheckMenuItem*> (&items.back());
|
||||
_step_edit_item = dynamic_cast<Gtk::CheckMenuItem*> (&items.back());
|
||||
}
|
||||
}
|
||||
|
||||
if (step_edit_item) {
|
||||
if (_step_edit_item) {
|
||||
if (track()->rec_enable_control()->get_value()) {
|
||||
step_edit_item->set_sensitive (false);
|
||||
_step_edit_item->set_sensitive (false);
|
||||
}
|
||||
step_edit_item->set_active (midi_track()->step_editing());
|
||||
_step_edit_item->set_active (midi_track()->step_editing());
|
||||
}
|
||||
if (rec_safe_item) {
|
||||
rec_safe_item->set_sensitive (!_route->rec_enable_control()->get_value());
|
||||
rec_safe_item->set_active (_route->rec_safe_control()->get_value());
|
||||
if (_rec_safe_item) {
|
||||
_rec_safe_item->set_sensitive (!_route->rec_enable_control()->get_value());
|
||||
_rec_safe_item->set_active (_route->rec_safe_control()->get_value());
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -967,7 +961,7 @@ RouteUI::toggle_step_edit ()
|
|||
return;
|
||||
}
|
||||
|
||||
midi_track()->set_step_editing (step_edit_item->get_active());
|
||||
midi_track()->set_step_editing (_step_edit_item->get_active());
|
||||
}
|
||||
|
||||
void
|
||||
|
@ -987,7 +981,7 @@ RouteUI::toggle_rec_safe ()
|
|||
return;
|
||||
}
|
||||
|
||||
rs->set_value (rec_safe_item->get_active (), Controllable::UseGroup);
|
||||
rs->set_value (_rec_safe_item->get_active (), Controllable::UseGroup);
|
||||
}
|
||||
|
||||
void
|
||||
|
@ -1000,8 +994,8 @@ RouteUI::step_edit_changed (bool yn)
|
|||
|
||||
start_step_editing ();
|
||||
|
||||
if (step_edit_item) {
|
||||
step_edit_item->set_active (true);
|
||||
if (_step_edit_item) {
|
||||
_step_edit_item->set_active (true);
|
||||
}
|
||||
|
||||
} else {
|
||||
|
@ -1012,8 +1006,8 @@ RouteUI::step_edit_changed (bool yn)
|
|||
|
||||
stop_step_editing ();
|
||||
|
||||
if (step_edit_item) {
|
||||
step_edit_item->set_active (false);
|
||||
if (_step_edit_item) {
|
||||
_step_edit_item->set_active (false);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -1023,8 +1017,8 @@ RouteUI::rec_enable_release (GdkEventButton* ev)
|
|||
{
|
||||
if (Keyboard::is_context_menu_event (ev)) {
|
||||
build_record_menu ();
|
||||
if (record_menu) {
|
||||
record_menu->popup (1, ev->time);
|
||||
if (_record_menu) {
|
||||
_record_menu->popup (1, ev->time);
|
||||
}
|
||||
return false;
|
||||
}
|
||||
|
@ -1398,15 +1392,15 @@ RouteUI::blink_rec_display (bool blinkOn)
|
|||
break;
|
||||
}
|
||||
|
||||
if (step_edit_item) {
|
||||
step_edit_item->set_sensitive (false);
|
||||
if (_step_edit_item) {
|
||||
_step_edit_item->set_sensitive (false);
|
||||
}
|
||||
|
||||
} else {
|
||||
rec_enable_button->unset_active_state ();
|
||||
|
||||
if (step_edit_item) {
|
||||
step_edit_item->set_sensitive (true);
|
||||
if (_step_edit_item) {
|
||||
_step_edit_item->set_sensitive (true);
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -1754,8 +1748,8 @@ RouteUI::route_rename ()
|
|||
void
|
||||
RouteUI::toggle_comment_editor ()
|
||||
{
|
||||
if (comment_window && comment_window->is_visible ()) {
|
||||
comment_window->hide ();
|
||||
if (_comment_window && _comment_window->is_visible ()) {
|
||||
_comment_window->hide ();
|
||||
} else {
|
||||
open_comment_editor ();
|
||||
}
|
||||
|
@ -1765,7 +1759,7 @@ RouteUI::toggle_comment_editor ()
|
|||
void
|
||||
RouteUI::open_comment_editor ()
|
||||
{
|
||||
if (comment_window == 0) {
|
||||
if (_comment_window == 0) {
|
||||
setup_comment_editor ();
|
||||
}
|
||||
|
||||
|
@ -1773,34 +1767,34 @@ RouteUI::open_comment_editor ()
|
|||
title = _route->name();
|
||||
title += _(": comment editor");
|
||||
|
||||
comment_window->set_title (title);
|
||||
comment_window->present();
|
||||
_comment_window->set_title (title);
|
||||
_comment_window->present();
|
||||
}
|
||||
|
||||
void
|
||||
RouteUI::setup_comment_editor ()
|
||||
{
|
||||
comment_window = new ArdourWindow (""); // title will be reset to show route
|
||||
comment_window->set_skip_taskbar_hint (true);
|
||||
comment_window->signal_hide().connect (sigc::mem_fun(*this, &MixerStrip::comment_editor_done_editing));
|
||||
comment_window->set_default_size (400, 200);
|
||||
_comment_window = new ArdourWindow (""); // title will be reset to show route
|
||||
_comment_window->set_skip_taskbar_hint (true);
|
||||
_comment_window->signal_hide().connect (sigc::mem_fun(*this, &MixerStrip::comment_editor_done_editing));
|
||||
_comment_window->set_default_size (400, 200);
|
||||
|
||||
comment_area = manage (new TextView());
|
||||
comment_area->set_name ("MixerTrackCommentArea");
|
||||
comment_area->set_wrap_mode (WRAP_WORD);
|
||||
comment_area->set_editable (true);
|
||||
comment_area->get_buffer()->set_text (_route->comment());
|
||||
comment_area->show ();
|
||||
_comment_area = manage (new TextView());
|
||||
_comment_area->set_name ("MixerTrackCommentArea");
|
||||
_comment_area->set_wrap_mode (WRAP_WORD);
|
||||
_comment_area->set_editable (true);
|
||||
_comment_area->get_buffer()->set_text (_route->comment());
|
||||
_comment_area->show ();
|
||||
|
||||
comment_window->add (*comment_area);
|
||||
_comment_window->add (*_comment_area);
|
||||
}
|
||||
|
||||
void
|
||||
RouteUI::comment_changed ()
|
||||
{
|
||||
_ignore_comment_edit = true;
|
||||
if (comment_area) {
|
||||
comment_area->get_buffer()->set_text (_route->comment());
|
||||
if (_comment_area) {
|
||||
_comment_area->get_buffer()->set_text (_route->comment());
|
||||
}
|
||||
_ignore_comment_edit = false;
|
||||
}
|
||||
|
@ -1810,7 +1804,7 @@ RouteUI::comment_editor_done_editing ()
|
|||
{
|
||||
ENSURE_GUI_THREAD (*this, &MixerStrip::comment_editor_done_editing, src)
|
||||
|
||||
string const str = comment_area->get_buffer()->get_text();
|
||||
string const str = _comment_area->get_buffer()->get_text();
|
||||
if (str == _route->comment ()) {
|
||||
return;
|
||||
}
|
||||
|
@ -2055,7 +2049,7 @@ RouteUI::setup_invert_buttons ()
|
|||
|
||||
/* remove old invert buttons */
|
||||
for (vector<ArdourButton*>::iterator i = _invert_buttons.begin(); i != _invert_buttons.end(); ++i) {
|
||||
_invert_button_box.remove (**i);
|
||||
invert_button_box.remove (**i);
|
||||
}
|
||||
|
||||
_invert_buttons.clear ();
|
||||
|
@ -2089,11 +2083,11 @@ RouteUI::setup_invert_buttons ()
|
|||
}
|
||||
|
||||
_invert_buttons.push_back (b);
|
||||
_invert_button_box.pack_start (*b);
|
||||
invert_button_box.pack_start (*b);
|
||||
}
|
||||
|
||||
_invert_button_box.set_spacing (1);
|
||||
_invert_button_box.show_all ();
|
||||
invert_button_box.set_spacing (1);
|
||||
invert_button_box.show_all ();
|
||||
|
||||
update_polarity_display ();
|
||||
}
|
||||
|
|
|
@ -68,7 +68,6 @@ namespace ArdourWidgets {
|
|||
|
||||
class ArdourWindow;
|
||||
class IOSelectorWindow;
|
||||
class ControlSlaveUI;
|
||||
class PatchChangeGridDialog;
|
||||
class SaveTemplateDialog;
|
||||
|
||||
|
@ -115,47 +114,21 @@ public:
|
|||
boost::shared_ptr<ARDOUR::AudioTrack> audio_track() const;
|
||||
boost::shared_ptr<ARDOUR::MidiTrack> midi_track() const;
|
||||
|
||||
// protected: XXX sigh this should be here
|
||||
|
||||
boost::shared_ptr<ARDOUR::Route> _route;
|
||||
|
||||
virtual void set_color (uint32_t c);
|
||||
Gdk::Color route_color () const;
|
||||
void choose_color ();
|
||||
|
||||
// protected: XXX sigh this should be here
|
||||
// callbacks used by dervice classes via &RouteUI::*
|
||||
|
||||
void edit_input_configuration ();
|
||||
void edit_output_configuration ();
|
||||
void select_midi_patch ();
|
||||
|
||||
bool wait_for_release;
|
||||
bool multiple_mute_change;
|
||||
bool multiple_solo_change;
|
||||
|
||||
Gtk::HBox _invert_button_box;
|
||||
ArdourWidgets::ArdourButton* mute_button;
|
||||
ArdourWidgets::ArdourButton* solo_button;
|
||||
ArdourWidgets::ArdourButton* rec_enable_button; /* audio tracks */
|
||||
ArdourWidgets::ArdourButton* show_sends_button; /* busses */
|
||||
ArdourWidgets::ArdourButton* monitor_input_button;
|
||||
ArdourWidgets::ArdourButton* monitor_disk_button;
|
||||
|
||||
Glib::RefPtr<Gdk::Pixbuf> solo_safe_pixbuf;
|
||||
|
||||
ArdourWidgets::ArdourButton* solo_safe_led;
|
||||
ArdourWidgets::ArdourButton* solo_isolated_led;
|
||||
|
||||
|
||||
Gtk::Label monitor_input_button_label;
|
||||
Gtk::Label monitor_disk_button_label;
|
||||
|
||||
void send_blink (bool);
|
||||
sigc::connection send_blink_connection;
|
||||
|
||||
sigc::connection rec_blink_connection;
|
||||
|
||||
Gtk::Menu* mute_menu;
|
||||
Gtk::Menu* solo_menu;
|
||||
Gtk::Menu* sends_menu;
|
||||
|
||||
boost::shared_ptr<ARDOUR::Delivery> _current_delivery;
|
||||
void choose_color ();
|
||||
void route_rename ();
|
||||
void manage_pins ();
|
||||
void duplicate_selected_routes ();
|
||||
void toggle_step_edit ();
|
||||
void toggle_denormal_protection();
|
||||
void save_as_template ();
|
||||
|
||||
bool mute_press(GdkEventButton*);
|
||||
bool mute_release(GdkEventButton*);
|
||||
|
@ -165,6 +138,8 @@ public:
|
|||
bool rec_enable_release(GdkEventButton*);
|
||||
bool show_sends_press(GdkEventButton*);
|
||||
bool show_sends_release(GdkEventButton*);
|
||||
bool solo_isolate_button_release (GdkEventButton*);
|
||||
bool solo_safe_button_release (GdkEventButton*);
|
||||
|
||||
bool monitor_release(GdkEventButton*, ARDOUR::MonitorChoice);
|
||||
bool monitor_input_press(GdkEventButton*);
|
||||
|
@ -172,27 +147,52 @@ public:
|
|||
bool monitor_disk_press(GdkEventButton*);
|
||||
bool monitor_disk_release(GdkEventButton*);
|
||||
void update_monitoring_display ();
|
||||
void open_comment_editor ();
|
||||
void toggle_comment_editor ();
|
||||
void comment_changed ();
|
||||
void set_route_active (bool, bool);
|
||||
void set_disk_io_point (ARDOUR::DiskIOPoint);
|
||||
void fan_out (bool to_busses = true, bool group = true);
|
||||
|
||||
void edit_input_configuration ();
|
||||
void edit_output_configuration ();
|
||||
/* The editor calls these when mapping an operation across multiple tracks */
|
||||
void use_new_playlist (bool prompt, std::vector<boost::shared_ptr<ARDOUR::Playlist> > const &, bool copy);
|
||||
void clear_playlist ();
|
||||
|
||||
void solo_changed(bool, void*);
|
||||
void solo_changed_so_update_mute ();
|
||||
void listen_changed(void*);
|
||||
/* used by EditorRoutes */
|
||||
static Gtkmm2ext::ActiveState solo_active_state (boost::shared_ptr<ARDOUR::Stripable>);
|
||||
static Gtkmm2ext::ActiveState solo_isolate_active_state (boost::shared_ptr<ARDOUR::Stripable>);
|
||||
static Gtkmm2ext::ActiveState solo_safe_active_state (boost::shared_ptr<ARDOUR::Stripable>);
|
||||
static Gtkmm2ext::ActiveState mute_active_state (ARDOUR::Session*, boost::shared_ptr<ARDOUR::Stripable>);
|
||||
|
||||
|
||||
protected:
|
||||
virtual void set_color (uint32_t c);
|
||||
virtual void processors_changed (ARDOUR::RouteProcessorChange) {}
|
||||
void route_rec_enable_changed();
|
||||
void session_rec_enable_changed();
|
||||
|
||||
void build_solo_menu ();
|
||||
virtual void route_property_changed (const PBD::PropertyChange&) = 0;
|
||||
virtual void route_active_changed () {}
|
||||
|
||||
void solo_isolated_toggle (void*, Gtk::CheckMenuItem*);
|
||||
void toggle_solo_isolated (Gtk::CheckMenuItem*);
|
||||
void disconnect_input ();
|
||||
void disconnect_output ();
|
||||
|
||||
bool solo_isolate_button_release (GdkEventButton*);
|
||||
bool solo_safe_button_release (GdkEventButton*);
|
||||
Gtk::HBox invert_button_box;
|
||||
|
||||
void solo_safe_toggle (void*, Gtk::CheckMenuItem*);
|
||||
void toggle_solo_safe (Gtk::CheckMenuItem*);
|
||||
ArdourWidgets::ArdourButton* mute_button;
|
||||
ArdourWidgets::ArdourButton* solo_button;
|
||||
ArdourWidgets::ArdourButton* rec_enable_button; /* audio tracks */
|
||||
ArdourWidgets::ArdourButton* show_sends_button; /* busses */
|
||||
ArdourWidgets::ArdourButton* monitor_input_button;
|
||||
ArdourWidgets::ArdourButton* monitor_disk_button;
|
||||
|
||||
ArdourWidgets::ArdourButton* solo_safe_led;
|
||||
ArdourWidgets::ArdourButton* solo_isolated_led;
|
||||
|
||||
Gtk::Menu* mute_menu;
|
||||
Gtk::Menu* solo_menu;
|
||||
Gtk::Menu* sends_menu;
|
||||
|
||||
boost::shared_ptr<ARDOUR::Route> _route;
|
||||
boost::shared_ptr<ARDOUR::Delivery> _current_delivery;
|
||||
|
||||
Gtk::CheckMenuItem* pre_fader_mute_check;
|
||||
Gtk::CheckMenuItem* post_fader_mute_check;
|
||||
|
@ -200,80 +200,9 @@ public:
|
|||
Gtk::CheckMenuItem* main_mute_check;
|
||||
Gtk::CheckMenuItem* solo_safe_check;
|
||||
Gtk::CheckMenuItem* solo_isolated_check;
|
||||
|
||||
void toggle_mute_menu(ARDOUR::MuteMaster::MutePoint, Gtk::CheckMenuItem*);
|
||||
void muting_change ();
|
||||
void build_mute_menu(void);
|
||||
void init_mute_menu(ARDOUR::MuteMaster::MutePoint, Gtk::CheckMenuItem*);
|
||||
|
||||
/* The editor calls these when mapping an operation across multiple tracks */
|
||||
void use_new_playlist (bool prompt, std::vector<boost::shared_ptr<ARDOUR::Playlist> > const &, bool copy);
|
||||
void clear_playlist ();
|
||||
|
||||
std::string resolve_new_group_playlist_name(std::string const&, std::vector<boost::shared_ptr<ARDOUR::Playlist> > const&);
|
||||
|
||||
int set_color_from_route ();
|
||||
|
||||
void route_rename();
|
||||
|
||||
void manage_pins ();
|
||||
void maybe_add_route_print_mgr ();
|
||||
void fan_out (bool to_busses = true, bool group = true);
|
||||
|
||||
virtual void route_property_changed (const PBD::PropertyChange&) = 0;
|
||||
void route_removed ();
|
||||
|
||||
virtual void route_active_changed () {}
|
||||
void set_route_active (bool, bool);
|
||||
void duplicate_selected_routes ();
|
||||
|
||||
Gtk::Menu* record_menu;
|
||||
void build_record_menu ();
|
||||
|
||||
Gtk::CheckMenuItem *step_edit_item;
|
||||
void toggle_step_edit ();
|
||||
virtual void step_edit_changed (bool);
|
||||
|
||||
Gtk::CheckMenuItem *rec_safe_item;
|
||||
void toggle_rec_safe ();
|
||||
|
||||
Gtk::CheckMenuItem *denormal_menu_item;
|
||||
void toggle_denormal_protection();
|
||||
virtual void denormal_protection_changed ();
|
||||
|
||||
void disconnect_input ();
|
||||
void disconnect_output ();
|
||||
|
||||
void save_as_template_dialog_response (int response, SaveTemplateDialog* d);
|
||||
void save_as_template ();
|
||||
|
||||
static Gtkmm2ext::ActiveState solo_active_state (boost::shared_ptr<ARDOUR::Stripable>);
|
||||
static Gtkmm2ext::ActiveState solo_isolate_active_state (boost::shared_ptr<ARDOUR::Stripable>);
|
||||
static Gtkmm2ext::ActiveState solo_safe_active_state (boost::shared_ptr<ARDOUR::Stripable>);
|
||||
static Gtkmm2ext::ActiveState mute_active_state (ARDOUR::Session*, boost::shared_ptr<ARDOUR::Stripable>);
|
||||
|
||||
/** Emitted when a bus has been set or unset from `display sends to this bus' mode
|
||||
* by a click on the `Sends' button. The parameter is the route that the sends are
|
||||
* to, or 0 if no route is now in this mode.
|
||||
*/
|
||||
static PBD::Signal1<void, boost::shared_ptr<ARDOUR::Route> > BusSendDisplayChanged;
|
||||
|
||||
void comment_editor_done_editing ();
|
||||
void setup_comment_editor ();
|
||||
void open_comment_editor ();
|
||||
void toggle_comment_editor ();
|
||||
|
||||
gint comment_key_release_handler (GdkEventKey*);
|
||||
void comment_changed ();
|
||||
void comment_edited ();
|
||||
|
||||
void set_disk_io_point (ARDOUR::DiskIOPoint);
|
||||
|
||||
protected:
|
||||
|
||||
ArdourWindow* comment_window;
|
||||
Gtk::TextView* comment_area;
|
||||
|
||||
typedef std::map <PBD::ID, IOSelectorWindow*> IOSelectorMap;
|
||||
|
||||
static IOSelectorMap input_selectors;
|
||||
|
@ -287,59 +216,37 @@ protected:
|
|||
void init ();
|
||||
void reset ();
|
||||
|
||||
virtual void self_delete ();
|
||||
virtual void blink_rec_display (bool onoff);
|
||||
virtual void map_frozen ();
|
||||
|
||||
virtual void self_delete ();
|
||||
virtual void route_rec_enable_changed ();
|
||||
virtual void route_color_changed () {}
|
||||
virtual void start_step_editing () {}
|
||||
virtual void stop_step_editing() {}
|
||||
|
||||
void build_sends_menu ();
|
||||
void set_sends_gain_from_track ();
|
||||
void set_sends_gain_to_zero ();
|
||||
void set_sends_gain_to_unity ();
|
||||
virtual void create_sends (ARDOUR::Placement, bool);
|
||||
virtual void create_selected_sends (ARDOUR::Placement, bool);
|
||||
|
||||
void set_invert_sensitive (bool);
|
||||
bool verify_new_route_name (const std::string& name);
|
||||
|
||||
void route_gui_changed (PBD::PropertyChange const&);
|
||||
virtual void route_color_changed () {}
|
||||
|
||||
void check_rec_enable_sensitivity ();
|
||||
|
||||
virtual void bus_send_display_changed (boost::shared_ptr<ARDOUR::Route>);
|
||||
|
||||
static std::string program_port_prefix;
|
||||
|
||||
bool mark_hidden (bool yn);
|
||||
void set_invert_sensitive (bool);
|
||||
bool verify_new_route_name (const std::string& name);
|
||||
void check_rec_enable_sensitivity ();
|
||||
void route_gui_changed (PBD::PropertyChange const&);
|
||||
|
||||
PatchChangeGridDialog* patch_change_dialog () const;
|
||||
|
||||
private:
|
||||
void parameter_changed (std::string const&);
|
||||
void relabel_solo_button ();
|
||||
void track_mode_changed ();
|
||||
void delete_patch_change_dialog ();
|
||||
|
||||
std::string route_state_id () const;
|
||||
|
||||
protected:
|
||||
ARDOUR::SoloMuteRelease* _solo_release;
|
||||
ARDOUR::SoloMuteRelease* _mute_release;
|
||||
|
||||
ControlSlaveUI* csu;
|
||||
|
||||
std::string playlist_tip () const;
|
||||
void build_playlist_menu ();
|
||||
void use_playlist (Gtk::RadioMenuItem *item, boost::weak_ptr<ARDOUR::Playlist> wpl);
|
||||
void show_playlist_selector ();
|
||||
void rename_current_playlist ();
|
||||
|
||||
Gtk::Menu* playlist_action_menu;
|
||||
|
||||
Gtk::CheckMenuItem *denormal_menu_item;
|
||||
|
||||
static void set_showing_sends_to (boost::shared_ptr<ARDOUR::Route>);
|
||||
static std::string program_port_prefix;
|
||||
|
||||
ARDOUR::SoloMuteRelease* _solo_release;
|
||||
ARDOUR::SoloMuteRelease* _mute_release;
|
||||
|
||||
private:
|
||||
void setup_invert_buttons ();
|
||||
|
@ -347,20 +254,76 @@ private:
|
|||
bool invert_press (GdkEventButton *);
|
||||
bool invert_release (GdkEventButton *, uint32_t i);
|
||||
|
||||
void toggle_solo_safe (Gtk::CheckMenuItem*);
|
||||
void toggle_mute_menu(ARDOUR::MuteMaster::MutePoint, Gtk::CheckMenuItem*);
|
||||
void toggle_solo_isolated (Gtk::CheckMenuItem*);
|
||||
|
||||
void update_solo_display ();
|
||||
void update_mute_display ();
|
||||
void update_polarity_display ();
|
||||
void update_solo_button ();
|
||||
void solo_changed_so_update_mute ();
|
||||
void session_rec_enable_changed ();
|
||||
void denormal_protection_changed ();
|
||||
void muting_change ();
|
||||
|
||||
int _i_am_the_modifier;
|
||||
std::vector<ArdourWidgets::ArdourButton*> _invert_buttons;
|
||||
void step_edit_changed (bool);
|
||||
void toggle_rec_safe ();
|
||||
|
||||
void setup_comment_editor ();
|
||||
void comment_editor_done_editing ();
|
||||
|
||||
void init_mute_menu (ARDOUR::MuteMaster::MutePoint, Gtk::CheckMenuItem*);
|
||||
void build_mute_menu ();
|
||||
void build_solo_menu ();
|
||||
void build_record_menu ();
|
||||
|
||||
void build_sends_menu ();
|
||||
void set_sends_gain_from_track ();
|
||||
void set_sends_gain_to_zero ();
|
||||
void set_sends_gain_to_unity ();
|
||||
|
||||
void show_playlist_selector ();
|
||||
void rename_current_playlist ();
|
||||
|
||||
void parameter_changed (std::string const&);
|
||||
void relabel_solo_button ();
|
||||
void track_mode_changed ();
|
||||
void send_blink (bool);
|
||||
|
||||
void delete_patch_change_dialog ();
|
||||
void maybe_add_route_print_mgr ();
|
||||
|
||||
std::string route_state_id () const;
|
||||
|
||||
void save_as_template_dialog_response (int response, SaveTemplateDialog* d);
|
||||
|
||||
std::string resolve_new_group_playlist_name (std::string const&, std::vector<boost::shared_ptr<ARDOUR::Playlist> > const&);
|
||||
|
||||
Gtk::Menu* _record_menu;
|
||||
ArdourWindow* _comment_window;
|
||||
Gtk::TextView* _comment_area;
|
||||
|
||||
Gtk::CheckMenuItem* _step_edit_item;
|
||||
Gtk::CheckMenuItem* _rec_safe_item;
|
||||
|
||||
bool _ignore_comment_edit;
|
||||
int _i_am_the_modifier;
|
||||
Gtk::Menu* _invert_menu;
|
||||
uint32_t _n_polarity_invert;
|
||||
|
||||
bool _ignore_comment_edit;
|
||||
std::vector<ArdourWidgets::ArdourButton*> _invert_buttons;
|
||||
|
||||
StripableColorDialog _color_picker;
|
||||
|
||||
sigc::connection send_blink_connection;
|
||||
sigc::connection rec_blink_connection;
|
||||
|
||||
/** Emitted when a bus has been set or unset from `display sends to this bus' mode
|
||||
* by a click on the `Sends' button. The parameter is the route that the sends are
|
||||
* to, or 0 if no route is now in this mode.
|
||||
*/
|
||||
static PBD::Signal1<void, boost::shared_ptr<ARDOUR::Route> > BusSendDisplayChanged;
|
||||
static boost::weak_ptr<ARDOUR::Route> _showing_sends_to;
|
||||
|
||||
static uint32_t _max_invert_buttons;
|
||||
|
|
Loading…
Reference in New Issue