summaryrefslogtreecommitdiff
path: root/src/lib
diff options
context:
space:
mode:
authorCarl Hetherington <cth@carlh.net>2013-03-08 22:51:39 +0000
committerCarl Hetherington <cth@carlh.net>2013-03-08 22:51:39 +0000
commit031a4066190454b1a4d933b74e86a053673a5e43 (patch)
tree640d54bffea6d4ac536dbaf643d32e6cc061ebe4 /src/lib
parent7339bd0457584dc8996a472ee7264a59a779c68e (diff)
Stop infinite loop if audio analysis fails.
Diffstat (limited to 'src/lib')
-rw-r--r--src/lib/analyse_audio_job.cc3
-rw-r--r--src/lib/film.cc7
-rw-r--r--src/lib/film.h2
3 files changed, 8 insertions, 4 deletions
diff --git a/src/lib/analyse_audio_job.cc b/src/lib/analyse_audio_job.cc
index de2632b0a..92c3cdd4e 100644
--- a/src/lib/analyse_audio_job.cc
+++ b/src/lib/analyse_audio_job.cc
@@ -29,6 +29,7 @@
using std::string;
using std::max;
+using std::min;
using std::cout;
using boost::shared_ptr;
@@ -67,7 +68,7 @@ AnalyseAudioJob::run ()
decoders.audio->Audio.connect (bind (&AnalyseAudioJob::audio, this, _1));
int64_t total_audio_frames = video_frames_to_audio_frames (_film->length().get(), _film->audio_stream()->sample_rate(), _film->source_frame_rate());
- _samples_per_point = min (1, total_audio_frames / _num_points);
+ _samples_per_point = max (1L, total_audio_frames / _num_points);
_current.resize (_film->audio_stream()->channels ());
_analysis.reset (new AudioAnalysis (_film->audio_stream()->channels()));
diff --git a/src/lib/film.cc b/src/lib/film.cc
index 8028f40ef..46b48f511 100644
--- a/src/lib/film.cc
+++ b/src/lib/film.cc
@@ -351,9 +351,12 @@ void
Film::analyse_audio_finished ()
{
ensure_ui_thread ();
- _analyse_audio_job.reset ();
- AudioAnalysisFinished ();
+ if (_analyse_audio_job->finished_ok ()) {
+ AudioAnalysisSucceeded ();
+ }
+
+ _analyse_audio_job.reset ();
}
void
diff --git a/src/lib/film.h b/src/lib/film.h
index 2ab4a9450..150e384bc 100644
--- a/src/lib/film.h
+++ b/src/lib/film.h
@@ -374,7 +374,7 @@ public:
/** Emitted when some property has changed */
mutable boost::signals2::signal<void (Property)> Changed;
- boost::signals2::signal<void ()> AudioAnalysisFinished;
+ boost::signals2::signal<void ()> AudioAnalysisSucceeded;
/** Current version number of the state file */
static int const state_version;