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:
Robin Gareus 2021-03-27 17:44:34 +01:00
parent 003be3d87e
commit ac5bca4a92
Signed by: rgareus
GPG Key ID: A090BCE02CF57F04
5 changed files with 187 additions and 233 deletions

View File

@ -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;

View File

@ -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;

View File

@ -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);

View File

@ -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 ();
}

View File

@ -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;