X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=gtk2_ardour%2Faudio_region_editor.cc;h=15186f2b8af4a9889ec8721986160974d6669af7;hb=e42699600b92db69a428979dc0412c96f7494141;hp=2aeb2dbe60aae44ffe7cfcd737c19cf5dd3d8691;hpb=6fa6514cfdb0ce38d93b51197f599dfd091bad1d;p=ardour.git diff --git a/gtk2_ardour/audio_region_editor.cc b/gtk2_ardour/audio_region_editor.cc index 2aeb2dbe60..15186f2b8a 100644 --- a/gtk2_ardour/audio_region_editor.cc +++ b/gtk2_ardour/audio_region_editor.cc @@ -31,11 +31,9 @@ #include "audio_region_editor.h" #include "audio_region_view.h" -#include "ardour_ui.h" -#include "utils.h" #include "gui_thread.h" -#include "i18n.h" +#include "pbd/i18n.h" using namespace ARDOUR; using namespace PBD; @@ -45,7 +43,6 @@ using namespace Gtkmm2ext; static void * _peak_amplitude_thread (void* arg) { - SessionEvent::create_per_thread_pool ("peak amplitude events", 64); static_cast(arg)->peak_amplitude_thread (); return 0; } @@ -90,14 +87,17 @@ AudioRegionEditor::AudioRegionEditor (Session* s, boost::shared_ptr _peak_amplitude.set_text (_("Calculating...")); PeakAmplitudeFound.connect (_peak_amplitude_connection, invalidator (*this), boost::bind (&AudioRegionEditor::peak_amplitude_found, this, _1), gui_context ()); - pthread_create_and_store (X_("peak-amplitude"), &_peak_amplitude_thread_handle, _peak_amplitude_thread, this); - _peak_channel.deliver ('c'); + + char name[64]; + snprintf (name, 64, "peak amplitude-%p", this); + pthread_create_and_store (name, &_peak_amplitude_thread_handle, _peak_amplitude_thread, this); + signal_peak_thread (); } AudioRegionEditor::~AudioRegionEditor () { void* v; - pthread_cancel_one (_peak_amplitude_thread_handle); + _peak_channel.deliver ('t'); pthread_join (_peak_amplitude_thread_handle, &v); } @@ -112,7 +112,7 @@ AudioRegionEditor::region_changed (const PBD::PropertyChange& what_changed) if (what_changed.contains (ARDOUR::Properties::start) || what_changed.contains (ARDOUR::Properties::length)) { /* ask the peak thread to run again */ - _peak_channel.deliver ('c'); + signal_peak_thread (); } } void @@ -133,14 +133,24 @@ AudioRegionEditor::gain_adjustment_changed () } } +void +AudioRegionEditor::signal_peak_thread () +{ + _peak_channel.deliver ('c'); +} + void AudioRegionEditor::peak_amplitude_thread () { while (1) { - /* await instructions to run */ char msg; + /* await instructions to run */ _peak_channel.receive (msg); + if (msg == 't') { + break; + } + /* compute peak amplitude and signal the fact */ PeakAmplitudeFound (accurate_coefficient_to_dB (_audio_region->maximum_amplitude ())); /* EMIT SIGNAL */ }