diff options
author | Robin Gareus <robin@gareus.org> | 2018-09-25 01:00:58 +0200 |
---|---|---|
committer | Robin Gareus <robin@gareus.org> | 2018-09-25 01:00:58 +0200 |
commit | 21601f8d56f174940ba482b3f40c3c2e2066e896 (patch) | |
tree | feccc69e8a6daa4cbbcc1f8ab5fd548215bcb672 | |
parent | d71dfdfd6a0c49014ff422cd65048a13ded3b3e5 (diff) |
Add a reset-all DSP-load-stats button
-rw-r--r-- | gtk2_ardour/plugin_dspload_window.cc | 30 | ||||
-rw-r--r-- | gtk2_ardour/plugin_dspload_window.h | 4 |
2 files changed, 33 insertions, 1 deletions
diff --git a/gtk2_ardour/plugin_dspload_window.cc b/gtk2_ardour/plugin_dspload_window.cc index 104ec9d7b6..e9b54380d2 100644 --- a/gtk2_ardour/plugin_dspload_window.cc +++ b/gtk2_ardour/plugin_dspload_window.cc @@ -32,12 +32,16 @@ using namespace ARDOUR; PluginDSPLoadWindow::PluginDSPLoadWindow () : ArdourWindow (_("Plugin DSP Load")) + , _reset_button (_("Reset All Stats")) { _scroller.set_border_width (0); _scroller.set_shadow_type (Gtk::SHADOW_NONE); _scroller.set_policy (Gtk::POLICY_NEVER, Gtk::POLICY_AUTOMATIC); _scroller.add (_box); + _reset_button.set_name ("generic button"); + _reset_button.signal_clicked.connect (sigc::mem_fun (*this, &PluginDSPLoadWindow::clear_all_stats)); + add (_scroller); _box.show (); _scroller.show (); @@ -84,13 +88,24 @@ PluginDSPLoadWindow::on_hide () } void +PluginDSPLoadWindow::clear_all_stats () +{ + RouteList routes = _session->get_routelist (); + for (RouteList::const_iterator i = routes.begin(); i != routes.end(); ++i) { + (*i)->foreach_processor (sigc::mem_fun (*this, &PluginDSPLoadWindow::clear_processor_stats)); + } +} + +void PluginDSPLoadWindow::drop_references () { std::list<Gtk::Widget*> children = _box.get_children (); for (std::list<Gtk::Widget*>::iterator child = children.begin(); child != children.end(); ++child) { (*child)->hide (); _box.remove (**child); - delete *child; + if (*child != &_reset_button) { + delete *child; + } } } @@ -115,6 +130,9 @@ PluginDSPLoadWindow::refill_processors () if (_box.get_children().size() == 0) { _box.add (*Gtk::manage (new Gtk::Label (_("No Plugins")))); _box.show_all (); + } else if (_box.get_children().size() > 1) { + _box.pack_start (_reset_button, Gtk::PACK_SHRINK, 2); + _reset_button.show (); } } @@ -137,3 +155,13 @@ PluginDSPLoadWindow::add_processor_to_display (boost::weak_ptr<Processor> w, std plsg->start_updating (); frame->show_all (); } + +void +PluginDSPLoadWindow::clear_processor_stats (boost::weak_ptr<Processor> w) +{ + boost::shared_ptr<Processor> p = w.lock (); + boost::shared_ptr<PluginInsert> pi = boost::dynamic_pointer_cast<PluginInsert> (p); + if (pi) { + pi->clear_stats (); + } +} diff --git a/gtk2_ardour/plugin_dspload_window.h b/gtk2_ardour/plugin_dspload_window.h index 5581d07138..51b81bbf1d 100644 --- a/gtk2_ardour/plugin_dspload_window.h +++ b/gtk2_ardour/plugin_dspload_window.h @@ -24,6 +24,7 @@ #include <gtkmm/box.h> #include <gtkmm/scrolledwindow.h> +#include "widgets/ardour_button.h" #include "pbd/signals.h" #include "ardour_window.h" @@ -51,10 +52,13 @@ protected: private: void refill_processors (); void drop_references (); + void clear_all_stats (); void add_processor_to_display (boost::weak_ptr<ARDOUR::Processor>, std::string const&); + void clear_processor_stats (boost::weak_ptr<ARDOUR::Processor>); Gtk::ScrolledWindow _scroller; Gtk::VBox _box; + ArdourWidgets::ArdourButton _reset_button; PBD::ScopedConnectionList _processor_connections; PBD::ScopedConnectionList _route_connections; |