protected override void FinalizeSearch(Repository.Series series, dynamic options, bool reportsFound, Model.Notification.ProgressNotification notification)
 {
     logger.Warn("Unable to find {0} in any of indexers.", series.Title);
 }
        public override List <EpisodeParseResult> PerformSearch(Repository.Series series, dynamic options, Model.Notification.ProgressNotification notification)
        {
            if (options.Episode == null)
            {
                throw new ArgumentException("Episode is invalid");
            }

            notification.CurrentMessage = "Looking for " + options.Episode;

            var reports = new List <EpisodeParseResult>();
            var title   = GetSearchTitle(series);

            var seasonNumber  = options.Episode.SeasonNumber;
            var episodeNumber = options.Episode.EpisodeNumber;

            Parallel.ForEach(_indexerProvider.GetEnabledIndexers(), indexer =>
            {
                try
                {
                    reports.AddRange(indexer.FetchEpisode(title, seasonNumber, episodeNumber));
                }

                catch (Exception e)
                {
                    logger.ErrorException(String.Format("An error has occurred while searching for {0}-S{1:00}E{2:00} from: {3}",
                                                        series.Title, options.SeasonNumber, options.EpisodeNumber, indexer.Name), e);
                }
            });

            return(reports);
        }