From f0ca2bc11e72e3b66c54b8d7bcee9e7d664c22b9 Mon Sep 17 00:00:00 2001 From: Mark McDowall Date: Tue, 16 Feb 2016 21:28:32 -0800 Subject: [PATCH] Fixed: Don't collapse episode titles when episode titles contain Part x only --- .../EpisodeTitleCollapseFixture.cs | 12 ++++++++++++ src/NzbDrone.Core/Organizer/FileNameBuilder.cs | 15 +++++++++++---- 2 files changed, 23 insertions(+), 4 deletions(-) diff --git a/src/NzbDrone.Core.Test/OrganizerTests/FileNameBuilderTests/EpisodeTitleCollapseFixture.cs b/src/NzbDrone.Core.Test/OrganizerTests/FileNameBuilderTests/EpisodeTitleCollapseFixture.cs index 2f0aaddc8..f4da13b5b 100644 --- a/src/NzbDrone.Core.Test/OrganizerTests/FileNameBuilderTests/EpisodeTitleCollapseFixture.cs +++ b/src/NzbDrone.Core.Test/OrganizerTests/FileNameBuilderTests/EpisodeTitleCollapseFixture.cs @@ -97,5 +97,17 @@ public void should_not_collapse_episode_titles_when_episode_titles_are_not_the_s Subject.BuildFileName(new List { _episode1, _episode2 }, _series, _episodeFile) .Should().Be("South Park - S15E06-E07 - Hello + World"); } + + [Test] + public void should_not_collaspe_when_result_is_empty() + { + _namingConfig.StandardEpisodeFormat = "{Episode Title}"; + + _episode1.Title = "Part 1"; + _episode2.Title = "Part 2"; + + Subject.BuildFileName(new List { _episode1, _episode2 }, _series, _episodeFile) + .Should().Be("Part 1 + Part 2"); + } } } diff --git a/src/NzbDrone.Core/Organizer/FileNameBuilder.cs b/src/NzbDrone.Core/Organizer/FileNameBuilder.cs index c0be11773..46d92348a 100644 --- a/src/NzbDrone.Core/Organizer/FileNameBuilder.cs +++ b/src/NzbDrone.Core/Organizer/FileNameBuilder.cs @@ -684,10 +684,17 @@ private string GetEpisodeTitle(List episodes, string separator) return episodes.First().Title.TrimEnd(EpisodeTitleTrimCharacters); } - var titles = episodes - .Select(c => c.Title.TrimEnd(EpisodeTitleTrimCharacters)) - .Select(CleanupEpisodeTitle) - .Distinct(); + var titles = episodes.Select(c => c.Title.TrimEnd(EpisodeTitleTrimCharacters)) + .Select(CleanupEpisodeTitle) + .Distinct() + .ToList(); + + if (titles.All(t => t.IsNullOrWhiteSpace())) + { + titles = episodes.Select(c => c.Title.TrimEnd(EpisodeTitleTrimCharacters)) + .Distinct() + .ToList(); + } return string.Join(separator, titles); }