summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRobin Gareus <robin@gareus.org>2018-09-25 01:00:58 +0200
committerRobin Gareus <robin@gareus.org>2018-09-25 01:00:58 +0200
commit21601f8d56f174940ba482b3f40c3c2e2066e896 (patch)
treefeccc69e8a6daa4cbbcc1f8ab5fd548215bcb672
parentd71dfdfd6a0c49014ff422cd65048a13ded3b3e5 (diff)
Add a reset-all DSP-load-stats button
-rw-r--r--gtk2_ardour/plugin_dspload_window.cc30
-rw-r--r--gtk2_ardour/plugin_dspload_window.h4
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;