- time += ContentTime::from_seconds (_content->delay() / 1000.0);
- _positions[stream] = time.frames_round (stream->frame_rate ());
+ reset = true;
+ } else if (std::abs(_positions[stream] - time.frames_round(resampled_rate)) > slack_frames) {
+ reset = true;
+ LOG_GENERAL (
+ "Reset audio position: was %1, new data at %2, slack: %3 frames",
+ _positions[stream],
+ time.frames_round(resampled_rate),
+ std::abs(_positions[stream] - time.frames_round(resampled_rate))
+ );
+ }
+
+ if (reset) {
+ _positions[stream] = time.frames_round (resampled_rate);