From 54cfabec5c8427acc4f605d5a67fa32e6ef68939 Mon Sep 17 00:00:00 2001 From: Taloth Saldono Date: Wed, 4 Sep 2019 23:24:29 +0200 Subject: [PATCH] New: Additional Atmos detection in MediaInfo ref Radarr/Radarr#3712 --- .../FormatAudioCodecFixture.cs | 5 + .../FormatVideoCodecFixture.cs | 1 + .../MediaInfo/MediaInfoFormatter.cs | 92 +++++++++++-------- 3 files changed, 62 insertions(+), 36 deletions(-) diff --git a/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/MediaInfoFormatterTests/FormatAudioCodecFixture.cs b/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/MediaInfoFormatterTests/FormatAudioCodecFixture.cs index a0e13b2bb..025af84a6 100644 --- a/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/MediaInfoFormatterTests/FormatAudioCodecFixture.cs +++ b/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/MediaInfoFormatterTests/FormatAudioCodecFixture.cs @@ -30,6 +30,8 @@ namespace NzbDrone.Core.Test.MediaFiles.MediaInfo.MediaInfoFormatterTests [TestCase("TrueHD, A_TRUEHD, , , ", "", "TrueHD")] [TestCase("MLP FBA, A_TRUEHD, , , ", "TrueHD", "TrueHD")] [TestCase("MLP FBA, A_TRUEHD, , , 16-ch", "Atmos", "TrueHD Atmos")] + [TestCase("Atmos / TrueHD, A_TRUEHD, , , ", "TrueHD.Atmos.7.1", "TrueHD Atmos")] + [TestCase("Atmos / TrueHD / AC-3, 131, , , ", "", "TrueHD Atmos")] [TestCase("WMA, 161, , , ", "Droned.wmv", "WMA")] [TestCase("WMA, 162, Pro, , ", "B.N.S04E18.720p.WEB-DL", "WMA")] [TestCase("Opus, A_OPUS, , , ", "Roadkill Ep3x11 - YouTube.webm", "Opus")] @@ -44,6 +46,9 @@ namespace NzbDrone.Core.Test.MediaFiles.MediaInfo.MediaInfoFormatterTests [TestCase("E-AC-3, A_EAC3, , , JOC", "EAC3", "EAC3")] [TestCase("E-AC-3, A_EAC3, , , ", "DD5.1", "EAC3")] [TestCase("AC-3, A_AC3, , , ", "DD5.1", "AC3")] + [TestCase("A_QUICKTIME, A_QUICKTIME, , , ", "", "")] + [TestCase("ADPCM, 2, , , ", "Custom?", "PCM")] + [TestCase("ADPCM, ima4, , , ", "Custom", "PCM")] public void should_format_audio_format(string audioFormatPack, string sceneName, string expectedFormat) { var split = audioFormatPack.Split(new string[] { ", " }, System.StringSplitOptions.None); diff --git a/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/MediaInfoFormatterTests/FormatVideoCodecFixture.cs b/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/MediaInfoFormatterTests/FormatVideoCodecFixture.cs index f6f0626d2..869687775 100644 --- a/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/MediaInfoFormatterTests/FormatVideoCodecFixture.cs +++ b/src/NzbDrone.Core.Test/MediaFiles/MediaInfo/MediaInfoFormatterTests/FormatVideoCodecFixture.cs @@ -44,6 +44,7 @@ namespace NzbDrone.Core.Test.MediaFiles.MediaInfo.MediaInfoFormatterTests [TestCase("MPEG-4 Visual, 20, Simple@L1, Lavc52.29.0", "Will.And.Grace.S08E14.WS.DVDrip.XviD.I.Love.L.Gay-Obfuscated", "XviD")] [TestCase("MPEG-4 Visual, 20, Advanced Simple@L5, XviD0046", "", "XviD")] [TestCase("mp4v, mp4v, , ", "American.Chopper.S06E07.Mountain.Creek.Bike.DSR.XviD-KRS", "XviD")] + [TestCase("mp43, V_MS/VFW/FOURCC / mp43, , ", "Bubble.Guppies.S01E13.480p.WEB-DL.H.264-BTN-Custom", "")] public void should_format_video_format(string videoFormatPack, string sceneName, string expectedFormat) { var split = videoFormatPack.Split(new string[] { ", " }, System.StringSplitOptions.None); diff --git a/src/NzbDrone.Core/MediaFiles/MediaInfo/MediaInfoFormatter.cs b/src/NzbDrone.Core/MediaFiles/MediaInfo/MediaInfoFormatter.cs index 1939dd81f..5a12a245c 100644 --- a/src/NzbDrone.Core/MediaFiles/MediaInfo/MediaInfoFormatter.cs +++ b/src/NzbDrone.Core/MediaFiles/MediaInfo/MediaInfoFormatter.cs @@ -39,38 +39,43 @@ namespace NzbDrone.Core.MediaFiles.MediaInfo return FormatAudioCodecLegacy(mediaInfo, sceneName); } - var audioFormat = mediaInfo.AudioFormat; + var audioFormat = mediaInfo.AudioFormat.Trim().Split(new[] { " / " }, StringSplitOptions.RemoveEmptyEntries); var audioCodecID = mediaInfo.AudioCodecID ?? string.Empty; var audioProfile = mediaInfo.AudioProfile ?? string.Empty; var audioCodecLibrary = mediaInfo.AudioCodecLibrary ?? string.Empty; var splitAdditionalFeatures = (mediaInfo.AudioAdditionalFeatures ?? string.Empty).Split(new[] {' '}, StringSplitOptions.RemoveEmptyEntries); - if (audioFormat.IsNullOrWhiteSpace()) + if (audioFormat.Empty()) { return string.Empty; } - - if (audioFormat.EqualsIgnoreCase("AC-3")) + + if (audioFormat.ContainsIgnoreCase("Atmos")) { - return "AC3"; + return "TrueHD Atmos"; } - if (audioFormat.EqualsIgnoreCase("E-AC-3")) + if (audioFormat.ContainsIgnoreCase("MLP FBA")) { - return "EAC3"; + if (splitAdditionalFeatures.ContainsIgnoreCase("16-ch")) + { + return "TrueHD Atmos"; + } + + return "TrueHD"; } - if (audioFormat.EqualsIgnoreCase("AAC")) + if (audioFormat.ContainsIgnoreCase("TrueHD")) { - if (audioCodecID == "A_AAC/MPEG4/LC/SBR") - { - return "HE-AAC"; - } + return "TrueHD"; + } - return "AAC"; + if (audioFormat.ContainsIgnoreCase("FLAC")) + { + return "FLAC"; } - if (audioFormat.EqualsIgnoreCase("DTS")) + if (audioFormat.ContainsIgnoreCase("DTS")) { if (splitAdditionalFeatures.ContainsIgnoreCase("XLL")) { @@ -94,17 +99,32 @@ namespace NzbDrone.Core.MediaFiles.MediaInfo return "DTS"; } - if (audioFormat.EqualsIgnoreCase("FLAC")) + if (audioFormat.ContainsIgnoreCase("E-AC-3")) { - return "FLAC"; + return "EAC3"; } - if (audioFormat.Trim().EqualsIgnoreCase("mp3")) + if (audioFormat.ContainsIgnoreCase("AC-3")) + { + return "AC3"; + } + + if (audioFormat.ContainsIgnoreCase("AAC")) + { + if (audioCodecID == "A_AAC/MPEG4/LC/SBR") + { + return "HE-AAC"; + } + + return "AAC"; + } + + if (audioFormat.ContainsIgnoreCase("mp3")) { return "MP3"; } - if (audioFormat.EqualsIgnoreCase("MPEG Audio")) + if (audioFormat.ContainsIgnoreCase("MPEG Audio")) { if (mediaInfo.AudioCodecID == "55" || mediaInfo.AudioCodecID == "A_MPEG/L3" || mediaInfo.AudioProfile == "Layer 3") { @@ -117,47 +137,42 @@ namespace NzbDrone.Core.MediaFiles.MediaInfo } } - if (audioFormat.EqualsIgnoreCase("Opus")) + if (audioFormat.ContainsIgnoreCase("Opus")) { return "Opus"; } - if (audioFormat.EqualsIgnoreCase("PCM")) + if (audioFormat.ContainsIgnoreCase("PCM")) { return "PCM"; } - if (audioFormat.EqualsIgnoreCase("TrueHD")) + if (audioFormat.ContainsIgnoreCase("ADPCM")) { - return "TrueHD"; + return "PCM"; } - if (audioFormat.EqualsIgnoreCase("MLP FBA")) + if (audioFormat.ContainsIgnoreCase("Vorbis")) { - if (splitAdditionalFeatures.ContainsIgnoreCase("16-ch")) - { - return "TrueHD Atmos"; - } - - return "TrueHD"; + return "Vorbis"; } - if (audioFormat.EqualsIgnoreCase("Vorbis")) + if (audioFormat.ContainsIgnoreCase("WMA")) { - return "Vorbis"; + return "WMA"; } - if (audioFormat == "WMA") + if (audioFormat.ContainsIgnoreCase("A_QUICKTIME")) { - return "WMA"; + return ""; } Logger.Debug() - .Message("Unknown audio format: '{0}' in '{1}'.", string.Join(", ", audioFormat, audioCodecID, audioProfile, audioCodecLibrary), sceneName) - .WriteSentryWarn("UnknownAudioFormat", mediaInfo.ContainerFormat, audioFormat, audioCodecID) + .Message("Unknown audio format: '{0}' in '{1}'.", string.Join(", ", mediaInfo.AudioFormat, audioCodecID, audioProfile, audioCodecLibrary, mediaInfo.AudioAdditionalFeatures), sceneName) + .WriteSentryWarn("UnknownAudioFormat", mediaInfo.ContainerFormat, mediaInfo.AudioFormat, audioCodecID) .Write(); - return audioFormat; + return mediaInfo.AudioFormat; } public static string FormatAudioCodecLegacy(MediaInfoModel mediaInfo, string sceneName) @@ -331,6 +346,11 @@ namespace NzbDrone.Core.MediaFiles.MediaInfo return "XviD"; } + if (videoFormat.EqualsIgnoreCase("mp43")) + { + return ""; + } + Logger.Debug() .Message("Unknown video format: '{0}' in '{1}'.", string.Join(", ", videoFormat, videoCodecID, videoProfile, videoCodecLibrary), sceneName) .WriteSentryWarn("UnknownVideoFormat", mediaInfo.ContainerFormat, videoFormat, videoCodecID)