| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091 | 
							- using MediaBrowser.Common.Configuration;
 
- using MediaBrowser.Common.IO;
 
- using MediaBrowser.Controller.LiveTv;
 
- using MediaBrowser.Model.IO;
 
- using MediaBrowser.Model.Logging;
 
- using System.Collections.Generic;
 
- using System.Globalization;
 
- using System.Threading.Tasks;
 
- namespace MediaBrowser.MediaEncoding.Encoder
 
- {
 
-     public class AudioEncoder
 
-     {
 
-         private readonly string _ffmpegPath;
 
-         private readonly ILogger _logger;
 
-         private readonly IFileSystem _fileSystem;
 
-         private readonly IApplicationPaths _appPaths;
 
-         private readonly IIsoManager _isoManager;
 
-         private readonly ILiveTvManager _liveTvManager;
 
-         private readonly CultureInfo _usCulture = new CultureInfo("en-US");
 
-         public AudioEncoder(string ffmpegPath, ILogger logger, IFileSystem fileSystem, IApplicationPaths appPaths, IIsoManager isoManager, ILiveTvManager liveTvManager)
 
-         {
 
-             _ffmpegPath = ffmpegPath;
 
-             _logger = logger;
 
-             _fileSystem = fileSystem;
 
-             _appPaths = appPaths;
 
-             _isoManager = isoManager;
 
-             _liveTvManager = liveTvManager;
 
-         }
 
-         public Task BeginEncoding(InternalEncodingTask task)
 
-         {
 
-             return new FFMpegProcess(_ffmpegPath, _logger, _fileSystem, _appPaths, _isoManager, _liveTvManager).Start(task, GetArguments);
 
-         }
 
-         private string GetArguments(InternalEncodingTask task, string mountedPath)
 
-         {
 
-             var options = task.Request;
 
-             return string.Format("{0} -i {1} {2} -id3v2_version 3 -write_id3v1 1 \"{3}\"",
 
-                 GetInputModifier(task),
 
-                 GetInputArgument(task),
 
-                 GetOutputModifier(task),
 
-                 options.OutputPath).Trim();
 
-         }
 
-         private string GetInputModifier(InternalEncodingTask task)
 
-         {
 
-             return EncodingUtils.GetInputModifier(task);
 
-         }
 
-         private string GetInputArgument(InternalEncodingTask task)
 
-         {
 
-             return EncodingUtils.GetInputArgument(new List<string> { task.MediaPath }, task.IsInputRemote);
 
-         }
 
-         private string GetOutputModifier(InternalEncodingTask task)
 
-         {
 
-             var options = task.Request;
 
-             var audioTranscodeParams = new List<string>
 
-             {
 
-                 "-threads " + EncodingUtils.GetNumberOfThreads(task, false).ToString(_usCulture),
 
-                 "-vn"
 
-             };
 
-             var bitrate = EncodingUtils.GetAudioBitrateParam(task);
 
-             if (bitrate.HasValue)
 
-             {
 
-                 audioTranscodeParams.Add("-ab " + bitrate.Value.ToString(_usCulture));
 
-             }
 
-             var channels = EncodingUtils.GetNumAudioChannelsParam(options, task.AudioStream);
 
-             if (channels.HasValue)
 
-             {
 
-                 audioTranscodeParams.Add("-ac " + channels.Value);
 
-             }
 
-             if (options.AudioSampleRate.HasValue)
 
-             {
 
-                 audioTranscodeParams.Add("-ar " + options.AudioSampleRate.Value);
 
-             }
 
-             return string.Join(" ", audioTranscodeParams.ToArray());
 
-         }
 
-     }
 
- }
 
 
  |