aboutsummaryrefslogtreecommitdiff
path: root/MediaBrowser.Providers/MediaInfo/AudioResolver.cs
diff options
context:
space:
mode:
authorJonas Resch <jonas.resch@live.de>2021-11-28 14:03:52 +0100
committerJonas Resch <jonas.resch@live.de>2021-11-30 19:31:46 +0100
commit0894a6193f025a9cec5c735226a8487caa2bc66b (patch)
treebfdfdaea9c0193bab158b3f7a19a35168fa297c9 /MediaBrowser.Providers/MediaInfo/AudioResolver.cs
parent9d34d6339a2d677139573ada98b92318de298653 (diff)
Implement coding standards from 2nd code feedback
Diffstat (limited to 'MediaBrowser.Providers/MediaInfo/AudioResolver.cs')
-rw-r--r--MediaBrowser.Providers/MediaInfo/AudioResolver.cs138
1 files changed, 59 insertions, 79 deletions
diff --git a/MediaBrowser.Providers/MediaInfo/AudioResolver.cs b/MediaBrowser.Providers/MediaInfo/AudioResolver.cs
index ccac450f6c..d23afdc3b9 100644
--- a/MediaBrowser.Providers/MediaInfo/AudioResolver.cs
+++ b/MediaBrowser.Providers/MediaInfo/AudioResolver.cs
@@ -21,69 +21,93 @@ namespace MediaBrowser.Providers.MediaInfo
{
public class AudioResolver
{
- public async Task<IAsyncEnumerable<MediaStream>> GetExternalAudioStreams(
+ private readonly ILocalizationManager _localizationManager;
+ private readonly IMediaEncoder _mediaEncoder;
+ private readonly NamingOptions _namingOptions;
+
+ public AudioResolver(
+ ILocalizationManager localizationManager,
+ IMediaEncoder mediaEncoder,
+ NamingOptions namingOptions)
+ {
+ _localizationManager = localizationManager;
+ _mediaEncoder = mediaEncoder;
+ _namingOptions = namingOptions;
+ }
+
+ public async IAsyncEnumerable<MediaStream> GetExternalAudioStreams(
Video video,
int startIndex,
IDirectoryService directoryService,
- NamingOptions namingOptions,
bool clearCache,
- ILocalizationManager localizationManager,
- IMediaEncoder mediaEncoder,
CancellationToken cancellationToken)
{
- var streams = new List<MediaStream>();
-
if (!video.IsFileProtocol)
{
- return streams;
+ yield break;
}
- List<string> paths = GetExternalAudioFiles(video, directoryService, namingOptions, clearCache);
+ IEnumerable<string> paths = GetExternalAudioFiles(video, directoryService, clearCache);
+ foreach (string path in paths)
+ {
+ string fileNameWithoutExtension = Path.GetFileNameWithoutExtension(path);
+ Model.MediaInfo.MediaInfo mediaInfo = await GetMediaInfo(path, cancellationToken);
- await AddExternalAudioStreams(streams, paths, startIndex, localizationManager, mediaEncoder, cancellationToken).ConfigureAwait(false);
+ foreach (MediaStream mediaStream in mediaInfo.MediaStreams)
+ {
+ mediaStream.Index = startIndex++;
+ mediaStream.Type = MediaStreamType.Audio;
+ mediaStream.IsExternal = true;
+ mediaStream.Path = path;
+ mediaStream.IsDefault = false;
+ mediaStream.Title = null;
- return streams;
+ if (string.IsNullOrEmpty(mediaStream.Language))
+ {
+ // Try to translate to three character code
+ // Be flexible and check against both the full and three character versions
+ var language = StringExtensions.RightPart(fileNameWithoutExtension, '.').ToString();
+
+ if (language != fileNameWithoutExtension)
+ {
+ var culture = _localizationManager.FindLanguageInfo(language);
+
+ language = culture == null ? language : culture.ThreeLetterISOLanguageName;
+ mediaStream.Language = language;
+ }
+ }
+
+ yield return mediaStream;
+ }
+ }
}
public IEnumerable<string> GetExternalAudioFiles(
Video video,
IDirectoryService directoryService,
- NamingOptions namingOptions,
bool clearCache)
{
- List<string> paths = new List<string>();
-
if (!video.IsFileProtocol)
{
- return paths;
+ yield break;
}
- paths.AddRange(GetAudioFilesFromFolder(video.ContainingFolderPath, video.Path, directoryService, namingOptions, clearCache));
-
- return paths;
- }
-
- private List<string> GetAudioFilesFromFolder(
- string folder,
- string videoFileName,
- IDirectoryService directoryService,
- NamingOptions namingOptions,
- bool clearCache)
- {
- List<string> paths = new List<string>();
- string videoFileNameWithoutExtension = Path.GetFileNameWithoutExtension(videoFileName);
-
+ // Check if video folder exists
+ string folder = video.ContainingFolderPath;
if (!Directory.Exists(folder))
{
- return paths;
+ yield break;
}
+ string videoFileNameWithoutExtension = Path.GetFileNameWithoutExtension(video.Path);
+
var files = directoryService.GetFilePaths(folder, clearCache, true);
for (int i = 0; i < files.Count; i++)
{
- string fileNameWithoutExtension = Path.GetFileNameWithoutExtension(files[i]);
+ string file = files[i];
+ string fileNameWithoutExtension = Path.GetFileNameWithoutExtension(file);
- if (!AudioFileParser.IsAudioFile(files[i], namingOptions))
+ if (!AudioFileParser.IsAudioFile(file, _namingOptions))
{
continue;
}
@@ -94,60 +118,16 @@ namespace MediaBrowser.Providers.MediaInfo
&& fileNameWithoutExtension[videoFileNameWithoutExtension.Length] == '.'
&& fileNameWithoutExtension.StartsWith(videoFileNameWithoutExtension, StringComparison.OrdinalIgnoreCase)))
{
- paths.Add(files[i]);
- }
- }
-
- return paths;
- }
-
- public async Task AddExternalAudioStreams(
- List<MediaStream> streams,
- List<string> paths,
- int startIndex,
- ILocalizationManager localizationManager,
- IMediaEncoder mediaEncoder,
- CancellationToken cancellationToken)
- {
- foreach (string path in paths)
- {
- string fileNameWithoutExtension = Path.GetFileNameWithoutExtension(path);
- Model.MediaInfo.MediaInfo mediaInfo = await GetMediaInfo(path, mediaEncoder, cancellationToken);
-
- foreach (MediaStream mediaStream in mediaInfo.MediaStreams)
- {
- mediaStream.Index = startIndex++;
- mediaStream.Type = MediaStreamType.Audio;
- mediaStream.IsExternal = true;
- mediaStream.Path = path;
- mediaStream.IsDefault = false;
- mediaStream.Title = null;
-
- if (string.IsNullOrEmpty(mediaStream.Language))
- {
- // Try to translate to three character code
- // Be flexible and check against both the full and three character versions
- var language = StringExtensions.RightPart(fileNameWithoutExtension, '.').ToString();
-
- if (language != fileNameWithoutExtension)
- {
- var culture = localizationManager.FindLanguageInfo(language);
-
- language = culture == null ? language : culture.ThreeLetterISOLanguageName;
- mediaStream.Language = language;
- }
- }
-
- streams.Add(mediaStream);
+ yield return file;
}
}
}
- private Task<Model.MediaInfo.MediaInfo> GetMediaInfo(string path, IMediaEncoder mediaEncoder, CancellationToken cancellationToken)
+ private Task<Model.MediaInfo.MediaInfo> GetMediaInfo(string path, CancellationToken cancellationToken)
{
cancellationToken.ThrowIfCancellationRequested();
- return mediaEncoder.GetMediaInfo(
+ return _mediaEncoder.GetMediaInfo(
new MediaInfoRequest
{
MediaType = DlnaProfileType.Audio,