Fix new TruncateSilence -- be sure to iterate over the correct track list

This commit is contained in:
Paul Licameli 2016-03-14 11:30:03 -04:00
commit 911513fefe
2 changed files with 5 additions and 5 deletions

View File

@ -314,7 +314,7 @@ bool EffectTruncSilence::ProcessIndependently()
RegionList silences;
if (!FindSilences(silences, track, last))
if (!FindSilences(silences, mOutputTracks, track, last))
return false;
// Treat tracks in the sync lock group only
Track *groupFirst, *groupLast;
@ -349,7 +349,7 @@ bool EffectTruncSilence::ProcessAll()
RegionList silences;
SelectedTrackListOfKindIterator iter(Track::Wave, mTracks);
if (FindSilences(silences, iter.First(), iter.Last())) {
if (FindSilences(silences, mTracks, iter.First(), iter.Last())) {
TrackListIterator iterOut(mOutputTracks);
double totalCutLen = 0.0;
Track *const first = iterOut.First();
@ -363,13 +363,13 @@ bool EffectTruncSilence::ProcessAll()
}
bool EffectTruncSilence::FindSilences
(RegionList &silences, Track *firstTrack, Track *lastTrack)
(RegionList &silences, TrackList *list, Track *firstTrack, Track *lastTrack)
{
// Start with the whole selection silent
silences.push_back(Region(mT0, mT1));
// Remove non-silent regions in each track
SelectedTrackListOfKindIterator iter(Track::Wave, mTracks);
SelectedTrackListOfKindIterator iter(Track::Wave, list);
int whichTrack = 0;
bool lastSeen = false;
for (Track *t = iter.StartWith(firstTrack); !lastSeen && t; t = iter.Next())

View File

@ -88,7 +88,7 @@ private:
bool ProcessIndependently();
bool ProcessAll();
bool FindSilences
(RegionList &silences, Track *firstTrack, Track *lastTrack);
(RegionList &silences, TrackList *list, Track *firstTrack, Track *lastTrack);
bool DoRemoval
(const RegionList &silences, unsigned iGroup, unsigned nGroups, Track *firstTrack, Track *lastTrack,
double &totalCutLen);