|  | @@ -309,14 +309,14 @@ namespace MediaBrowser.Model.Dlna
 | 
	
		
			
				|  |  |              return list;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -        public List<SubtitleStreamInfo> GetExternalSubtitles(bool includeSelectedTrackOnly, string baseUrl, string accessToken)
 | 
	
		
			
				|  |  | +        public List<SubtitleStreamInfo> GetExternalSubtitles(ITranscoderSupport transcoderSupport, bool includeSelectedTrackOnly, string baseUrl, string accessToken)
 | 
	
		
			
				|  |  |          {
 | 
	
		
			
				|  |  | -            return GetExternalSubtitles(includeSelectedTrackOnly, false, baseUrl, accessToken);
 | 
	
		
			
				|  |  | +            return GetExternalSubtitles(transcoderSupport, includeSelectedTrackOnly, false, baseUrl, accessToken);
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -        public List<SubtitleStreamInfo> GetExternalSubtitles(bool includeSelectedTrackOnly, bool enableAllProfiles, string baseUrl, string accessToken)
 | 
	
		
			
				|  |  | +        public List<SubtitleStreamInfo> GetExternalSubtitles(ITranscoderSupport transcoderSupport, bool includeSelectedTrackOnly, bool enableAllProfiles, string baseUrl, string accessToken)
 | 
	
		
			
				|  |  |          {
 | 
	
		
			
				|  |  | -            List<SubtitleStreamInfo> list = GetSubtitleProfiles(includeSelectedTrackOnly, enableAllProfiles, baseUrl, accessToken);
 | 
	
		
			
				|  |  | +            List<SubtitleStreamInfo> list = GetSubtitleProfiles(transcoderSupport, includeSelectedTrackOnly, enableAllProfiles, baseUrl, accessToken);
 | 
	
		
			
				|  |  |              List<SubtitleStreamInfo> newList = new List<SubtitleStreamInfo>();
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |              // First add the selected track
 | 
	
	
		
			
				|  | @@ -331,12 +331,12 @@ namespace MediaBrowser.Model.Dlna
 | 
	
		
			
				|  |  |              return newList;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -        public List<SubtitleStreamInfo> GetSubtitleProfiles(bool includeSelectedTrackOnly, string baseUrl, string accessToken)
 | 
	
		
			
				|  |  | +        public List<SubtitleStreamInfo> GetSubtitleProfiles(ITranscoderSupport transcoderSupport, bool includeSelectedTrackOnly, string baseUrl, string accessToken)
 | 
	
		
			
				|  |  |          {
 | 
	
		
			
				|  |  | -            return GetSubtitleProfiles(includeSelectedTrackOnly, false, baseUrl, accessToken);
 | 
	
		
			
				|  |  | +            return GetSubtitleProfiles(transcoderSupport, includeSelectedTrackOnly, false, baseUrl, accessToken);
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -        public List<SubtitleStreamInfo> GetSubtitleProfiles(bool includeSelectedTrackOnly, bool enableAllProfiles, string baseUrl, string accessToken)
 | 
	
		
			
				|  |  | +        public List<SubtitleStreamInfo> GetSubtitleProfiles(ITranscoderSupport transcoderSupport, bool includeSelectedTrackOnly, bool enableAllProfiles, string baseUrl, string accessToken)
 | 
	
		
			
				|  |  |          {
 | 
	
		
			
				|  |  |              List<SubtitleStreamInfo> list = new List<SubtitleStreamInfo>();
 | 
	
		
			
				|  |  |  
 | 
	
	
		
			
				|  | @@ -352,7 +352,7 @@ namespace MediaBrowser.Model.Dlna
 | 
	
		
			
				|  |  |                  {
 | 
	
		
			
				|  |  |                      if (stream.Type == MediaStreamType.Subtitle && stream.Index == SubtitleStreamIndex.Value)
 | 
	
		
			
				|  |  |                      {
 | 
	
		
			
				|  |  | -                        AddSubtitleProfiles(list, stream, enableAllProfiles, baseUrl, accessToken, startPositionTicks);
 | 
	
		
			
				|  |  | +                        AddSubtitleProfiles(list, stream, transcoderSupport, enableAllProfiles, baseUrl, accessToken, startPositionTicks);
 | 
	
		
			
				|  |  |                      }
 | 
	
		
			
				|  |  |                  }
 | 
	
		
			
				|  |  |              }
 | 
	
	
		
			
				|  | @@ -363,7 +363,7 @@ namespace MediaBrowser.Model.Dlna
 | 
	
		
			
				|  |  |                  {
 | 
	
		
			
				|  |  |                      if (stream.Type == MediaStreamType.Subtitle && (!SubtitleStreamIndex.HasValue || stream.Index != SubtitleStreamIndex.Value))
 | 
	
		
			
				|  |  |                      {
 | 
	
		
			
				|  |  | -                        AddSubtitleProfiles(list, stream, enableAllProfiles, baseUrl, accessToken, startPositionTicks);
 | 
	
		
			
				|  |  | +                        AddSubtitleProfiles(list, stream, transcoderSupport, enableAllProfiles, baseUrl, accessToken, startPositionTicks);
 | 
	
		
			
				|  |  |                      }
 | 
	
		
			
				|  |  |                  }
 | 
	
		
			
				|  |  |              }
 | 
	
	
		
			
				|  | @@ -371,28 +371,28 @@ namespace MediaBrowser.Model.Dlna
 | 
	
		
			
				|  |  |              return list;
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -        private void AddSubtitleProfiles(List<SubtitleStreamInfo> list, MediaStream stream, bool enableAllProfiles, string baseUrl, string accessToken, long startPositionTicks)
 | 
	
		
			
				|  |  | +        private void AddSubtitleProfiles(List<SubtitleStreamInfo> list, MediaStream stream, ITranscoderSupport transcoderSupport, bool enableAllProfiles, string baseUrl, string accessToken, long startPositionTicks)
 | 
	
		
			
				|  |  |          {
 | 
	
		
			
				|  |  |              if (enableAllProfiles)
 | 
	
		
			
				|  |  |              {
 | 
	
		
			
				|  |  |                  foreach (SubtitleProfile profile in DeviceProfile.SubtitleProfiles)
 | 
	
		
			
				|  |  |                  {
 | 
	
		
			
				|  |  | -                    SubtitleStreamInfo info = GetSubtitleStreamInfo(stream, baseUrl, accessToken, startPositionTicks, new[] { profile });
 | 
	
		
			
				|  |  | +                    SubtitleStreamInfo info = GetSubtitleStreamInfo(stream, baseUrl, accessToken, startPositionTicks, new[] { profile }, transcoderSupport);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |                      list.Add(info);
 | 
	
		
			
				|  |  |                  }
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  |              else
 | 
	
		
			
				|  |  |              {
 | 
	
		
			
				|  |  | -                SubtitleStreamInfo info = GetSubtitleStreamInfo(stream, baseUrl, accessToken, startPositionTicks, DeviceProfile.SubtitleProfiles);
 | 
	
		
			
				|  |  | +                SubtitleStreamInfo info = GetSubtitleStreamInfo(stream, baseUrl, accessToken, startPositionTicks, DeviceProfile.SubtitleProfiles, transcoderSupport);
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  |                  list.Add(info);
 | 
	
		
			
				|  |  |              }
 | 
	
		
			
				|  |  |          }
 | 
	
		
			
				|  |  |  
 | 
	
		
			
				|  |  | -        private SubtitleStreamInfo GetSubtitleStreamInfo(MediaStream stream, string baseUrl, string accessToken, long startPositionTicks, SubtitleProfile[] subtitleProfiles)
 | 
	
		
			
				|  |  | +        private SubtitleStreamInfo GetSubtitleStreamInfo(MediaStream stream, string baseUrl, string accessToken, long startPositionTicks, SubtitleProfile[] subtitleProfiles, ITranscoderSupport transcoderSupport)
 | 
	
		
			
				|  |  |          {
 | 
	
		
			
				|  |  | -            SubtitleProfile subtitleProfile = StreamBuilder.GetSubtitleProfile(stream, subtitleProfiles, PlayMethod, SubProtocol, Container);
 | 
	
		
			
				|  |  | +            SubtitleProfile subtitleProfile = StreamBuilder.GetSubtitleProfile(stream, subtitleProfiles, PlayMethod, transcoderSupport, SubProtocol, Container);
 | 
	
		
			
				|  |  |              SubtitleStreamInfo info = new SubtitleStreamInfo
 | 
	
		
			
				|  |  |              {
 | 
	
		
			
				|  |  |                  IsForced = stream.IsForced,
 |