From 8967bcc9af08e78c469217bc69d57b8afa71d7e5 Mon Sep 17 00:00:00 2001 From: ConfusedPolarBear <33811686+ConfusedPolarBear@users.noreply.github.com> Date: Sun, 19 Jun 2022 00:36:34 -0500 Subject: [PATCH] Make second analysis pass more resilient --- .../ScheduledTasks/FingerprinterTask.cs | 41 ++++++++++++++----- 1 file changed, 30 insertions(+), 11 deletions(-) diff --git a/ConfusedPolarBear.Plugin.IntroSkipper/ScheduledTasks/FingerprinterTask.cs b/ConfusedPolarBear.Plugin.IntroSkipper/ScheduledTasks/FingerprinterTask.cs index 531ac04..8a4b187 100644 --- a/ConfusedPolarBear.Plugin.IntroSkipper/ScheduledTasks/FingerprinterTask.cs +++ b/ConfusedPolarBear.Plugin.IntroSkipper/ScheduledTasks/FingerprinterTask.cs @@ -188,11 +188,11 @@ public class FingerprinterTask : IScheduledTask if (unanalyzed) { - _logger.LogInformation( - "Analyzing {Count} episodes from {Name} season {Season}", - season.Value.Count, - first.SeriesName, - first.SeasonNumber); + _logger.LogInformation( + "Analyzing {Count} episodes from {Name} season {Season}", + season.Value.Count, + first.SeriesName, + first.SeasonNumber); } else { @@ -234,8 +234,7 @@ public class FingerprinterTask : IScheduledTask } // TODO: add retry logic - var alreadyDone = Plugin.Instance!.Intros; - if (alreadyDone.ContainsKey(lhs.EpisodeId) && alreadyDone.ContainsKey(rhs.EpisodeId)) + if (Plugin.Instance!.Intros.ContainsKey(lhs.EpisodeId) && Plugin.Instance!.Intros.ContainsKey(rhs.EpisodeId)) { _logger.LogTrace( "Episodes {LHS} and {RHS} have both already been fingerprinted", @@ -513,15 +512,13 @@ public class FingerprinterTask : IScheduledTask /// List of episodes that was just analyzed. private void RunSecondPass(List episodes) { - var intros = Plugin.Instance!.Intros; - // First, assert that at least half of the episodes in this season have an intro. var validCount = 0; var totalCount = episodes.Count; foreach (var episode in episodes) { - if (intros[episode.EpisodeId].Valid) + if (Plugin.Instance!.Intros[episode.EpisodeId].Valid) { validCount++; } @@ -604,7 +601,29 @@ public class FingerprinterTask : IScheduledTask var goodFingerprints = new List>(); foreach (var id in maxBucket.Episodes) { - goodFingerprints.Add(_fingerprintCache[id]); + // Sometimes an episode isn't in the fingerprint cache. When this occurs, it has to be fingerprinted again. + _logger.LogTrace("Second pass: searching cache for {Id}", id); + + if (_fingerprintCache.ContainsKey(id)) + { + _logger.LogTrace("Second pass: cache hit for {Id}", id); + goodFingerprints.Add(_fingerprintCache[id]); + } + else + { + _logger.LogTrace("Second pass: cache miss for {Id}", id); + + var fullEp = episodes.Find((e) => { return e.EpisodeId == id; }); + + if (fullEp is not null) + { + goodFingerprints.Add(Chromaprint.Fingerprint(fullEp)); + } + else + { + _logger.LogTrace("Second pass: unable to find episode {Id}", id); + } + } } foreach (var episode in episodes)