浏览代码

Remove more warnings

Cody Robibero 3 年之前
父节点
当前提交
7bfc6b5679
共有 50 个文件被更改,包括 231 次插入265 次删除
  1. 5 5
      Emby.Drawing/ImageProcessor.cs
  2. 3 3
      Emby.Naming/TV/SeasonPathParser.cs
  3. 3 5
      Emby.Server.Implementations/Channels/ChannelManager.cs
  4. 1 1
      Emby.Server.Implementations/Collections/CollectionManager.cs
  5. 41 77
      Emby.Server.Implementations/Data/SqliteItemRepository.cs
  6. 1 0
      Emby.Server.Implementations/EntryPoints/LibraryChangedNotifier.cs
  7. 10 10
      Emby.Server.Implementations/IO/StreamHelper.cs
  8. 2 2
      Emby.Server.Implementations/Images/CollectionFolderImageProvider.cs
  9. 7 7
      Emby.Server.Implementations/Library/LibraryManager.cs
  10. 3 4
      Emby.Server.Implementations/Library/MediaSourceManager.cs
  11. 1 1
      Emby.Server.Implementations/Library/SearchEngine.cs
  12. 2 0
      Emby.Server.Implementations/LiveTv/Listings/SchedulesDirect.cs
  13. 17 20
      Emby.Server.Implementations/LiveTv/LiveTvManager.cs
  14. 1 1
      Emby.Server.Implementations/LiveTv/TunerHosts/HdHomerun/HdHomerunChannelCommands.cs
  15. 2 2
      Emby.Server.Implementations/LiveTv/TunerHosts/HdHomerun/HdHomerunManager.cs
  16. 1 1
      Emby.Server.Implementations/LiveTv/TunerHosts/HdHomerun/HdHomerunUdpStream.cs
  17. 1 1
      Emby.Server.Implementations/LiveTv/TunerHosts/HdHomerun/IHdHomerunChannelCommands.cs
  18. 1 1
      Emby.Server.Implementations/LiveTv/TunerHosts/HdHomerun/LegacyHdHomerunChannelCommands.cs
  19. 1 1
      Emby.Server.Implementations/Playlists/PlaylistManager.cs
  20. 3 3
      Emby.Server.Implementations/TV/TVSeriesManager.cs
  21. 3 3
      Emby.Server.Implementations/Updates/InstallationManager.cs
  22. 4 4
      Jellyfin.Api/Controllers/FilterController.cs
  23. 1 1
      Jellyfin.Api/Controllers/ItemsController.cs
  24. 1 1
      Jellyfin.Api/Helpers/RequestHelpers.cs
  25. 7 7
      Jellyfin.Server.Implementations/Users/UserManager.cs
  26. 2 2
      Jellyfin.Server/Migrations/PreStartupRoutines/CreateNetworkConfiguration.cs
  27. 1 1
      MediaBrowser.Common/Net/IPNetAddress.cs
  28. 1 1
      MediaBrowser.Common/Net/IPObject.cs
  29. 1 1
      MediaBrowser.Controller/Drawing/IImageProcessor.cs
  30. 1 1
      MediaBrowser.Controller/Entities/Audio/Audio.cs
  31. 2 2
      MediaBrowser.Controller/Entities/BaseItem.cs
  32. 2 2
      MediaBrowser.Controller/Entities/InternalItemsQuery.cs
  33. 1 1
      MediaBrowser.Controller/Entities/Video.cs
  34. 7 7
      MediaBrowser.Controller/Library/ILibraryManager.cs
  35. 2 2
      MediaBrowser.Controller/LiveTv/ILiveTvManager.cs
  36. 25 25
      MediaBrowser.Controller/MediaEncoding/EncodingHelper.cs
  37. 1 1
      MediaBrowser.Controller/MediaEncoding/IAttachmentExtractor.cs
  38. 3 3
      MediaBrowser.Controller/MediaEncoding/IMediaEncoder.cs
  39. 1 1
      MediaBrowser.Controller/MediaEncoding/JobLogger.cs
  40. 6 6
      MediaBrowser.Controller/Persistence/IItemRepository.cs
  41. 3 3
      MediaBrowser.Controller/Providers/MetadataResult.cs
  42. 1 1
      MediaBrowser.MediaEncoding/Attachments/AttachmentExtractor.cs
  43. 4 0
      MediaBrowser.MediaEncoding/Encoder/MediaEncoder.cs
  44. 5 5
      MediaBrowser.MediaEncoding/Subtitles/SubtitleEncoder.cs
  45. 13 13
      MediaBrowser.Model/Dlna/StreamBuilder.cs
  46. 2 2
      MediaBrowser.Model/Session/GeneralCommandType.cs
  47. 2 2
      MediaBrowser.Providers/Manager/MetadataService.cs
  48. 5 5
      MediaBrowser.Providers/Plugins/MusicBrainz/MusicBrainzAlbumProvider.cs
  49. 1 1
      MediaBrowser.XbmcMetadata/Parsers/BaseNfoParser.cs
  50. 17 16
      tests/Jellyfin.XbmcMetadata.Tests/Parsers/MovieNfoParserTests.cs

+ 5 - 5
Emby.Drawing/ImageProcessor.cs

@@ -101,7 +101,7 @@ namespace Emby.Drawing
         public async Task ProcessImage(ImageProcessingOptions options, Stream toStream)
         public async Task ProcessImage(ImageProcessingOptions options, Stream toStream)
         {
         {
             var file = await ProcessImage(options).ConfigureAwait(false);
             var file = await ProcessImage(options).ConfigureAwait(false);
-            using (var fileStream = AsyncFile.OpenRead(file.path))
+            using (var fileStream = AsyncFile.OpenRead(file.Path))
             {
             {
                 await fileStream.CopyToAsync(toStream).ConfigureAwait(false);
                 await fileStream.CopyToAsync(toStream).ConfigureAwait(false);
             }
             }
@@ -116,7 +116,7 @@ namespace Emby.Drawing
             => _transparentImageTypes.Contains(Path.GetExtension(path));
             => _transparentImageTypes.Contains(Path.GetExtension(path));
 
 
         /// <inheritdoc />
         /// <inheritdoc />
-        public async Task<(string path, string? mimeType, DateTime dateModified)> ProcessImage(ImageProcessingOptions options)
+        public async Task<(string Path, string? MimeType, DateTime DateModified)> ProcessImage(ImageProcessingOptions options)
         {
         {
             ItemImageInfo originalImage = options.Image;
             ItemImageInfo originalImage = options.Image;
             BaseItem item = options.Item;
             BaseItem item = options.Item;
@@ -135,14 +135,14 @@ namespace Emby.Drawing
             }
             }
 
 
             var supportedImageInfo = await GetSupportedImage(originalImagePath, dateModified).ConfigureAwait(false);
             var supportedImageInfo = await GetSupportedImage(originalImagePath, dateModified).ConfigureAwait(false);
-            originalImagePath = supportedImageInfo.path;
+            originalImagePath = supportedImageInfo.Path;
 
 
             if (!File.Exists(originalImagePath))
             if (!File.Exists(originalImagePath))
             {
             {
                 return (originalImagePath, MimeTypes.GetMimeType(originalImagePath), dateModified);
                 return (originalImagePath, MimeTypes.GetMimeType(originalImagePath), dateModified);
             }
             }
 
 
-            dateModified = supportedImageInfo.dateModified;
+            dateModified = supportedImageInfo.DateModified;
             bool requiresTransparency = _transparentImageTypes.Contains(Path.GetExtension(originalImagePath));
             bool requiresTransparency = _transparentImageTypes.Contains(Path.GetExtension(originalImagePath));
 
 
             bool autoOrient = false;
             bool autoOrient = false;
@@ -436,7 +436,7 @@ namespace Emby.Drawing
                 .ToString("N", CultureInfo.InvariantCulture);
                 .ToString("N", CultureInfo.InvariantCulture);
         }
         }
 
 
-        private async Task<(string path, DateTime dateModified)> GetSupportedImage(string originalImagePath, DateTime dateModified)
+        private async Task<(string Path, DateTime DateModified)> GetSupportedImage(string originalImagePath, DateTime dateModified)
         {
         {
             var inputFormat = Path.GetExtension(originalImagePath)
             var inputFormat = Path.GetExtension(originalImagePath)
                 .TrimStart('.')
                 .TrimStart('.')

+ 3 - 3
Emby.Naming/TV/SeasonPathParser.cs

@@ -55,7 +55,7 @@ namespace Emby.Naming.TV
         /// <param name="supportSpecialAliases">if set to <c>true</c> [support special aliases].</param>
         /// <param name="supportSpecialAliases">if set to <c>true</c> [support special aliases].</param>
         /// <param name="supportNumericSeasonFolders">if set to <c>true</c> [support numeric season folders].</param>
         /// <param name="supportNumericSeasonFolders">if set to <c>true</c> [support numeric season folders].</param>
         /// <returns>System.Nullable{System.Int32}.</returns>
         /// <returns>System.Nullable{System.Int32}.</returns>
-        private static (int? seasonNumber, bool isSeasonFolder) GetSeasonNumberFromPath(
+        private static (int? SeasonNumber, bool IsSeasonFolder) GetSeasonNumberFromPath(
             string path,
             string path,
             bool supportSpecialAliases,
             bool supportSpecialAliases,
             bool supportNumericSeasonFolders)
             bool supportNumericSeasonFolders)
@@ -99,7 +99,7 @@ namespace Emby.Naming.TV
                 if (filename.Contains(name, StringComparison.OrdinalIgnoreCase))
                 if (filename.Contains(name, StringComparison.OrdinalIgnoreCase))
                 {
                 {
                     var result = GetSeasonNumberFromPathSubstring(filename.Replace(name, " ", StringComparison.OrdinalIgnoreCase));
                     var result = GetSeasonNumberFromPathSubstring(filename.Replace(name, " ", StringComparison.OrdinalIgnoreCase));
-                    if (result.seasonNumber.HasValue)
+                    if (result.SeasonNumber.HasValue)
                     {
                     {
                         return result;
                         return result;
                     }
                     }
@@ -142,7 +142,7 @@ namespace Emby.Naming.TV
         /// </summary>
         /// </summary>
         /// <param name="path">The path.</param>
         /// <param name="path">The path.</param>
         /// <returns>System.Nullable{System.Int32}.</returns>
         /// <returns>System.Nullable{System.Int32}.</returns>
-        private static (int? seasonNumber, bool isSeasonFolder) GetSeasonNumberFromPathSubstring(ReadOnlySpan<char> path)
+        private static (int? SeasonNumber, bool IsSeasonFolder) GetSeasonNumberFromPathSubstring(ReadOnlySpan<char> path)
         {
         {
             var numericStart = -1;
             var numericStart = -1;
             var length = 0;
             var length = 0;

+ 3 - 5
Emby.Server.Implementations/Channels/ChannelManager.cs

@@ -130,16 +130,14 @@ namespace Emby.Server.Implementations.Channels
             var internalChannel = _libraryManager.GetItemById(item.ChannelId);
             var internalChannel = _libraryManager.GetItemById(item.ChannelId);
             if (internalChannel == null)
             if (internalChannel == null)
             {
             {
-                throw new ArgumentException();
+                throw new ArgumentException(nameof(item.ChannelId));
             }
             }
 
 
             var channel = Channels.FirstOrDefault(i => GetInternalChannelId(i.Name).Equals(internalChannel.Id));
             var channel = Channels.FirstOrDefault(i => GetInternalChannelId(i.Name).Equals(internalChannel.Id));
 
 
-            var supportsDelete = channel as ISupportsDelete;
-
-            if (supportsDelete == null)
+            if (channel is not ISupportsDelete supportsDelete)
             {
             {
-                throw new ArgumentException();
+                throw new ArgumentException(nameof(channel));
             }
             }
 
 
             return supportsDelete.DeleteItem(item.ExternalId, CancellationToken.None);
             return supportsDelete.DeleteItem(item.ExternalId, CancellationToken.None);

+ 1 - 1
Emby.Server.Implementations/Collections/CollectionManager.cs

@@ -140,7 +140,7 @@ namespace Emby.Server.Implementations.Collections
 
 
             if (parentFolder == null)
             if (parentFolder == null)
             {
             {
-                throw new ArgumentException();
+                throw new ArgumentException(nameof(parentFolder));
             }
             }
 
 
             var path = Path.Combine(parentFolder.Path, folderName);
             var path = Path.Combine(parentFolder.Path, folderName);

+ 41 - 77
Emby.Server.Implementations/Data/SqliteItemRepository.cs

@@ -248,40 +248,6 @@ namespace Emby.Server.Implementations.Data
             BaseItemKind.AudioBook
             BaseItemKind.AudioBook
         };
         };
 
 
-        private static readonly Type[] _knownTypes =
-        {
-            typeof(LiveTvProgram),
-            typeof(LiveTvChannel),
-            typeof(Series),
-            typeof(Audio),
-            typeof(MusicAlbum),
-            typeof(MusicArtist),
-            typeof(MusicGenre),
-            typeof(MusicVideo),
-            typeof(Movie),
-            typeof(Playlist),
-            typeof(AudioBook),
-            typeof(Trailer),
-            typeof(BoxSet),
-            typeof(Episode),
-            typeof(Season),
-            typeof(Series),
-            typeof(Book),
-            typeof(CollectionFolder),
-            typeof(Folder),
-            typeof(Genre),
-            typeof(Person),
-            typeof(Photo),
-            typeof(PhotoAlbum),
-            typeof(Studio),
-            typeof(UserRootFolder),
-            typeof(UserView),
-            typeof(Video),
-            typeof(Year),
-            typeof(Channel),
-            typeof(AggregateFolder)
-        };
-
         private static readonly Dictionary<BaseItemKind, string> _baseItemKindNames = new()
         private static readonly Dictionary<BaseItemKind, string> _baseItemKindNames = new()
         {
         {
             { BaseItemKind.AggregateFolder, typeof(AggregateFolder).FullName },
             { BaseItemKind.AggregateFolder, typeof(AggregateFolder).FullName },
@@ -688,13 +654,13 @@ namespace Emby.Server.Implementations.Data
                 connection.RunInTransaction(
                 connection.RunInTransaction(
                     db =>
                     db =>
                     {
                     {
-                        SaveItemsInTranscation(db, tuples);
+                        SaveItemsInTransaction(db, tuples);
                     },
                     },
                     TransactionMode);
                     TransactionMode);
             }
             }
         }
         }
 
 
-        private void SaveItemsInTranscation(IDatabaseConnection db, IEnumerable<(BaseItem, List<Guid>, BaseItem, string, List<string>)> tuples)
+        private void SaveItemsInTransaction(IDatabaseConnection db, IEnumerable<(BaseItem Item, List<Guid> AncestorIds, BaseItem TopParent, string UserDataKey, List<string> InheritedTags)> tuples)
         {
         {
             var statements = PrepareAll(db, new string[]
             var statements = PrepareAll(db, new string[]
             {
             {
@@ -713,17 +679,17 @@ namespace Emby.Server.Implementations.Data
                         saveItemStatement.Reset();
                         saveItemStatement.Reset();
                     }
                     }
 
 
-                    var item = tuple.Item1;
-                    var topParent = tuple.Item3;
-                    var userDataKey = tuple.Item4;
+                    var item = tuple.Item;
+                    var topParent = tuple.TopParent;
+                    var userDataKey = tuple.UserDataKey;
 
 
                     SaveItem(item, topParent, userDataKey, saveItemStatement);
                     SaveItem(item, topParent, userDataKey, saveItemStatement);
 
 
-                    var inheritedTags = tuple.Item5;
+                    var inheritedTags = tuple.InheritedTags;
 
 
                     if (item.SupportsAncestors)
                     if (item.SupportsAncestors)
                     {
                     {
-                        UpdateAncestors(item.Id, tuple.Item2, db, deleteAncestorsStatement);
+                        UpdateAncestors(item.Id, tuple.AncestorIds, db, deleteAncestorsStatement);
                     }
                     }
 
 
                     UpdateItemValues(item.Id, GetItemValuesToSave(item, inheritedTags), db);
                     UpdateItemValues(item.Id, GetItemValuesToSave(item, inheritedTags), db);
@@ -2201,7 +2167,7 @@ namespace Emby.Server.Implementations.Data
                 return false;
                 return false;
             }
             }
 
 
-            var sortingFields = new HashSet<string>(query.OrderBy.Select(i => i.Item1), StringComparer.OrdinalIgnoreCase);
+            var sortingFields = new HashSet<string>(query.OrderBy.Select(i => i.OrderBy), StringComparer.OrdinalIgnoreCase);
 
 
             return sortingFields.Contains(ItemSortBy.IsFavoriteOrLiked)
             return sortingFields.Contains(ItemSortBy.IsFavoriteOrLiked)
                     || sortingFields.Contains(ItemSortBy.IsPlayed)
                     || sortingFields.Contains(ItemSortBy.IsPlayed)
@@ -3049,88 +3015,86 @@ namespace Emby.Server.Implementations.Data
 
 
             return " ORDER BY " + string.Join(',', orderBy.Select(i =>
             return " ORDER BY " + string.Join(',', orderBy.Select(i =>
             {
             {
-                var columnMap = MapOrderByField(i.Item1, query);
-
-                var sortOrder = i.Item2 == SortOrder.Ascending ? "ASC" : "DESC";
+                var columnMap = MapOrderByField(i.OrderBy, query);
 
 
-                return columnMap.Item1 + " " + sortOrder;
+                return columnMap.SortBy + " " + columnMap.SortOrder;
             }));
             }));
         }
         }
 
 
-        private (string, bool) MapOrderByField(string name, InternalItemsQuery query)
+        private (string SortBy, SortOrder SortOrder) MapOrderByField(string name, InternalItemsQuery query)
         {
         {
             if (string.Equals(name, ItemSortBy.AirTime, StringComparison.OrdinalIgnoreCase))
             if (string.Equals(name, ItemSortBy.AirTime, StringComparison.OrdinalIgnoreCase))
             {
             {
                 // TODO
                 // TODO
-                return ("SortName", false);
+                return ("SortName", SortOrder.Descending);
             }
             }
             else if (string.Equals(name, ItemSortBy.Runtime, StringComparison.OrdinalIgnoreCase))
             else if (string.Equals(name, ItemSortBy.Runtime, StringComparison.OrdinalIgnoreCase))
             {
             {
-                return ("RuntimeTicks", false);
+                return ("RuntimeTicks", SortOrder.Descending);
             }
             }
             else if (string.Equals(name, ItemSortBy.Random, StringComparison.OrdinalIgnoreCase))
             else if (string.Equals(name, ItemSortBy.Random, StringComparison.OrdinalIgnoreCase))
             {
             {
-                return ("RANDOM()", false);
+                return ("RANDOM()", SortOrder.Descending);
             }
             }
             else if (string.Equals(name, ItemSortBy.DatePlayed, StringComparison.OrdinalIgnoreCase))
             else if (string.Equals(name, ItemSortBy.DatePlayed, StringComparison.OrdinalIgnoreCase))
             {
             {
                 if (query.GroupBySeriesPresentationUniqueKey)
                 if (query.GroupBySeriesPresentationUniqueKey)
                 {
                 {
-                    return ("MAX(LastPlayedDate)", false);
+                    return ("MAX(LastPlayedDate)", SortOrder.Descending);
                 }
                 }
 
 
-                return ("LastPlayedDate", false);
+                return ("LastPlayedDate", SortOrder.Descending);
             }
             }
             else if (string.Equals(name, ItemSortBy.PlayCount, StringComparison.OrdinalIgnoreCase))
             else if (string.Equals(name, ItemSortBy.PlayCount, StringComparison.OrdinalIgnoreCase))
             {
             {
-                return ("PlayCount", false);
+                return ("PlayCount", SortOrder.Descending);
             }
             }
             else if (string.Equals(name, ItemSortBy.IsFavoriteOrLiked, StringComparison.OrdinalIgnoreCase))
             else if (string.Equals(name, ItemSortBy.IsFavoriteOrLiked, StringComparison.OrdinalIgnoreCase))
             {
             {
-                return ("(Select Case When IsFavorite is null Then 0 Else IsFavorite End )", true);
+                return ("(Select Case When IsFavorite is null Then 0 Else IsFavorite End )", SortOrder.Ascending);
             }
             }
             else if (string.Equals(name, ItemSortBy.IsFolder, StringComparison.OrdinalIgnoreCase))
             else if (string.Equals(name, ItemSortBy.IsFolder, StringComparison.OrdinalIgnoreCase))
             {
             {
-                return ("IsFolder", true);
+                return ("IsFolder", SortOrder.Ascending);
             }
             }
             else if (string.Equals(name, ItemSortBy.IsPlayed, StringComparison.OrdinalIgnoreCase))
             else if (string.Equals(name, ItemSortBy.IsPlayed, StringComparison.OrdinalIgnoreCase))
             {
             {
-                return ("played", true);
+                return ("played", SortOrder.Ascending);
             }
             }
             else if (string.Equals(name, ItemSortBy.IsUnplayed, StringComparison.OrdinalIgnoreCase))
             else if (string.Equals(name, ItemSortBy.IsUnplayed, StringComparison.OrdinalIgnoreCase))
             {
             {
-                return ("played", false);
+                return ("played", SortOrder.Descending);
             }
             }
             else if (string.Equals(name, ItemSortBy.DateLastContentAdded, StringComparison.OrdinalIgnoreCase))
             else if (string.Equals(name, ItemSortBy.DateLastContentAdded, StringComparison.OrdinalIgnoreCase))
             {
             {
-                return ("DateLastMediaAdded", false);
+                return ("DateLastMediaAdded", SortOrder.Descending);
             }
             }
             else if (string.Equals(name, ItemSortBy.Artist, StringComparison.OrdinalIgnoreCase))
             else if (string.Equals(name, ItemSortBy.Artist, StringComparison.OrdinalIgnoreCase))
             {
             {
-                return ("(select CleanValue from itemvalues where ItemId=Guid and Type=0 LIMIT 1)", false);
+                return ("(select CleanValue from itemvalues where ItemId=Guid and Type=0 LIMIT 1)", SortOrder.Descending);
             }
             }
             else if (string.Equals(name, ItemSortBy.AlbumArtist, StringComparison.OrdinalIgnoreCase))
             else if (string.Equals(name, ItemSortBy.AlbumArtist, StringComparison.OrdinalIgnoreCase))
             {
             {
-                return ("(select CleanValue from itemvalues where ItemId=Guid and Type=1 LIMIT 1)", false);
+                return ("(select CleanValue from itemvalues where ItemId=Guid and Type=1 LIMIT 1)", SortOrder.Descending);
             }
             }
             else if (string.Equals(name, ItemSortBy.OfficialRating, StringComparison.OrdinalIgnoreCase))
             else if (string.Equals(name, ItemSortBy.OfficialRating, StringComparison.OrdinalIgnoreCase))
             {
             {
-                return ("InheritedParentalRatingValue", false);
+                return ("InheritedParentalRatingValue", SortOrder.Descending);
             }
             }
             else if (string.Equals(name, ItemSortBy.Studio, StringComparison.OrdinalIgnoreCase))
             else if (string.Equals(name, ItemSortBy.Studio, StringComparison.OrdinalIgnoreCase))
             {
             {
-                return ("(select CleanValue from itemvalues where ItemId=Guid and Type=3 LIMIT 1)", false);
+                return ("(select CleanValue from itemvalues where ItemId=Guid and Type=3 LIMIT 1)", SortOrder.Descending);
             }
             }
             else if (string.Equals(name, ItemSortBy.SeriesDatePlayed, StringComparison.OrdinalIgnoreCase))
             else if (string.Equals(name, ItemSortBy.SeriesDatePlayed, StringComparison.OrdinalIgnoreCase))
             {
             {
-                return ("(Select MAX(LastPlayedDate) from TypedBaseItems B" + GetJoinUserDataText(query) + " where Played=1 and B.SeriesPresentationUniqueKey=A.PresentationUniqueKey)", false);
+                return ("(Select MAX(LastPlayedDate) from TypedBaseItems B" + GetJoinUserDataText(query) + " where Played=1 and B.SeriesPresentationUniqueKey=A.PresentationUniqueKey)", SortOrder.Descending);
             }
             }
             else if (string.Equals(name, ItemSortBy.SeriesSortName, StringComparison.OrdinalIgnoreCase))
             else if (string.Equals(name, ItemSortBy.SeriesSortName, StringComparison.OrdinalIgnoreCase))
             {
             {
-                return ("SeriesName", false);
+                return ("SeriesName", SortOrder.Descending);
             }
             }
 
 
-            return (name, false);
+            return (name, SortOrder.Descending);
         }
         }
 
 
         public List<Guid> GetItemIdsList(InternalItemsQuery query)
         public List<Guid> GetItemIdsList(InternalItemsQuery query)
@@ -5230,32 +5194,32 @@ AND Type = @InternalPersonType)");
             }
             }
         }
         }
 
 
-        public QueryResult<(BaseItem, ItemCounts)> GetAllArtists(InternalItemsQuery query)
+        public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetAllArtists(InternalItemsQuery query)
         {
         {
             return GetItemValues(query, new[] { 0, 1 }, typeof(MusicArtist).FullName);
             return GetItemValues(query, new[] { 0, 1 }, typeof(MusicArtist).FullName);
         }
         }
 
 
-        public QueryResult<(BaseItem, ItemCounts)> GetArtists(InternalItemsQuery query)
+        public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetArtists(InternalItemsQuery query)
         {
         {
             return GetItemValues(query, new[] { 0 }, typeof(MusicArtist).FullName);
             return GetItemValues(query, new[] { 0 }, typeof(MusicArtist).FullName);
         }
         }
 
 
-        public QueryResult<(BaseItem, ItemCounts)> GetAlbumArtists(InternalItemsQuery query)
+        public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetAlbumArtists(InternalItemsQuery query)
         {
         {
             return GetItemValues(query, new[] { 1 }, typeof(MusicArtist).FullName);
             return GetItemValues(query, new[] { 1 }, typeof(MusicArtist).FullName);
         }
         }
 
 
-        public QueryResult<(BaseItem, ItemCounts)> GetStudios(InternalItemsQuery query)
+        public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetStudios(InternalItemsQuery query)
         {
         {
             return GetItemValues(query, new[] { 3 }, typeof(Studio).FullName);
             return GetItemValues(query, new[] { 3 }, typeof(Studio).FullName);
         }
         }
 
 
-        public QueryResult<(BaseItem, ItemCounts)> GetGenres(InternalItemsQuery query)
+        public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetGenres(InternalItemsQuery query)
         {
         {
             return GetItemValues(query, new[] { 2 }, typeof(Genre).FullName);
             return GetItemValues(query, new[] { 2 }, typeof(Genre).FullName);
         }
         }
 
 
-        public QueryResult<(BaseItem, ItemCounts)> GetMusicGenres(InternalItemsQuery query)
+        public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetMusicGenres(InternalItemsQuery query)
         {
         {
             return GetItemValues(query, new[] { 2 }, typeof(MusicGenre).FullName);
             return GetItemValues(query, new[] { 2 }, typeof(MusicGenre).FullName);
         }
         }
@@ -5351,7 +5315,7 @@ AND Type = @InternalPersonType)");
             return list;
             return list;
         }
         }
 
 
-        private QueryResult<(BaseItem, ItemCounts)> GetItemValues(InternalItemsQuery query, int[] itemValueTypes, string returnType)
+        private QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetItemValues(InternalItemsQuery query, int[] itemValueTypes, string returnType)
         {
         {
             if (query == null)
             if (query == null)
             {
             {
@@ -5676,7 +5640,7 @@ AND Type = @InternalPersonType)");
             return counts;
             return counts;
         }
         }
 
 
-        private List<(int, string)> GetItemValuesToSave(BaseItem item, List<string> inheritedTags)
+        private List<(int MagicNumber, string Value)> GetItemValuesToSave(BaseItem item, List<string> inheritedTags)
         {
         {
             var list = new List<(int, string)>();
             var list = new List<(int, string)>();
 
 
@@ -5701,7 +5665,7 @@ AND Type = @InternalPersonType)");
             return list;
             return list;
         }
         }
 
 
-        private void UpdateItemValues(Guid itemId, List<(int, string)> values, IDatabaseConnection db)
+        private void UpdateItemValues(Guid itemId, List<(int MagicNumber, string Value)> values, IDatabaseConnection db)
         {
         {
             if (itemId.Equals(Guid.Empty))
             if (itemId.Equals(Guid.Empty))
             {
             {
@@ -5723,7 +5687,7 @@ AND Type = @InternalPersonType)");
             InsertItemValues(guidBlob, values, db);
             InsertItemValues(guidBlob, values, db);
         }
         }
 
 
-        private void InsertItemValues(byte[] idBlob, List<(int, string)> values, IDatabaseConnection db)
+        private void InsertItemValues(byte[] idBlob, List<(int MagicNumber, string Value)> values, IDatabaseConnection db)
         {
         {
             const int Limit = 100;
             const int Limit = 100;
             var startIndex = 0;
             var startIndex = 0;
@@ -5755,7 +5719,7 @@ AND Type = @InternalPersonType)");
 
 
                         var currentValueInfo = values[i];
                         var currentValueInfo = values[i];
 
 
-                        var itemValue = currentValueInfo.Item2;
+                        var itemValue = currentValueInfo.Value;
 
 
                         // Don't save if invalid
                         // Don't save if invalid
                         if (string.IsNullOrWhiteSpace(itemValue))
                         if (string.IsNullOrWhiteSpace(itemValue))
@@ -5763,7 +5727,7 @@ AND Type = @InternalPersonType)");
                             continue;
                             continue;
                         }
                         }
 
 
-                        statement.TryBind("@Type" + index, currentValueInfo.Item1);
+                        statement.TryBind("@Type" + index, currentValueInfo.MagicNumber);
                         statement.TryBind("@Value" + index, itemValue);
                         statement.TryBind("@Value" + index, itemValue);
                         statement.TryBind("@CleanValue" + index, GetCleanValue(itemValue));
                         statement.TryBind("@CleanValue" + index, GetCleanValue(itemValue));
                     }
                     }

+ 1 - 0
Emby.Server.Implementations/EntryPoints/LibraryChangedNotifier.cs

@@ -464,6 +464,7 @@ namespace Emby.Server.Implementations.EntryPoints
         public void Dispose()
         public void Dispose()
         {
         {
             Dispose(true);
             Dispose(true);
+            GC.SuppressFinalize(this);
         }
         }
 
 
         /// <summary>
         /// <summary>

+ 10 - 10
Emby.Server.Implementations/IO/StreamHelper.cs

@@ -17,11 +17,11 @@ namespace Emby.Server.Implementations.IO
             try
             try
             {
             {
                 int read;
                 int read;
-                while ((read = await source.ReadAsync(buffer, 0, buffer.Length, cancellationToken).ConfigureAwait(false)) != 0)
+                while ((read = await source.ReadAsync(buffer, cancellationToken).ConfigureAwait(false)) != 0)
                 {
                 {
                     cancellationToken.ThrowIfCancellationRequested();
                     cancellationToken.ThrowIfCancellationRequested();
 
 
-                    await destination.WriteAsync(buffer, 0, read, cancellationToken).ConfigureAwait(false);
+                    await destination.WriteAsync(buffer.AsMemory(0, read), cancellationToken).ConfigureAwait(false);
 
 
                     if (onStarted != null)
                     if (onStarted != null)
                     {
                     {
@@ -44,11 +44,11 @@ namespace Emby.Server.Implementations.IO
                 if (emptyReadLimit <= 0)
                 if (emptyReadLimit <= 0)
                 {
                 {
                     int read;
                     int read;
-                    while ((read = await source.ReadAsync(buffer, 0, buffer.Length, cancellationToken).ConfigureAwait(false)) != 0)
+                    while ((read = await source.ReadAsync(buffer, cancellationToken).ConfigureAwait(false)) != 0)
                     {
                     {
                         cancellationToken.ThrowIfCancellationRequested();
                         cancellationToken.ThrowIfCancellationRequested();
 
 
-                        await destination.WriteAsync(buffer, 0, read, cancellationToken).ConfigureAwait(false);
+                        await destination.WriteAsync(buffer.AsMemory(0, read), cancellationToken).ConfigureAwait(false);
                     }
                     }
 
 
                     return;
                     return;
@@ -60,7 +60,7 @@ namespace Emby.Server.Implementations.IO
                 {
                 {
                     cancellationToken.ThrowIfCancellationRequested();
                     cancellationToken.ThrowIfCancellationRequested();
 
 
-                    var bytesRead = await source.ReadAsync(buffer, 0, buffer.Length, cancellationToken).ConfigureAwait(false);
+                    var bytesRead = await source.ReadAsync(buffer, cancellationToken).ConfigureAwait(false);
 
 
                     if (bytesRead == 0)
                     if (bytesRead == 0)
                     {
                     {
@@ -71,7 +71,7 @@ namespace Emby.Server.Implementations.IO
                     {
                     {
                         eofCount = 0;
                         eofCount = 0;
 
 
-                        await destination.WriteAsync(buffer, 0, bytesRead, cancellationToken).ConfigureAwait(false);
+                        await destination.WriteAsync(buffer.AsMemory(0, bytesRead), cancellationToken).ConfigureAwait(false);
                     }
                     }
                 }
                 }
             }
             }
@@ -88,13 +88,13 @@ namespace Emby.Server.Implementations.IO
             {
             {
                 int bytesRead;
                 int bytesRead;
 
 
-                while ((bytesRead = await source.ReadAsync(buffer, 0, buffer.Length, cancellationToken).ConfigureAwait(false)) != 0)
+                while ((bytesRead = await source.ReadAsync(buffer, cancellationToken).ConfigureAwait(false)) != 0)
                 {
                 {
                     var bytesToWrite = Math.Min(bytesRead, copyLength);
                     var bytesToWrite = Math.Min(bytesRead, copyLength);
 
 
                     if (bytesToWrite > 0)
                     if (bytesToWrite > 0)
                     {
                     {
-                        await destination.WriteAsync(buffer, 0, Convert.ToInt32(bytesToWrite), cancellationToken).ConfigureAwait(false);
+                        await destination.WriteAsync(buffer.AsMemory(0, Convert.ToInt32(bytesToWrite)), cancellationToken).ConfigureAwait(false);
                     }
                     }
 
 
                     copyLength -= bytesToWrite;
                     copyLength -= bytesToWrite;
@@ -137,9 +137,9 @@ namespace Emby.Server.Implementations.IO
             int bytesRead;
             int bytesRead;
             int totalBytesRead = 0;
             int totalBytesRead = 0;
 
 
-            while ((bytesRead = await source.ReadAsync(buffer, 0, buffer.Length, cancellationToken).ConfigureAwait(false)) != 0)
+            while ((bytesRead = await source.ReadAsync(buffer, cancellationToken).ConfigureAwait(false)) != 0)
             {
             {
-                await destination.WriteAsync(buffer, 0, bytesRead, cancellationToken).ConfigureAwait(false);
+                await destination.WriteAsync(buffer.AsMemory(0, bytesRead), cancellationToken).ConfigureAwait(false);
 
 
                 totalBytesRead += bytesRead;
                 totalBytesRead += bytesRead;
             }
             }

+ 2 - 2
Emby.Server.Implementations/Images/CollectionFolderImageProvider.cs

@@ -68,9 +68,9 @@ namespace Emby.Server.Implementations.Images
                 DtoOptions = new DtoOptions(false),
                 DtoOptions = new DtoOptions(false),
                 ImageTypes = new ImageType[] { ImageType.Primary },
                 ImageTypes = new ImageType[] { ImageType.Primary },
                 Limit = 8,
                 Limit = 8,
-                OrderBy = new ValueTuple<string, SortOrder>[]
+                OrderBy = new[]
                 {
                 {
-                    new ValueTuple<string, SortOrder>(ItemSortBy.Random, SortOrder.Ascending)
+                    (ItemSortBy.Random, SortOrder.Ascending)
                 },
                 },
                 IncludeItemTypes = includeItemTypes
                 IncludeItemTypes = includeItemTypes
             });
             });

+ 7 - 7
Emby.Server.Implementations/Library/LibraryManager.cs

@@ -1373,7 +1373,7 @@ namespace Emby.Server.Implementations.Library
             return _itemRepository.GetItemIdsList(query);
             return _itemRepository.GetItemIdsList(query);
         }
         }
 
 
-        public QueryResult<(BaseItem, ItemCounts)> GetStudios(InternalItemsQuery query)
+        public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetStudios(InternalItemsQuery query)
         {
         {
             if (query.User != null)
             if (query.User != null)
             {
             {
@@ -1384,7 +1384,7 @@ namespace Emby.Server.Implementations.Library
             return _itemRepository.GetStudios(query);
             return _itemRepository.GetStudios(query);
         }
         }
 
 
-        public QueryResult<(BaseItem, ItemCounts)> GetGenres(InternalItemsQuery query)
+        public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetGenres(InternalItemsQuery query)
         {
         {
             if (query.User != null)
             if (query.User != null)
             {
             {
@@ -1395,7 +1395,7 @@ namespace Emby.Server.Implementations.Library
             return _itemRepository.GetGenres(query);
             return _itemRepository.GetGenres(query);
         }
         }
 
 
-        public QueryResult<(BaseItem, ItemCounts)> GetMusicGenres(InternalItemsQuery query)
+        public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetMusicGenres(InternalItemsQuery query)
         {
         {
             if (query.User != null)
             if (query.User != null)
             {
             {
@@ -1406,7 +1406,7 @@ namespace Emby.Server.Implementations.Library
             return _itemRepository.GetMusicGenres(query);
             return _itemRepository.GetMusicGenres(query);
         }
         }
 
 
-        public QueryResult<(BaseItem, ItemCounts)> GetAllArtists(InternalItemsQuery query)
+        public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetAllArtists(InternalItemsQuery query)
         {
         {
             if (query.User != null)
             if (query.User != null)
             {
             {
@@ -1417,7 +1417,7 @@ namespace Emby.Server.Implementations.Library
             return _itemRepository.GetAllArtists(query);
             return _itemRepository.GetAllArtists(query);
         }
         }
 
 
-        public QueryResult<(BaseItem, ItemCounts)> GetArtists(InternalItemsQuery query)
+        public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetArtists(InternalItemsQuery query)
         {
         {
             if (query.User != null)
             if (query.User != null)
             {
             {
@@ -1458,7 +1458,7 @@ namespace Emby.Server.Implementations.Library
             }
             }
         }
         }
 
 
-        public QueryResult<(BaseItem, ItemCounts)> GetAlbumArtists(InternalItemsQuery query)
+        public QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetAlbumArtists(InternalItemsQuery query)
         {
         {
             if (query.User != null)
             if (query.User != null)
             {
             {
@@ -1757,7 +1757,7 @@ namespace Emby.Server.Implementations.Library
             return orderedItems ?? items;
             return orderedItems ?? items;
         }
         }
 
 
-        public IEnumerable<BaseItem> Sort(IEnumerable<BaseItem> items, User user, IEnumerable<ValueTuple<string, SortOrder>> orderBy)
+        public IEnumerable<BaseItem> Sort(IEnumerable<BaseItem> items, User user, IEnumerable<(string OrderBy, SortOrder SortOrder)> orderBy)
         {
         {
             var isFirst = true;
             var isFirst = true;
 
 

+ 3 - 4
Emby.Server.Implementations/Library/MediaSourceManager.cs

@@ -464,12 +464,11 @@ namespace Emby.Server.Implementations.Library
 
 
             try
             try
             {
             {
-                var tuple = GetProvider(request.OpenToken);
-                var provider = tuple.Item1;
+                var (provider, keyId) = GetProvider(request.OpenToken);
 
 
                 var currentLiveStreams = _openStreams.Values.ToList();
                 var currentLiveStreams = _openStreams.Values.ToList();
 
 
-                liveStream = await provider.OpenMediaSource(tuple.Item2, currentLiveStreams, cancellationToken).ConfigureAwait(false);
+                liveStream = await provider.OpenMediaSource(keyId, currentLiveStreams, cancellationToken).ConfigureAwait(false);
 
 
                 mediaSource = liveStream.MediaSource;
                 mediaSource = liveStream.MediaSource;
 
 
@@ -829,7 +828,7 @@ namespace Emby.Server.Implementations.Library
             }
             }
         }
         }
 
 
-        private (IMediaSourceProvider, string) GetProvider(string key)
+        private (IMediaSourceProvider MediaSourceProvider, string KeyId) GetProvider(string key)
         {
         {
             if (string.IsNullOrEmpty(key))
             if (string.IsNullOrEmpty(key))
             {
             {

+ 1 - 1
Emby.Server.Implementations/Library/SearchEngine.cs

@@ -190,7 +190,7 @@ namespace Emby.Server.Implementations.Library
                 searchQuery.ParentId = Guid.Empty;
                 searchQuery.ParentId = Guid.Empty;
                 searchQuery.IncludeItemsByName = true;
                 searchQuery.IncludeItemsByName = true;
                 searchQuery.IncludeItemTypes = Array.Empty<BaseItemKind>();
                 searchQuery.IncludeItemTypes = Array.Empty<BaseItemKind>();
-                mediaItems = _libraryManager.GetAllArtists(searchQuery).Items.Select(i => i.Item1).ToList();
+                mediaItems = _libraryManager.GetAllArtists(searchQuery).Items.Select(i => i.Item).ToList();
             }
             }
             else
             else
             {
             {

+ 2 - 0
Emby.Server.Implementations/LiveTv/Listings/SchedulesDirect.cs

@@ -643,7 +643,9 @@ namespace Emby.Server.Implementations.LiveTv.Listings
             CancellationToken cancellationToken)
             CancellationToken cancellationToken)
         {
         {
             using var options = new HttpRequestMessage(HttpMethod.Post, ApiUrl + "/token");
             using var options = new HttpRequestMessage(HttpMethod.Post, ApiUrl + "/token");
+#pragma warning disable CA5350 // SchedulesDirect is always SHA1.
             var hashedPasswordBytes = SHA1.HashData(Encoding.ASCII.GetBytes(password));
             var hashedPasswordBytes = SHA1.HashData(Encoding.ASCII.GetBytes(password));
+#pragma warning restore CA5350
             // TODO: remove ToLower when Convert.ToHexString supports lowercase
             // TODO: remove ToLower when Convert.ToHexString supports lowercase
             // Schedules Direct requires the hex to be lowercase
             // Schedules Direct requires the hex to be lowercase
             string hashedPassword = Convert.ToHexString(hashedPasswordBytes).ToLowerInvariant();
             string hashedPassword = Convert.ToHexString(hashedPasswordBytes).ToLowerInvariant();

+ 17 - 20
Emby.Server.Implementations/LiveTv/LiveTvManager.cs

@@ -207,7 +207,7 @@ namespace Emby.Server.Implementations.LiveTv
                 orderBy.Insert(0, (ItemSortBy.IsFavoriteOrLiked, SortOrder.Descending));
                 orderBy.Insert(0, (ItemSortBy.IsFavoriteOrLiked, SortOrder.Descending));
             }
             }
 
 
-            if (!internalQuery.OrderBy.Any(i => string.Equals(i.Item1, ItemSortBy.SortName, StringComparison.OrdinalIgnoreCase)))
+            if (!internalQuery.OrderBy.Any(i => string.Equals(i.OrderBy, ItemSortBy.SortName, StringComparison.OrdinalIgnoreCase)))
             {
             {
                 orderBy.Add((ItemSortBy.SortName, SortOrder.Ascending));
                 orderBy.Add((ItemSortBy.SortName, SortOrder.Ascending));
             }
             }
@@ -520,7 +520,7 @@ namespace Emby.Server.Implementations.LiveTv
             return item;
             return item;
         }
         }
 
 
-        private (LiveTvProgram item, bool isNew, bool isUpdated) GetProgram(ProgramInfo info, Dictionary<Guid, LiveTvProgram> allExistingPrograms, LiveTvChannel channel)
+        private (LiveTvProgram Item, bool IsNew, bool IsUpdated) GetProgram(ProgramInfo info, Dictionary<Guid, LiveTvProgram> allExistingPrograms, LiveTvChannel channel)
         {
         {
             var id = _tvDtoService.GetInternalProgramId(info.Id);
             var id = _tvDtoService.GetInternalProgramId(info.Id);
 
 
@@ -779,9 +779,9 @@ namespace Emby.Server.Implementations.LiveTv
 
 
             var dto = _dtoService.GetBaseItemDto(program, new DtoOptions(), user);
             var dto = _dtoService.GetBaseItemDto(program, new DtoOptions(), user);
 
 
-            var list = new List<Tuple<BaseItemDto, string, string>>
+            var list = new List<(BaseItemDto ItemDto, string ExternalId, string ExternalSeriesId)>
             {
             {
-                new Tuple<BaseItemDto, string, string>(dto, program.ExternalId, program.ExternalSeriesId)
+                (dto, program.ExternalId, program.ExternalSeriesId)
             };
             };
 
 
             await AddRecordingInfo(list, cancellationToken).ConfigureAwait(false);
             await AddRecordingInfo(list, cancellationToken).ConfigureAwait(false);
@@ -976,16 +976,16 @@ namespace Emby.Server.Implementations.LiveTv
             return score;
             return score;
         }
         }
 
 
-        private async Task AddRecordingInfo(IEnumerable<Tuple<BaseItemDto, string, string>> programs, CancellationToken cancellationToken)
+        private async Task AddRecordingInfo(IEnumerable<(BaseItemDto ItemDto, string ExternalId, string ExternalSeriesId)> programs, CancellationToken cancellationToken)
         {
         {
             IReadOnlyList<TimerInfo> timerList = null;
             IReadOnlyList<TimerInfo> timerList = null;
             IReadOnlyList<SeriesTimerInfo> seriesTimerList = null;
             IReadOnlyList<SeriesTimerInfo> seriesTimerList = null;
 
 
             foreach (var programTuple in programs)
             foreach (var programTuple in programs)
             {
             {
-                var program = programTuple.Item1;
-                var externalProgramId = programTuple.Item2;
-                string externalSeriesId = programTuple.Item3;
+                var program = programTuple.ItemDto;
+                var externalProgramId = programTuple.ExternalId;
+                string externalSeriesId = programTuple.ExternalSeriesId;
 
 
                 timerList ??= (await GetTimersInternal(new TimerQuery(), cancellationToken).ConfigureAwait(false)).Items;
                 timerList ??= (await GetTimersInternal(new TimerQuery(), cancellationToken).ConfigureAwait(false)).Items;
 
 
@@ -1186,13 +1186,13 @@ namespace Emby.Server.Implementations.LiveTv
                     foreach (var program in channelPrograms)
                     foreach (var program in channelPrograms)
                     {
                     {
                         var programTuple = GetProgram(program, existingPrograms, currentChannel);
                         var programTuple = GetProgram(program, existingPrograms, currentChannel);
-                        var programItem = programTuple.item;
+                        var programItem = programTuple.Item;
 
 
-                        if (programTuple.isNew)
+                        if (programTuple.IsNew)
                         {
                         {
                             newPrograms.Add(programItem);
                             newPrograms.Add(programItem);
                         }
                         }
-                        else if (programTuple.isUpdated)
+                        else if (programTuple.IsUpdated)
                         {
                         {
                             updatedPrograms.Add(programItem);
                             updatedPrograms.Add(programItem);
                         }
                         }
@@ -1423,9 +1423,9 @@ namespace Emby.Server.Implementations.LiveTv
             return result;
             return result;
         }
         }
 
 
-        public Task AddInfoToProgramDto(IReadOnlyCollection<(BaseItem, BaseItemDto)> programs, IReadOnlyList<ItemFields> fields, User user = null)
+        public Task AddInfoToProgramDto(IReadOnlyCollection<(BaseItem Item, BaseItemDto ItemDto)> programs, IReadOnlyList<ItemFields> fields, User user = null)
         {
         {
-            var programTuples = new List<Tuple<BaseItemDto, string, string>>();
+            var programTuples = new List<(BaseItemDto Dto, string ExternalId, string ExternalSeriesId)>();
             var hasChannelImage = fields.Contains(ItemFields.ChannelImage);
             var hasChannelImage = fields.Contains(ItemFields.ChannelImage);
             var hasChannelInfo = fields.Contains(ItemFields.ChannelInfo);
             var hasChannelInfo = fields.Contains(ItemFields.ChannelInfo);
 
 
@@ -1461,7 +1461,7 @@ namespace Emby.Server.Implementations.LiveTv
                     }
                     }
                 }
                 }
 
 
-                programTuples.Add(new Tuple<BaseItemDto, string, string>(dto, program.ExternalId, program.ExternalSeriesId));
+                programTuples.Add((dto, program.ExternalId, program.ExternalSeriesId));
             }
             }
 
 
             return AddRecordingInfo(programTuples, CancellationToken.None);
             return AddRecordingInfo(programTuples, CancellationToken.None);
@@ -1868,11 +1868,11 @@ namespace Emby.Server.Implementations.LiveTv
             return _libraryManager.GetItemById(internalChannelId);
             return _libraryManager.GetItemById(internalChannelId);
         }
         }
 
 
-        public void AddChannelInfo(IReadOnlyCollection<(BaseItemDto, LiveTvChannel)> items, DtoOptions options, User user)
+        public void AddChannelInfo(IReadOnlyCollection<(BaseItemDto ItemDto, LiveTvChannel Channel)> items, DtoOptions options, User user)
         {
         {
             var now = DateTime.UtcNow;
             var now = DateTime.UtcNow;
 
 
-            var channelIds = items.Select(i => i.Item2.Id).Distinct().ToArray();
+            var channelIds = items.Select(i => i.Channel.Id).Distinct().ToArray();
 
 
             var programs = options.AddCurrentProgram ? _libraryManager.GetItemList(new InternalItemsQuery(user)
             var programs = options.AddCurrentProgram ? _libraryManager.GetItemList(new InternalItemsQuery(user)
             {
             {
@@ -1893,11 +1893,8 @@ namespace Emby.Server.Implementations.LiveTv
 
 
             var addCurrentProgram = options.AddCurrentProgram;
             var addCurrentProgram = options.AddCurrentProgram;
 
 
-            foreach (var tuple in items)
+            foreach (var (dto, channel) in items)
             {
             {
-                var dto = tuple.Item1;
-                var channel = tuple.Item2;
-
                 dto.Number = channel.Number;
                 dto.Number = channel.Number;
                 dto.ChannelNumber = channel.Number;
                 dto.ChannelNumber = channel.Number;
                 dto.ChannelType = channel.ChannelType;
                 dto.ChannelType = channel.ChannelType;

+ 1 - 1
Emby.Server.Implementations/LiveTv/TunerHosts/HdHomerun/HdHomerunChannelCommands.cs

@@ -16,7 +16,7 @@ namespace Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun
             _profile = profile;
             _profile = profile;
         }
         }
 
 
-        public IEnumerable<(string, string)> GetCommands()
+        public IEnumerable<(string CommandName, string CommandValue)> GetCommands()
         {
         {
             if (!string.IsNullOrEmpty(_channel))
             if (!string.IsNullOrEmpty(_channel))
             {
             {

+ 2 - 2
Emby.Server.Implementations/LiveTv/TunerHosts/HdHomerun/HdHomerunManager.cs

@@ -114,7 +114,7 @@ namespace Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun
 
 
                     foreach (var command in commands.GetCommands())
                     foreach (var command in commands.GetCommands())
                     {
                     {
-                        var channelMsgLen = WriteSetMessage(buffer, i, command.Item1, command.Item2, lockKeyValue);
+                        var channelMsgLen = WriteSetMessage(buffer, i, command.CommandName, command.CommandValue, lockKeyValue);
                         await stream.WriteAsync(buffer.AsMemory(0, channelMsgLen), cancellationToken).ConfigureAwait(false);
                         await stream.WriteAsync(buffer.AsMemory(0, channelMsgLen), cancellationToken).ConfigureAwait(false);
                         receivedBytes = await stream.ReadAsync(buffer, cancellationToken).ConfigureAwait(false);
                         receivedBytes = await stream.ReadAsync(buffer, cancellationToken).ConfigureAwait(false);
 
 
@@ -167,7 +167,7 @@ namespace Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun
             {
             {
                 foreach (var command in commandList)
                 foreach (var command in commandList)
                 {
                 {
-                    var channelMsgLen = WriteSetMessage(buffer, _activeTuner, command.Item1, command.Item2, _lockkey);
+                    var channelMsgLen = WriteSetMessage(buffer, _activeTuner, command.CommandName, command.CommandValue, _lockkey);
                     await stream.WriteAsync(buffer.AsMemory(0, channelMsgLen), cancellationToken).ConfigureAwait(false);
                     await stream.WriteAsync(buffer.AsMemory(0, channelMsgLen), cancellationToken).ConfigureAwait(false);
                     int receivedBytes = await stream.ReadAsync(buffer, cancellationToken).ConfigureAwait(false);
                     int receivedBytes = await stream.ReadAsync(buffer, cancellationToken).ConfigureAwait(false);
 
 

+ 1 - 1
Emby.Server.Implementations/LiveTv/TunerHosts/HdHomerun/HdHomerunUdpStream.cs

@@ -212,7 +212,7 @@ namespace Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun
 
 
                         if (read > 0)
                         if (read > 0)
                         {
                         {
-                            fileStream.Write(buffer, RtpHeaderBytes, read);
+                            await fileStream.WriteAsync(buffer.AsMemory(RtpHeaderBytes, read), linkedSource.Token).ConfigureAwait(false);
                         }
                         }
 
 
                         if (!resolved)
                         if (!resolved)

+ 1 - 1
Emby.Server.Implementations/LiveTv/TunerHosts/HdHomerun/IHdHomerunChannelCommands.cs

@@ -6,6 +6,6 @@ namespace Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun
 {
 {
     public interface IHdHomerunChannelCommands
     public interface IHdHomerunChannelCommands
     {
     {
-        IEnumerable<(string, string)> GetCommands();
+        IEnumerable<(string CommandName, string CommandValue)> GetCommands();
     }
     }
 }
 }

+ 1 - 1
Emby.Server.Implementations/LiveTv/TunerHosts/HdHomerun/LegacyHdHomerunChannelCommands.cs

@@ -22,7 +22,7 @@ namespace Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun
             }
             }
         }
         }
 
 
-        public IEnumerable<(string, string)> GetCommands()
+        public IEnumerable<(string CommandName, string CommandValue)> GetCommands()
         {
         {
             if (!string.IsNullOrEmpty(_channel))
             if (!string.IsNullOrEmpty(_channel))
             {
             {

+ 1 - 1
Emby.Server.Implementations/Playlists/PlaylistManager.cs

@@ -72,7 +72,7 @@ namespace Emby.Server.Implementations.Playlists
             var parentFolder = GetPlaylistsFolder(Guid.Empty);
             var parentFolder = GetPlaylistsFolder(Guid.Empty);
             if (parentFolder == null)
             if (parentFolder == null)
             {
             {
-                throw new ArgumentException();
+                throw new ArgumentException(nameof(parentFolder));
             }
             }
 
 
             if (string.IsNullOrEmpty(options.MediaType))
             if (string.IsNullOrEmpty(options.MediaType))

+ 3 - 3
Emby.Server.Implementations/TV/TVSeriesManager.cs

@@ -117,7 +117,7 @@ namespace Emby.Server.Implementations.TV
                     new InternalItemsQuery(user)
                     new InternalItemsQuery(user)
                     {
                     {
                         IncludeItemTypes = new[] { BaseItemKind.Episode },
                         IncludeItemTypes = new[] { BaseItemKind.Episode },
-                        OrderBy = new[] { new ValueTuple<string, SortOrder>(ItemSortBy.DatePlayed, SortOrder.Descending) },
+                        OrderBy = new[] { (ItemSortBy.DatePlayed, SortOrder.Descending) },
                         SeriesPresentationUniqueKey = presentationUniqueKey,
                         SeriesPresentationUniqueKey = presentationUniqueKey,
                         Limit = limit,
                         Limit = limit,
                         DtoOptions = new DtoOptions { Fields = new[] { ItemFields.SeriesPresentationUniqueKey }, EnableImages = false },
                         DtoOptions = new DtoOptions { Fields = new[] { ItemFields.SeriesPresentationUniqueKey }, EnableImages = false },
@@ -193,7 +193,7 @@ namespace Emby.Server.Implementations.TV
                 AncestorWithPresentationUniqueKey = null,
                 AncestorWithPresentationUniqueKey = null,
                 SeriesPresentationUniqueKey = seriesKey,
                 SeriesPresentationUniqueKey = seriesKey,
                 IncludeItemTypes = new[] { BaseItemKind.Episode },
                 IncludeItemTypes = new[] { BaseItemKind.Episode },
-                OrderBy = new[] { new ValueTuple<string, SortOrder>(ItemSortBy.SortName, SortOrder.Descending) },
+                OrderBy = new[] { (ItemSortBy.SortName, SortOrder.Descending) },
                 IsPlayed = true,
                 IsPlayed = true,
                 Limit = 1,
                 Limit = 1,
                 ParentIndexNumberNotEquals = 0,
                 ParentIndexNumberNotEquals = 0,
@@ -211,7 +211,7 @@ namespace Emby.Server.Implementations.TV
                     AncestorWithPresentationUniqueKey = null,
                     AncestorWithPresentationUniqueKey = null,
                     SeriesPresentationUniqueKey = seriesKey,
                     SeriesPresentationUniqueKey = seriesKey,
                     IncludeItemTypes = new[] { BaseItemKind.Episode },
                     IncludeItemTypes = new[] { BaseItemKind.Episode },
-                    OrderBy = new[] { new ValueTuple<string, SortOrder>(ItemSortBy.SortName, SortOrder.Ascending) },
+                    OrderBy = new[] { (ItemSortBy.SortName, SortOrder.Ascending) },
                     Limit = 1,
                     Limit = 1,
                     IsPlayed = false,
                     IsPlayed = false,
                     IsVirtualItem = false,
                     IsVirtualItem = false,

+ 3 - 3
Emby.Server.Implementations/Updates/InstallationManager.cs

@@ -52,7 +52,7 @@ namespace Emby.Server.Implementations.Updates
         /// <summary>
         /// <summary>
         /// The current installations.
         /// The current installations.
         /// </summary>
         /// </summary>
-        private readonly List<(InstallationInfo info, CancellationTokenSource token)> _currentInstallations;
+        private readonly List<(InstallationInfo Info, CancellationTokenSource Token)> _currentInstallations;
 
 
         /// <summary>
         /// <summary>
         /// The completed installations.
         /// The completed installations.
@@ -399,13 +399,13 @@ namespace Emby.Server.Implementations.Updates
         {
         {
             lock (_currentInstallationsLock)
             lock (_currentInstallationsLock)
             {
             {
-                var install = _currentInstallations.Find(x => x.info.Id == id);
+                var install = _currentInstallations.Find(x => x.Info.Id == id);
                 if (install == default((InstallationInfo, CancellationTokenSource)))
                 if (install == default((InstallationInfo, CancellationTokenSource)))
                 {
                 {
                     return false;
                     return false;
                 }
                 }
 
 
-                install.token.Cancel();
+                install.Token.Cancel();
                 _currentInstallations.Remove(install);
                 _currentInstallations.Remove(install);
                 return true;
                 return true;
             }
             }

+ 4 - 4
Jellyfin.Api/Controllers/FilterController.cs

@@ -197,16 +197,16 @@ namespace Jellyfin.Api.Controllers
             {
             {
                 filters.Genres = _libraryManager.GetMusicGenres(genreQuery).Items.Select(i => new NameGuidPair
                 filters.Genres = _libraryManager.GetMusicGenres(genreQuery).Items.Select(i => new NameGuidPair
                 {
                 {
-                    Name = i.Item1.Name,
-                    Id = i.Item1.Id
+                    Name = i.Item.Name,
+                    Id = i.Item.Id
                 }).ToArray();
                 }).ToArray();
             }
             }
             else
             else
             {
             {
                 filters.Genres = _libraryManager.GetGenres(genreQuery).Items.Select(i => new NameGuidPair
                 filters.Genres = _libraryManager.GetGenres(genreQuery).Items.Select(i => new NameGuidPair
                 {
                 {
-                    Name = i.Item1.Name,
-                    Id = i.Item1.Id
+                    Name = i.Item.Name,
+                    Id = i.Item.Id
                 }).ToArray();
                 }).ToArray();
             }
             }
 
 

+ 1 - 1
Jellyfin.Api/Controllers/ItemsController.cs

@@ -484,7 +484,7 @@ namespace Jellyfin.Api.Controllers
                     // Albums by artist
                     // Albums by artist
                     if (query.ArtistIds.Length > 0 && query.IncludeItemTypes.Length == 1 && query.IncludeItemTypes[0] == BaseItemKind.MusicAlbum)
                     if (query.ArtistIds.Length > 0 && query.IncludeItemTypes.Length == 1 && query.IncludeItemTypes[0] == BaseItemKind.MusicAlbum)
                     {
                     {
-                        query.OrderBy = new[] { new ValueTuple<string, SortOrder>(ItemSortBy.ProductionYear, SortOrder.Descending), new ValueTuple<string, SortOrder>(ItemSortBy.SortName, SortOrder.Ascending) };
+                        query.OrderBy = new[] { (ItemSortBy.ProductionYear, SortOrder.Descending), (ItemSortBy.SortName, SortOrder.Ascending) };
                     }
                     }
                 }
                 }
 
 

+ 1 - 1
Jellyfin.Api/Helpers/RequestHelpers.cs

@@ -30,7 +30,7 @@ namespace Jellyfin.Api.Helpers
         {
         {
             if (sortBy.Count == 0)
             if (sortBy.Count == 0)
             {
             {
-                return Array.Empty<ValueTuple<string, SortOrder>>();
+                return Array.Empty<(string, SortOrder)>();
             }
             }
 
 
             var result = new (string, SortOrder)[sortBy.Count];
             var result = new (string, SortOrder)[sortBy.Count];

+ 7 - 7
Jellyfin.Server.Implementations/Users/UserManager.cs

@@ -394,12 +394,12 @@ namespace Jellyfin.Server.Implementations.Users
             var user = Users.FirstOrDefault(i => string.Equals(username, i.Username, StringComparison.OrdinalIgnoreCase));
             var user = Users.FirstOrDefault(i => string.Equals(username, i.Username, StringComparison.OrdinalIgnoreCase));
             var authResult = await AuthenticateLocalUser(username, password, user, remoteEndPoint)
             var authResult = await AuthenticateLocalUser(username, password, user, remoteEndPoint)
                 .ConfigureAwait(false);
                 .ConfigureAwait(false);
-            var authenticationProvider = authResult.authenticationProvider;
-            var success = authResult.success;
+            var authenticationProvider = authResult.AuthenticationProvider;
+            var success = authResult.Success;
 
 
             if (user == null)
             if (user == null)
             {
             {
-                string updatedUsername = authResult.username;
+                string updatedUsername = authResult.Username;
 
 
                 if (success
                 if (success
                     && authenticationProvider != null
                     && authenticationProvider != null
@@ -785,7 +785,7 @@ namespace Jellyfin.Server.Implementations.Users
             return providers;
             return providers;
         }
         }
 
 
-        private async Task<(IAuthenticationProvider? authenticationProvider, string username, bool success)> AuthenticateLocalUser(
+        private async Task<(IAuthenticationProvider? AuthenticationProvider, string Username, bool Success)> AuthenticateLocalUser(
                 string username,
                 string username,
                 string password,
                 string password,
                 User? user,
                 User? user,
@@ -798,8 +798,8 @@ namespace Jellyfin.Server.Implementations.Users
             {
             {
                 var providerAuthResult =
                 var providerAuthResult =
                     await AuthenticateWithProvider(provider, username, password, user).ConfigureAwait(false);
                     await AuthenticateWithProvider(provider, username, password, user).ConfigureAwait(false);
-                var updatedUsername = providerAuthResult.username;
-                success = providerAuthResult.success;
+                var updatedUsername = providerAuthResult.Username;
+                success = providerAuthResult.Success;
 
 
                 if (success)
                 if (success)
                 {
                 {
@@ -822,7 +822,7 @@ namespace Jellyfin.Server.Implementations.Users
             return (authenticationProvider, username, success);
             return (authenticationProvider, username, success);
         }
         }
 
 
-        private async Task<(string username, bool success)> AuthenticateWithProvider(
+        private async Task<(string Username, bool Success)> AuthenticateWithProvider(
             IAuthenticationProvider provider,
             IAuthenticationProvider provider,
             string username,
             string username,
             string password,
             string password,

+ 2 - 2
Jellyfin.Server/Migrations/PreStartupRoutines/CreateNetworkConfiguration.cs

@@ -53,7 +53,7 @@ public class CreateNetworkConfiguration : IMigrationRoutine
         networkConfigSerializer.Serialize(xmlWriter, networkSettings);
         networkConfigSerializer.Serialize(xmlWriter, networkSettings);
     }
     }
 
 
-#pragma warning disable CS1591
+#pragma warning disable
     public sealed class OldNetworkConfiguration
     public sealed class OldNetworkConfiguration
     {
     {
         public const int DefaultHttpPort = 8096;
         public const int DefaultHttpPort = 8096;
@@ -134,5 +134,5 @@ public class CreateNetworkConfiguration : IMigrationRoutine
 
 
         public string[] KnownProxies { get; set; } = Array.Empty<string>();
         public string[] KnownProxies { get; set; } = Array.Empty<string>();
     }
     }
-#pragma warning restore CS1591
+#pragma warning restore
 }
 }

+ 1 - 1
MediaBrowser.Common/Net/IPNetAddress.cs

@@ -195,7 +195,7 @@ namespace MediaBrowser.Common.Net
                     return NetworkAddress.PrefixLength <= netaddrObj.PrefixLength;
                     return NetworkAddress.PrefixLength <= netaddrObj.PrefixLength;
                 }
                 }
 
 
-                var altAddress = NetworkAddressOf(netaddrObj.Address, PrefixLength).address;
+                var altAddress = NetworkAddressOf(netaddrObj.Address, PrefixLength).Address;
                 return NetworkAddress.Address.Equals(altAddress);
                 return NetworkAddress.Address.Equals(altAddress);
             }
             }
 
 

+ 1 - 1
MediaBrowser.Common/Net/IPObject.cs

@@ -53,7 +53,7 @@ namespace MediaBrowser.Common.Net
         /// <param name="address">IP Address to convert.</param>
         /// <param name="address">IP Address to convert.</param>
         /// <param name="prefixLength">Subnet prefix.</param>
         /// <param name="prefixLength">Subnet prefix.</param>
         /// <returns>IPAddress.</returns>
         /// <returns>IPAddress.</returns>
-        public static (IPAddress address, byte prefixLength) NetworkAddressOf(IPAddress address, byte prefixLength)
+        public static (IPAddress Address, byte PrefixLength) NetworkAddressOf(IPAddress address, byte prefixLength)
         {
         {
             if (address == null)
             if (address == null)
             {
             {

+ 1 - 1
MediaBrowser.Controller/Drawing/IImageProcessor.cs

@@ -75,7 +75,7 @@ namespace MediaBrowser.Controller.Drawing
         /// </summary>
         /// </summary>
         /// <param name="options">The options.</param>
         /// <param name="options">The options.</param>
         /// <returns>Task.</returns>
         /// <returns>Task.</returns>
-        Task<(string path, string? mimeType, DateTime dateModified)> ProcessImage(ImageProcessingOptions options);
+        Task<(string Path, string? MimeType, DateTime DateModified)> ProcessImage(ImageProcessingOptions options);
 
 
         /// <summary>
         /// <summary>
         /// Gets the supported image output formats.
         /// Gets the supported image output formats.

+ 1 - 1
MediaBrowser.Controller/Entities/Audio/Audio.cs

@@ -135,7 +135,7 @@ namespace MediaBrowser.Controller.Entities.Audio
             return info;
             return info;
         }
         }
 
 
-        protected override IEnumerable<(BaseItem, MediaSourceType)> GetAllItemsForMediaSources()
+        protected override IEnumerable<(BaseItem Item, MediaSourceType MediaSourceType)> GetAllItemsForMediaSources()
             => new[] { ((BaseItem)this, MediaSourceType.Default) };
             => new[] { ((BaseItem)this, MediaSourceType.Default) };
     }
     }
 }
 }

+ 2 - 2
MediaBrowser.Controller/Entities/BaseItem.cs

@@ -1069,7 +1069,7 @@ namespace MediaBrowser.Controller.Entities
             }
             }
 
 
             var list = GetAllItemsForMediaSources();
             var list = GetAllItemsForMediaSources();
-            var result = list.Select(i => GetVersionInfo(enablePathSubstitution, i.Item1, i.Item2)).ToList();
+            var result = list.Select(i => GetVersionInfo(enablePathSubstitution, i.Item, i.MediaSourceType)).ToList();
 
 
             if (IsActiveRecording())
             if (IsActiveRecording())
             {
             {
@@ -1097,7 +1097,7 @@ namespace MediaBrowser.Controller.Entities
             .ToList();
             .ToList();
         }
         }
 
 
-        protected virtual IEnumerable<(BaseItem, MediaSourceType)> GetAllItemsForMediaSources()
+        protected virtual IEnumerable<(BaseItem Item, MediaSourceType MediaSourceType)> GetAllItemsForMediaSources()
         {
         {
             return Enumerable.Empty<(BaseItem, MediaSourceType)>();
             return Enumerable.Empty<(BaseItem, MediaSourceType)>();
         }
         }

+ 2 - 2
MediaBrowser.Controller/Entities/InternalItemsQuery.cs

@@ -38,7 +38,7 @@ namespace MediaBrowser.Controller.Entities
             MediaTypes = Array.Empty<string>();
             MediaTypes = Array.Empty<string>();
             MinSimilarityScore = 20;
             MinSimilarityScore = 20;
             OfficialRatings = Array.Empty<string>();
             OfficialRatings = Array.Empty<string>();
-            OrderBy = Array.Empty<ValueTuple<string, SortOrder>>();
+            OrderBy = Array.Empty<(string, SortOrder)>();
             PersonIds = Array.Empty<Guid>();
             PersonIds = Array.Empty<Guid>();
             PersonTypes = Array.Empty<string>();
             PersonTypes = Array.Empty<string>();
             PresetViews = Array.Empty<string>();
             PresetViews = Array.Empty<string>();
@@ -271,7 +271,7 @@ namespace MediaBrowser.Controller.Entities
 
 
         public bool? HasChapterImages { get; set; }
         public bool? HasChapterImages { get; set; }
 
 
-        public IReadOnlyList<(string, SortOrder)> OrderBy { get; set; }
+        public IReadOnlyList<(string OrderBy, SortOrder SortOrder)> OrderBy { get; set; }
 
 
         public DateTime? MinDateCreated { get; set; }
         public DateTime? MinDateCreated { get; set; }
 
 

+ 1 - 1
MediaBrowser.Controller/Entities/Video.cs

@@ -517,7 +517,7 @@ namespace MediaBrowser.Controller.Entities
             }).FirstOrDefault();
             }).FirstOrDefault();
         }
         }
 
 
-        protected override IEnumerable<(BaseItem, MediaSourceType)> GetAllItemsForMediaSources()
+        protected override IEnumerable<(BaseItem Item, MediaSourceType MediaSourceType)> GetAllItemsForMediaSources()
         {
         {
             var list = new List<(BaseItem, MediaSourceType)>
             var list = new List<(BaseItem, MediaSourceType)>
             {
             {

+ 7 - 7
MediaBrowser.Controller/Library/ILibraryManager.cs

@@ -212,7 +212,7 @@ namespace MediaBrowser.Controller.Library
         /// <returns>IEnumerable{BaseItem}.</returns>
         /// <returns>IEnumerable{BaseItem}.</returns>
         IEnumerable<BaseItem> Sort(IEnumerable<BaseItem> items, User user, IEnumerable<string> sortBy, SortOrder sortOrder);
         IEnumerable<BaseItem> Sort(IEnumerable<BaseItem> items, User user, IEnumerable<string> sortBy, SortOrder sortOrder);
 
 
-        IEnumerable<BaseItem> Sort(IEnumerable<BaseItem> items, User user, IEnumerable<ValueTuple<string, SortOrder>> orderBy);
+        IEnumerable<BaseItem> Sort(IEnumerable<BaseItem> items, User user, IEnumerable<(string OrderBy, SortOrder SortOrder)> orderBy);
 
 
         /// <summary>
         /// <summary>
         /// Gets the user root folder.
         /// Gets the user root folder.
@@ -573,17 +573,17 @@ namespace MediaBrowser.Controller.Library
 
 
         void RemoveMediaPath(string virtualFolderName, string mediaPath);
         void RemoveMediaPath(string virtualFolderName, string mediaPath);
 
 
-        QueryResult<(BaseItem, ItemCounts)> GetGenres(InternalItemsQuery query);
+        QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetGenres(InternalItemsQuery query);
 
 
-        QueryResult<(BaseItem, ItemCounts)> GetMusicGenres(InternalItemsQuery query);
+        QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetMusicGenres(InternalItemsQuery query);
 
 
-        QueryResult<(BaseItem, ItemCounts)> GetStudios(InternalItemsQuery query);
+        QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetStudios(InternalItemsQuery query);
 
 
-        QueryResult<(BaseItem, ItemCounts)> GetArtists(InternalItemsQuery query);
+        QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetArtists(InternalItemsQuery query);
 
 
-        QueryResult<(BaseItem, ItemCounts)> GetAlbumArtists(InternalItemsQuery query);
+        QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetAlbumArtists(InternalItemsQuery query);
 
 
-        QueryResult<(BaseItem, ItemCounts)> GetAllArtists(InternalItemsQuery query);
+        QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetAllArtists(InternalItemsQuery query);
 
 
         int GetCount(InternalItemsQuery query);
         int GetCount(InternalItemsQuery query);
 
 

+ 2 - 2
MediaBrowser.Controller/LiveTv/ILiveTvManager.cs

@@ -251,7 +251,7 @@ namespace MediaBrowser.Controller.LiveTv
         /// <param name="fields">The fields.</param>
         /// <param name="fields">The fields.</param>
         /// <param name="user">The user.</param>
         /// <param name="user">The user.</param>
         /// <returns>Task.</returns>
         /// <returns>Task.</returns>
-        Task AddInfoToProgramDto(IReadOnlyCollection<(BaseItem, BaseItemDto)> programs, IReadOnlyList<ItemFields> fields, User user = null);
+        Task AddInfoToProgramDto(IReadOnlyCollection<(BaseItem Item, BaseItemDto ItemDto)> programs, IReadOnlyList<ItemFields> fields, User user = null);
 
 
         /// <summary>
         /// <summary>
         /// Saves the tuner host.
         /// Saves the tuner host.
@@ -292,7 +292,7 @@ namespace MediaBrowser.Controller.LiveTv
         /// <param name="items">The items.</param>
         /// <param name="items">The items.</param>
         /// <param name="options">The options.</param>
         /// <param name="options">The options.</param>
         /// <param name="user">The user.</param>
         /// <param name="user">The user.</param>
-        void AddChannelInfo(IReadOnlyCollection<(BaseItemDto, LiveTvChannel)> items, DtoOptions options, User user);
+        void AddChannelInfo(IReadOnlyCollection<(BaseItemDto ItemDto, LiveTvChannel Channel)> items, DtoOptions options, User user);
 
 
         Task<List<ChannelInfo>> GetChannelsForListingsProvider(string id, CancellationToken cancellationToken);
         Task<List<ChannelInfo>> GetChannelsForListingsProvider(string id, CancellationToken cancellationToken);
 
 

+ 25 - 25
MediaBrowser.Controller/MediaEncoding/EncodingHelper.cs

@@ -21,6 +21,13 @@ namespace MediaBrowser.Controller.MediaEncoding
 {
 {
     public class EncodingHelper
     public class EncodingHelper
     {
     {
+        private const string QsvAlias = "qs";
+        private const string VaapiAlias = "va";
+        private const string D3d11vaAlias = "dx11";
+        private const string VideotoolboxAlias = "vt";
+        private const string OpenclAlias = "ocl";
+        private const string CudaAlias = "cu";
+
         private readonly IMediaEncoder _mediaEncoder;
         private readonly IMediaEncoder _mediaEncoder;
         private readonly ISubtitleEncoder _subtitleEncoder;
         private readonly ISubtitleEncoder _subtitleEncoder;
 
 
@@ -42,13 +49,6 @@ namespace MediaBrowser.Controller.MediaEncoding
             "Main10"
             "Main10"
         };
         };
 
 
-        private const string QsvAlias = "qs";
-        private const string VaapiAlias = "va";
-        private const string D3d11vaAlias = "dx11";
-        private const string VideotoolboxAlias = "vt";
-        private const string OpenclAlias = "ocl";
-        private const string CudaAlias = "cu";
-
         public EncodingHelper(
         public EncodingHelper(
             IMediaEncoder mediaEncoder,
             IMediaEncoder mediaEncoder,
             ISubtitleEncoder subtitleEncoder)
             ISubtitleEncoder subtitleEncoder)
@@ -2290,7 +2290,7 @@ namespace MediaBrowser.Controller.MediaEncoding
             return returnFirstIfNoIndex ? streams.FirstOrDefault() : null;
             return returnFirstIfNoIndex ? streams.FirstOrDefault() : null;
         }
         }
 
 
-        public static (int? width, int? height) GetFixedOutputSize(
+        public static (int? Width, int? Height) GetFixedOutputSize(
             int? videoWidth,
             int? videoWidth,
             int? videoHeight,
             int? videoHeight,
             int? requestedWidth,
             int? requestedWidth,
@@ -2671,7 +2671,7 @@ namespace MediaBrowser.Controller.MediaEncoding
         /// <param name="options">Encoding options.</param>
         /// <param name="options">Encoding options.</param>
         /// <param name="vidEncoder">Video encoder to use.</param>
         /// <param name="vidEncoder">Video encoder to use.</param>
         /// <returns>The tuple contains three lists: main, sub and overlay filters.</returns>
         /// <returns>The tuple contains three lists: main, sub and overlay filters.</returns>
-        public (List<string>, List<string>, List<string>) GetSwVidFilterChain(
+        public (List<string> MainFilters, List<string> SubFilters, List<string> OverlayFilters) GetSwVidFilterChain(
             EncodingJobInfo state,
             EncodingJobInfo state,
             EncodingOptions options,
             EncodingOptions options,
             string vidEncoder)
             string vidEncoder)
@@ -2751,7 +2751,7 @@ namespace MediaBrowser.Controller.MediaEncoding
         /// <param name="options">Encoding options.</param>
         /// <param name="options">Encoding options.</param>
         /// <param name="vidEncoder">Video encoder to use.</param>
         /// <param name="vidEncoder">Video encoder to use.</param>
         /// <returns>The tuple contains three lists: main, sub and overlay filters.</returns>
         /// <returns>The tuple contains three lists: main, sub and overlay filters.</returns>
-        public (List<string>, List<string>, List<string>) GetNvidiaVidFilterChain(
+        public (List<string> MainFilters, List<string> SubFilters, List<string> OverlayFilters) GetNvidiaVidFilterChain(
             EncodingJobInfo state,
             EncodingJobInfo state,
             EncodingOptions options,
             EncodingOptions options,
             string vidEncoder)
             string vidEncoder)
@@ -2778,7 +2778,7 @@ namespace MediaBrowser.Controller.MediaEncoding
             return GetNvidiaVidFiltersPrefered(state, options, vidDecoder, vidEncoder);
             return GetNvidiaVidFiltersPrefered(state, options, vidDecoder, vidEncoder);
         }
         }
 
 
-        public (List<string>, List<string>, List<string>) GetNvidiaVidFiltersPrefered(
+        public (List<string> MainFilters, List<string> SubFilters, List<string> OverlayFilters) GetNvidiaVidFiltersPrefered(
             EncodingJobInfo state,
             EncodingJobInfo state,
             EncodingOptions options,
             EncodingOptions options,
             string vidDecoder,
             string vidDecoder,
@@ -2838,6 +2838,7 @@ namespace MediaBrowser.Controller.MediaEncoding
                     mainFilters.Add("hwupload");
                     mainFilters.Add("hwupload");
                 }
                 }
             }
             }
+
             if (isNvdecDecoder)
             if (isNvdecDecoder)
             {
             {
                 // INPUT cuda surface(vram)
                 // INPUT cuda surface(vram)
@@ -2938,7 +2939,7 @@ namespace MediaBrowser.Controller.MediaEncoding
         /// <param name="options">Encoding options.</param>
         /// <param name="options">Encoding options.</param>
         /// <param name="vidEncoder">Video encoder to use.</param>
         /// <param name="vidEncoder">Video encoder to use.</param>
         /// <returns>The tuple contains three lists: main, sub and overlay filters.</returns>
         /// <returns>The tuple contains three lists: main, sub and overlay filters.</returns>
-        public (List<string>, List<string>, List<string>) GetAmdVidFilterChain(
+        public (List<string> MainFilters, List<string> SubFilters, List<string> OverlayFilters) GetAmdVidFilterChain(
             EncodingJobInfo state,
             EncodingJobInfo state,
             EncodingOptions options,
             EncodingOptions options,
             string vidEncoder)
             string vidEncoder)
@@ -2966,7 +2967,7 @@ namespace MediaBrowser.Controller.MediaEncoding
             return GetAmdDx11VidFiltersPrefered(state, options, vidDecoder, vidEncoder);
             return GetAmdDx11VidFiltersPrefered(state, options, vidDecoder, vidEncoder);
         }
         }
 
 
-        public (List<string>, List<string>, List<string>) GetAmdDx11VidFiltersPrefered(
+        public (List<string> MainFilters, List<string> SubFilters, List<string> OverlayFilters) GetAmdDx11VidFiltersPrefered(
             EncodingJobInfo state,
             EncodingJobInfo state,
             EncodingOptions options,
             EncodingOptions options,
             string vidDecoder,
             string vidDecoder,
@@ -3136,7 +3137,7 @@ namespace MediaBrowser.Controller.MediaEncoding
         /// <param name="options">Encoding options.</param>
         /// <param name="options">Encoding options.</param>
         /// <param name="vidEncoder">Video encoder to use.</param>
         /// <param name="vidEncoder">Video encoder to use.</param>
         /// <returns>The tuple contains three lists: main, sub and overlay filters.</returns>
         /// <returns>The tuple contains three lists: main, sub and overlay filters.</returns>
-        public (List<string>, List<string>, List<string>) GetIntelVidFilterChain(
+        public (List<string> MainFilters, List<string> SubFilters, List<string> OverlayFilters) GetIntelVidFilterChain(
             EncodingJobInfo state,
             EncodingJobInfo state,
             EncodingOptions options,
             EncodingOptions options,
             string vidEncoder)
             string vidEncoder)
@@ -3182,7 +3183,7 @@ namespace MediaBrowser.Controller.MediaEncoding
             return (null, null, null);
             return (null, null, null);
         }
         }
 
 
-        public (List<string>, List<string>, List<string>) GetIntelQsvDx11VidFiltersPrefered(
+        public (List<string> MainFilters, List<string> SubFilters, List<string> OverlayFilters) GetIntelQsvDx11VidFiltersPrefered(
             EncodingJobInfo state,
             EncodingJobInfo state,
             EncodingOptions options,
             EncodingOptions options,
             string vidDecoder,
             string vidDecoder,
@@ -3374,7 +3375,7 @@ namespace MediaBrowser.Controller.MediaEncoding
             return (mainFilters, subFilters, overlayFilters);
             return (mainFilters, subFilters, overlayFilters);
         }
         }
 
 
-        public (List<string>, List<string>, List<string>) GetIntelQsvVaapiVidFiltersPrefered(
+        public (List<string> MainFilters, List<string> SubFilters, List<string> OverlayFilters) GetIntelQsvVaapiVidFiltersPrefered(
             EncodingJobInfo state,
             EncodingJobInfo state,
             EncodingOptions options,
             EncodingOptions options,
             string vidDecoder,
             string vidDecoder,
@@ -3589,7 +3590,7 @@ namespace MediaBrowser.Controller.MediaEncoding
         /// <param name="options">Encoding options.</param>
         /// <param name="options">Encoding options.</param>
         /// <param name="vidEncoder">Video encoder to use.</param>
         /// <param name="vidEncoder">Video encoder to use.</param>
         /// <returns>The tuple contains three lists: main, sub and overlay filters.</returns>
         /// <returns>The tuple contains three lists: main, sub and overlay filters.</returns>
-        public (List<string>, List<string>, List<string>) GetVaapiVidFilterChain(
+        public (List<string> MainFilters, List<string> SubFilters, List<string> OverlayFilters) GetVaapiVidFilterChain(
             EncodingJobInfo state,
             EncodingJobInfo state,
             EncodingOptions options,
             EncodingOptions options,
             string vidEncoder)
             string vidEncoder)
@@ -3615,13 +3616,13 @@ namespace MediaBrowser.Controller.MediaEncoding
                 if (!isSwEncoder)
                 if (!isSwEncoder)
                 {
                 {
                     var newfilters = new List<string>();
                     var newfilters = new List<string>();
-                    var noOverlay = swFilterChain.Item3.Count == 0;
-                    newfilters.AddRange(noOverlay ? swFilterChain.Item1 : swFilterChain.Item3);
+                    var noOverlay = swFilterChain.OverlayFilters.Count == 0;
+                    newfilters.AddRange(noOverlay ? swFilterChain.MainFilters : swFilterChain.OverlayFilters);
                     newfilters.Add("hwupload");
                     newfilters.Add("hwupload");
 
 
-                    var mainFilters = noOverlay ? newfilters : swFilterChain.Item1;
-                    var overlayFilters = noOverlay ? swFilterChain.Item3 : newfilters;
-                    return (mainFilters, swFilterChain.Item2, overlayFilters);
+                    var mainFilters = noOverlay ? newfilters : swFilterChain.MainFilters;
+                    var overlayFilters = noOverlay ? swFilterChain.OverlayFilters : newfilters;
+                    return (mainFilters, swFilterChain.SubFilters, overlayFilters);
                 }
                 }
 
 
                 return swFilterChain;
                 return swFilterChain;
@@ -3638,7 +3639,7 @@ namespace MediaBrowser.Controller.MediaEncoding
             return GetVaapiLimitedVidFiltersPrefered(state, options, vidDecoder, vidEncoder);
             return GetVaapiLimitedVidFiltersPrefered(state, options, vidDecoder, vidEncoder);
         }
         }
 
 
-        public (List<string>, List<string>, List<string>) GetVaapiFullVidFiltersPrefered(
+        public (List<string> MainFilters, List<string> SubFilters, List<string> OverlayFilters) GetVaapiFullVidFiltersPrefered(
             EncodingJobInfo state,
             EncodingJobInfo state,
             EncodingOptions options,
             EncodingOptions options,
             string vidDecoder,
             string vidDecoder,
@@ -3834,7 +3835,7 @@ namespace MediaBrowser.Controller.MediaEncoding
             return (mainFilters, subFilters, overlayFilters);
             return (mainFilters, subFilters, overlayFilters);
         }
         }
 
 
-        public (List<string>, List<string>, List<string>) GetVaapiLimitedVidFiltersPrefered(
+        public (List<string> MainFilters, List<string> SubFilters, List<string> OverlayFilters) GetVaapiLimitedVidFiltersPrefered(
             EncodingJobInfo state,
             EncodingJobInfo state,
             EncodingOptions options,
             EncodingOptions options,
             string vidDecoder,
             string vidDecoder,
@@ -4090,7 +4091,6 @@ namespace MediaBrowser.Controller.MediaEncoding
                         "{0}",
                         "{0}",
                         string.Join(',', overlayFilters));
                         string.Join(',', overlayFilters));
 
 
-
                 var mapPrefix = Convert.ToInt32(state.SubtitleStream.IsExternal);
                 var mapPrefix = Convert.ToInt32(state.SubtitleStream.IsExternal);
                 var subtitleStreamIndex = state.SubtitleStream.IsExternal
                 var subtitleStreamIndex = state.SubtitleStream.IsExternal
                     ? 0
                     ? 0

+ 1 - 1
MediaBrowser.Controller/MediaEncoding/IAttachmentExtractor.cs

@@ -12,7 +12,7 @@ namespace MediaBrowser.Controller.MediaEncoding
 {
 {
     public interface IAttachmentExtractor
     public interface IAttachmentExtractor
     {
     {
-        Task<(MediaAttachment attachment, Stream stream)> GetAttachment(
+        Task<(MediaAttachment Attachment, Stream Stream)> GetAttachment(
             BaseItem item,
             BaseItem item,
             string mediaSourceId,
             string mediaSourceId,
             int attachmentStreamIndex,
             int attachmentStreamIndex,

+ 3 - 3
MediaBrowser.Controller/MediaEncoding/IMediaEncoder.cs

@@ -32,19 +32,19 @@ namespace MediaBrowser.Controller.MediaEncoding
         Version EncoderVersion { get; }
         Version EncoderVersion { get; }
 
 
         /// <summary>
         /// <summary>
-        /// Whether the configured Vaapi device is from AMD(radeonsi/r600 Mesa driver).
+        /// Gets a value indicating whether the configured Vaapi device is from AMD(radeonsi/r600 Mesa driver).
         /// </summary>
         /// </summary>
         /// <value><c>true</c> if the Vaapi device is an AMD(radeonsi/r600 Mesa driver) GPU, <c>false</c> otherwise.</value>
         /// <value><c>true</c> if the Vaapi device is an AMD(radeonsi/r600 Mesa driver) GPU, <c>false</c> otherwise.</value>
         bool IsVaapiDeviceAmd { get; }
         bool IsVaapiDeviceAmd { get; }
 
 
         /// <summary>
         /// <summary>
-        /// Whether the configured Vaapi device is from Intel(iHD driver).
+        /// Gets a value indicating whether the configured Vaapi device is from Intel(iHD driver).
         /// </summary>
         /// </summary>
         /// <value><c>true</c> if the Vaapi device is an Intel(iHD driver) GPU, <c>false</c> otherwise.</value>
         /// <value><c>true</c> if the Vaapi device is an Intel(iHD driver) GPU, <c>false</c> otherwise.</value>
         bool IsVaapiDeviceInteliHD { get; }
         bool IsVaapiDeviceInteliHD { get; }
 
 
         /// <summary>
         /// <summary>
-        /// Whether the configured Vaapi device is from Intel(legacy i965 driver).
+        /// Gets a value indicating whether the configured Vaapi device is from Intel(legacy i965 driver).
         /// </summary>
         /// </summary>
         /// <value><c>true</c> if the Vaapi device is an Intel(legacy i965 driver) GPU, <c>false</c> otherwise.</value>
         /// <value><c>true</c> if the Vaapi device is an Intel(legacy i965 driver) GPU, <c>false</c> otherwise.</value>
         bool IsVaapiDeviceInteli965 { get; }
         bool IsVaapiDeviceInteli965 { get; }

+ 1 - 1
MediaBrowser.Controller/MediaEncoding/JobLogger.cs

@@ -41,7 +41,7 @@ namespace MediaBrowser.Controller.MediaEncoding
                             break;
                             break;
                         }
                         }
 
 
-                        await target.WriteAsync(bytes, 0, bytes.Length).ConfigureAwait(false);
+                        await target.WriteAsync(bytes).ConfigureAwait(false);
 
 
                         // Check again, the stream could have been closed
                         // Check again, the stream could have been closed
                         if (!target.CanWrite)
                         if (!target.CanWrite)

+ 6 - 6
MediaBrowser.Controller/Persistence/IItemRepository.cs

@@ -161,17 +161,17 @@ namespace MediaBrowser.Controller.Persistence
 
 
         int GetCount(InternalItemsQuery query);
         int GetCount(InternalItemsQuery query);
 
 
-        QueryResult<(BaseItem, ItemCounts)> GetGenres(InternalItemsQuery query);
+        QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetGenres(InternalItemsQuery query);
 
 
-        QueryResult<(BaseItem, ItemCounts)> GetMusicGenres(InternalItemsQuery query);
+        QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetMusicGenres(InternalItemsQuery query);
 
 
-        QueryResult<(BaseItem, ItemCounts)> GetStudios(InternalItemsQuery query);
+        QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetStudios(InternalItemsQuery query);
 
 
-        QueryResult<(BaseItem, ItemCounts)> GetArtists(InternalItemsQuery query);
+        QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetArtists(InternalItemsQuery query);
 
 
-        QueryResult<(BaseItem, ItemCounts)> GetAlbumArtists(InternalItemsQuery query);
+        QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetAlbumArtists(InternalItemsQuery query);
 
 
-        QueryResult<(BaseItem, ItemCounts)> GetAllArtists(InternalItemsQuery query);
+        QueryResult<(BaseItem Item, ItemCounts ItemCounts)> GetAllArtists(InternalItemsQuery query);
 
 
         List<string> GetMusicGenreNames();
         List<string> GetMusicGenreNames();
 
 

+ 3 - 3
MediaBrowser.Controller/Providers/MetadataResult.cs

@@ -14,7 +14,7 @@ namespace MediaBrowser.Controller.Providers
     {
     {
         // Images aren't always used so the allocation is a waste a lot of the time
         // Images aren't always used so the allocation is a waste a lot of the time
         private List<LocalImageInfo> _images;
         private List<LocalImageInfo> _images;
-        private List<(string url, ImageType type)> _remoteImages;
+        private List<(string Url, ImageType Type)> _remoteImages;
 
 
         public MetadataResult()
         public MetadataResult()
         {
         {
@@ -27,9 +27,9 @@ namespace MediaBrowser.Controller.Providers
             set => _images = value;
             set => _images = value;
         }
         }
 
 
-        public List<(string url, ImageType type)> RemoteImages
+        public List<(string Url, ImageType Type)> RemoteImages
         {
         {
-            get => _remoteImages ??= new List<(string url, ImageType type)>();
+            get => _remoteImages ??= new List<(string Url, ImageType Type)>();
             set => _remoteImages = value;
             set => _remoteImages = value;
         }
         }
 
 

+ 1 - 1
MediaBrowser.MediaEncoding/Attachments/AttachmentExtractor.cs

@@ -50,7 +50,7 @@ namespace MediaBrowser.MediaEncoding.Attachments
         }
         }
 
 
         /// <inheritdoc />
         /// <inheritdoc />
-        public async Task<(MediaAttachment attachment, Stream stream)> GetAttachment(BaseItem item, string mediaSourceId, int attachmentStreamIndex, CancellationToken cancellationToken)
+        public async Task<(MediaAttachment Attachment, Stream Stream)> GetAttachment(BaseItem item, string mediaSourceId, int attachmentStreamIndex, CancellationToken cancellationToken)
         {
         {
             if (item == null)
             if (item == null)
             {
             {

+ 4 - 0
MediaBrowser.MediaEncoding/Encoder/MediaEncoder.cs

@@ -91,9 +91,13 @@ namespace MediaBrowser.MediaEncoding.Encoder
 
 
         /// <inheritdoc />
         /// <inheritdoc />
         public string EncoderPath => _ffmpegPath;
         public string EncoderPath => _ffmpegPath;
+
         public Version EncoderVersion => _ffmpegVersion;
         public Version EncoderVersion => _ffmpegVersion;
+
         public bool IsVaapiDeviceAmd => _isVaapiDeviceAmd;
         public bool IsVaapiDeviceAmd => _isVaapiDeviceAmd;
+
         public bool IsVaapiDeviceInteliHD => _isVaapiDeviceInteliHD;
         public bool IsVaapiDeviceInteliHD => _isVaapiDeviceInteliHD;
+
         public bool IsVaapiDeviceInteli965 => _isVaapiDeviceInteli965;
         public bool IsVaapiDeviceInteli965 => _isVaapiDeviceInteli965;
 
 
         /// <summary>
         /// <summary>

+ 5 - 5
MediaBrowser.MediaEncoding/Subtitles/SubtitleEncoder.cs

@@ -139,28 +139,28 @@ namespace MediaBrowser.MediaEncoding.Subtitles
             var subtitle = await GetSubtitleStream(mediaSource, subtitleStream, cancellationToken)
             var subtitle = await GetSubtitleStream(mediaSource, subtitleStream, cancellationToken)
                         .ConfigureAwait(false);
                         .ConfigureAwait(false);
 
 
-            var inputFormat = subtitle.format;
+            var inputFormat = subtitle.Format;
 
 
             // Return the original if we don't have any way of converting it
             // Return the original if we don't have any way of converting it
             if (!TryGetWriter(outputFormat, out var writer))
             if (!TryGetWriter(outputFormat, out var writer))
             {
             {
-                return subtitle.stream;
+                return subtitle.Stream;
             }
             }
 
 
             // Return the original if the same format is being requested
             // Return the original if the same format is being requested
             // Character encoding was already handled in GetSubtitleStream
             // Character encoding was already handled in GetSubtitleStream
             if (string.Equals(inputFormat, outputFormat, StringComparison.OrdinalIgnoreCase))
             if (string.Equals(inputFormat, outputFormat, StringComparison.OrdinalIgnoreCase))
             {
             {
-                return subtitle.stream;
+                return subtitle.Stream;
             }
             }
 
 
-            using (var stream = subtitle.stream)
+            using (var stream = subtitle.Stream)
             {
             {
                 return ConvertSubtitles(stream, inputFormat, outputFormat, startTimeTicks, endTimeTicks, preserveOriginalTimestamps, cancellationToken);
                 return ConvertSubtitles(stream, inputFormat, outputFormat, startTimeTicks, endTimeTicks, preserveOriginalTimestamps, cancellationToken);
             }
             }
         }
         }
 
 
-        private async Task<(Stream stream, string format)> GetSubtitleStream(
+        private async Task<(Stream Stream, string Format)> GetSubtitleStream(
             MediaSourceInfo mediaSource,
             MediaSourceInfo mediaSource,
             MediaStream subtitleStream,
             MediaStream subtitleStream,
             CancellationToken cancellationToken)
             CancellationToken cancellationToken)

+ 13 - 13
MediaBrowser.Model/Dlna/StreamBuilder.cs

@@ -289,8 +289,8 @@ namespace MediaBrowser.Model.Dlna
 
 
             var directPlayInfo = GetAudioDirectPlayMethods(item, audioStream, options);
             var directPlayInfo = GetAudioDirectPlayMethods(item, audioStream, options);
 
 
-            var directPlayMethods = directPlayInfo.Item1;
-            var transcodeReasons = directPlayInfo.Item2.ToList();
+            var directPlayMethods = directPlayInfo.PlayMethods;
+            var transcodeReasons = directPlayInfo.TranscodeReasons.ToList();
 
 
             int? inputAudioChannels = audioStream?.Channels;
             int? inputAudioChannels = audioStream?.Channels;
             int? inputAudioBitrate = audioStream?.BitDepth;
             int? inputAudioBitrate = audioStream?.BitDepth;
@@ -448,7 +448,7 @@ namespace MediaBrowser.Model.Dlna
             return options.GetMaxBitrate(isAudio);
             return options.GetMaxBitrate(isAudio);
         }
         }
 
 
-        private (IEnumerable<PlayMethod>, IEnumerable<TranscodeReason>) GetAudioDirectPlayMethods(MediaSourceInfo item, MediaStream audioStream, AudioOptions options)
+        private (IEnumerable<PlayMethod> PlayMethods, IEnumerable<TranscodeReason> TranscodeReasons) GetAudioDirectPlayMethods(MediaSourceInfo item, MediaStream audioStream, AudioOptions options)
         {
         {
             DirectPlayProfile directPlayProfile = options.Profile.DirectPlayProfiles
             DirectPlayProfile directPlayProfile = options.Profile.DirectPlayProfiles
                 .FirstOrDefault(x => x.Type == DlnaProfileType.Audio && IsAudioDirectPlaySupported(x, item, audioStream));
                 .FirstOrDefault(x => x.Type == DlnaProfileType.Audio && IsAudioDirectPlaySupported(x, item, audioStream));
@@ -679,8 +679,8 @@ namespace MediaBrowser.Model.Dlna
             // TODO: This doesn't account for situations where the device is able to handle the media's bitrate, but the connection isn't fast enough
             // TODO: This doesn't account for situations where the device is able to handle the media's bitrate, but the connection isn't fast enough
             var directPlayEligibilityResult = IsEligibleForDirectPlay(item, GetBitrateForDirectPlayCheck(item, options, true) ?? 0, subtitleStream, audioStream, options, PlayMethod.DirectPlay);
             var directPlayEligibilityResult = IsEligibleForDirectPlay(item, GetBitrateForDirectPlayCheck(item, options, true) ?? 0, subtitleStream, audioStream, options, PlayMethod.DirectPlay);
             var directStreamEligibilityResult = IsEligibleForDirectPlay(item, options.GetMaxBitrate(false) ?? 0, subtitleStream, audioStream, options, PlayMethod.DirectStream);
             var directStreamEligibilityResult = IsEligibleForDirectPlay(item, options.GetMaxBitrate(false) ?? 0, subtitleStream, audioStream, options, PlayMethod.DirectStream);
-            bool isEligibleForDirectPlay = options.EnableDirectPlay && (options.ForceDirectPlay || directPlayEligibilityResult.directPlay);
-            bool isEligibleForDirectStream = options.EnableDirectStream && (options.ForceDirectStream || directStreamEligibilityResult.directPlay);
+            bool isEligibleForDirectPlay = options.EnableDirectPlay && (options.ForceDirectPlay || directPlayEligibilityResult.DirectPlay);
+            bool isEligibleForDirectStream = options.EnableDirectStream && (options.ForceDirectStream || directStreamEligibilityResult.DirectPlay);
 
 
             _logger.LogDebug(
             _logger.LogDebug(
                 "Profile: {0}, Path: {1}, isEligibleForDirectPlay: {2}, isEligibleForDirectStream: {3}",
                 "Profile: {0}, Path: {1}, isEligibleForDirectPlay: {2}, isEligibleForDirectStream: {3}",
@@ -695,7 +695,7 @@ namespace MediaBrowser.Model.Dlna
             {
             {
                 // See if it can be direct played
                 // See if it can be direct played
                 var directPlayInfo = GetVideoDirectPlayProfile(options, item, videoStream, audioStream, isEligibleForDirectStream);
                 var directPlayInfo = GetVideoDirectPlayProfile(options, item, videoStream, audioStream, isEligibleForDirectStream);
-                var directPlay = directPlayInfo.playMethod;
+                var directPlay = directPlayInfo.PlayMethod;
 
 
                 if (directPlay != null)
                 if (directPlay != null)
                 {
                 {
@@ -713,17 +713,17 @@ namespace MediaBrowser.Model.Dlna
                     return playlistItem;
                     return playlistItem;
                 }
                 }
 
 
-                transcodeReasons.AddRange(directPlayInfo.transcodeReasons);
+                transcodeReasons.AddRange(directPlayInfo.TranscodeReasons);
             }
             }
 
 
-            if (directPlayEligibilityResult.reason.HasValue)
+            if (directPlayEligibilityResult.Reason.HasValue)
             {
             {
-                transcodeReasons.Add(directPlayEligibilityResult.reason.Value);
+                transcodeReasons.Add(directPlayEligibilityResult.Reason.Value);
             }
             }
 
 
-            if (directStreamEligibilityResult.reason.HasValue)
+            if (directStreamEligibilityResult.Reason.HasValue)
             {
             {
-                transcodeReasons.Add(directStreamEligibilityResult.reason.Value);
+                transcodeReasons.Add(directStreamEligibilityResult.Reason.Value);
             }
             }
 
 
             // Can't direct play, find the transcoding profile
             // Can't direct play, find the transcoding profile
@@ -1000,7 +1000,7 @@ namespace MediaBrowser.Model.Dlna
             return 7168000;
             return 7168000;
         }
         }
 
 
-        private (PlayMethod? playMethod, List<TranscodeReason> transcodeReasons) GetVideoDirectPlayProfile(
+        private (PlayMethod? PlayMethod, List<TranscodeReason> TranscodeReasons) GetVideoDirectPlayProfile(
             VideoOptions options,
             VideoOptions options,
             MediaSourceInfo mediaSource,
             MediaSourceInfo mediaSource,
             MediaStream videoStream,
             MediaStream videoStream,
@@ -1209,7 +1209,7 @@ namespace MediaBrowser.Model.Dlna
                 mediaSource.Path ?? "Unknown path");
                 mediaSource.Path ?? "Unknown path");
         }
         }
 
 
-        private (bool directPlay, TranscodeReason? reason) IsEligibleForDirectPlay(
+        private (bool DirectPlay, TranscodeReason? Reason) IsEligibleForDirectPlay(
             MediaSourceInfo item,
             MediaSourceInfo item,
             long maxBitrate,
             long maxBitrate,
             MediaStream subtitleStream,
             MediaStream subtitleStream,

+ 2 - 2
MediaBrowser.Model/Session/GeneralCommandType.cs

@@ -39,7 +39,6 @@ namespace MediaBrowser.Model.Session
         SetRepeatMode = 29,
         SetRepeatMode = 29,
         ChannelUp = 30,
         ChannelUp = 30,
         ChannelDown = 31,
         ChannelDown = 31,
-        SetMaxStreamingBitrate = 31,
         Guide = 32,
         Guide = 32,
         ToggleStats = 33,
         ToggleStats = 33,
         PlayMediaSource = 34,
         PlayMediaSource = 34,
@@ -48,6 +47,7 @@ namespace MediaBrowser.Model.Session
         PlayState = 37,
         PlayState = 37,
         PlayNext = 38,
         PlayNext = 38,
         ToggleOsdMenu = 39,
         ToggleOsdMenu = 39,
-        Play = 40
+        Play = 40,
+        SetMaxStreamingBitrate = 41
     }
     }
 }
 }

+ 2 - 2
MediaBrowser.Providers/Manager/MetadataService.cs

@@ -682,12 +682,12 @@ namespace MediaBrowser.Providers.Manager
                         {
                         {
                             try
                             try
                             {
                             {
-                                await ProviderManager.SaveImage(item, remoteImage.url, remoteImage.type, null, cancellationToken).ConfigureAwait(false);
+                                await ProviderManager.SaveImage(item, remoteImage.Url, remoteImage.Type, null, cancellationToken).ConfigureAwait(false);
                                 refreshResult.UpdateType |= ItemUpdateType.ImageUpdate;
                                 refreshResult.UpdateType |= ItemUpdateType.ImageUpdate;
                             }
                             }
                             catch (HttpRequestException ex)
                             catch (HttpRequestException ex)
                             {
                             {
-                                Logger.LogError(ex, "Could not save {ImageType} image: {Url}", Enum.GetName(remoteImage.type), remoteImage.url);
+                                Logger.LogError(ex, "Could not save {ImageType} image: {Url}", Enum.GetName(remoteImage.Type), remoteImage.Url);
                             }
                             }
                         }
                         }
 
 

+ 5 - 5
MediaBrowser.Providers/Plugins/MusicBrainz/MusicBrainzAlbumProvider.cs

@@ -303,7 +303,7 @@ namespace MediaBrowser.Providers.Music
             return ReleaseResult.Parse(reader).FirstOrDefault();
             return ReleaseResult.Parse(reader).FirstOrDefault();
         }
         }
 
 
-        private static (string, string) ParseArtistCredit(XmlReader reader)
+        private static (string Name, string ArtistId) ParseArtistCredit(XmlReader reader)
         {
         {
             reader.MoveToContent();
             reader.MoveToContent();
             reader.Read();
             reader.Read();
@@ -345,7 +345,7 @@ namespace MediaBrowser.Providers.Music
             return default;
             return default;
         }
         }
 
 
-        private static (string, string) ParseArtistNameCredit(XmlReader reader)
+        private static (string Name, string ArtistId) ParseArtistNameCredit(XmlReader reader)
         {
         {
             reader.MoveToContent();
             reader.MoveToContent();
             reader.Read();
             reader.Read();
@@ -388,7 +388,7 @@ namespace MediaBrowser.Providers.Music
             return (null, null);
             return (null, null);
         }
         }
 
 
-        private static (string name, string id) ParseArtistArtistCredit(XmlReader reader, string artistId)
+        private static (string Name, string ArtistId) ParseArtistArtistCredit(XmlReader reader, string artistId)
         {
         {
             reader.MoveToContent();
             reader.MoveToContent();
             reader.Read();
             reader.Read();
@@ -628,7 +628,7 @@ namespace MediaBrowser.Providers.Music
             public string Overview;
             public string Overview;
             public int? Year;
             public int? Year;
 
 
-            public List<ValueTuple<string, string>> Artists = new List<ValueTuple<string, string>>();
+            public List<(string, string)> Artists = new();
 
 
             public static IEnumerable<ReleaseResult> Parse(XmlReader reader)
             public static IEnumerable<ReleaseResult> Parse(XmlReader reader)
             {
             {
@@ -776,7 +776,7 @@ namespace MediaBrowser.Providers.Music
                                     using var subReader = reader.ReadSubtree();
                                     using var subReader = reader.ReadSubtree();
                                     var artist = ParseArtistCredit(subReader);
                                     var artist = ParseArtistCredit(subReader);
 
 
-                                    if (!string.IsNullOrEmpty(artist.Item1))
+                                    if (!string.IsNullOrEmpty(artist.Name))
                                     {
                                     {
                                         result.Artists.Add(artist);
                                         result.Artists.Add(artist);
                                     }
                                     }

+ 1 - 1
MediaBrowser.XbmcMetadata/Parsers/BaseNfoParser.cs

@@ -872,7 +872,7 @@ namespace MediaBrowser.XbmcMetadata.Parsers
             else
             else
             {
             {
                 // only allow one item of each type
                 // only allow one item of each type
-                if (itemResult.RemoteImages.Any(x => x.type == imageType))
+                if (itemResult.RemoteImages.Any(x => x.Type == imageType))
                 {
                 {
                     return;
                     return;
                 }
                 }

+ 17 - 16
tests/Jellyfin.XbmcMetadata.Tests/Parsers/MovieNfoParserTests.cs

@@ -1,4 +1,5 @@
 using System;
 using System;
+using System.Collections.Generic;
 using System.Linq;
 using System.Linq;
 using System.Threading;
 using System.Threading;
 using Jellyfin.Data.Entities;
 using Jellyfin.Data.Entities;
@@ -157,33 +158,33 @@ namespace Jellyfin.XbmcMetadata.Tests.Parsers
             // Images
             // Images
             Assert.Equal(7, result.RemoteImages.Count);
             Assert.Equal(7, result.RemoteImages.Count);
 
 
-            var posters = result.RemoteImages.Where(x => x.type == ImageType.Primary).ToList();
+            var posters = result.RemoteImages.Where(x => x.Type == ImageType.Primary).ToList();
             Assert.Single(posters);
             Assert.Single(posters);
-            Assert.Equal("http://image.tmdb.org/t/p/original/9rtrRGeRnL0JKtu9IMBWsmlmmZz.jpg", posters[0].url);
+            Assert.Equal("http://image.tmdb.org/t/p/original/9rtrRGeRnL0JKtu9IMBWsmlmmZz.jpg", posters[0].Url);
 
 
-            var logos = result.RemoteImages.Where(x => x.type == ImageType.Logo).ToList();
+            var logos = result.RemoteImages.Where(x => x.Type == ImageType.Logo).ToList();
             Assert.Single(logos);
             Assert.Single(logos);
-            Assert.Equal("https://assets.fanart.tv/fanart/movies/141052/hdmovielogo/justice-league-5865bf95cbadb.png", logos[0].url);
+            Assert.Equal("https://assets.fanart.tv/fanart/movies/141052/hdmovielogo/justice-league-5865bf95cbadb.png", logos[0].Url);
 
 
-            var banners = result.RemoteImages.Where(x => x.type == ImageType.Banner).ToList();
+            var banners = result.RemoteImages.Where(x => x.Type == ImageType.Banner).ToList();
             Assert.Single(banners);
             Assert.Single(banners);
-            Assert.Equal("https://assets.fanart.tv/fanart/movies/141052/moviebanner/justice-league-586017e95adbd.jpg", banners[0].url);
+            Assert.Equal("https://assets.fanart.tv/fanart/movies/141052/moviebanner/justice-league-586017e95adbd.jpg", banners[0].Url);
 
 
-            var thumbs = result.RemoteImages.Where(x => x.type == ImageType.Thumb).ToList();
+            var thumbs = result.RemoteImages.Where(x => x.Type == ImageType.Thumb).ToList();
             Assert.Single(thumbs);
             Assert.Single(thumbs);
-            Assert.Equal("https://assets.fanart.tv/fanart/movies/141052/moviethumb/justice-league-585fb155c3743.jpg", thumbs[0].url);
+            Assert.Equal("https://assets.fanart.tv/fanart/movies/141052/moviethumb/justice-league-585fb155c3743.jpg", thumbs[0].Url);
 
 
-            var art = result.RemoteImages.Where(x => x.type == ImageType.Art).ToList();
+            var art = result.RemoteImages.Where(x => x.Type == ImageType.Art).ToList();
             Assert.Single(art);
             Assert.Single(art);
-            Assert.Equal("https://assets.fanart.tv/fanart/movies/141052/hdmovieclearart/justice-league-5865c23193041.png", art[0].url);
+            Assert.Equal("https://assets.fanart.tv/fanart/movies/141052/hdmovieclearart/justice-league-5865c23193041.png", art[0].Url);
 
 
-            var discArt = result.RemoteImages.Where(x => x.type == ImageType.Disc).ToList();
+            var discArt = result.RemoteImages.Where(x => x.Type == ImageType.Disc).ToList();
             Assert.Single(discArt);
             Assert.Single(discArt);
-            Assert.Equal("https://assets.fanart.tv/fanart/movies/141052/moviedisc/justice-league-5a3af26360617.png", discArt[0].url);
+            Assert.Equal("https://assets.fanart.tv/fanart/movies/141052/moviedisc/justice-league-5a3af26360617.png", discArt[0].Url);
 
 
-            var backdrop = result.RemoteImages.Where(x => x.type == ImageType.Backdrop).ToList();
+            var backdrop = result.RemoteImages.Where(x => x.Type == ImageType.Backdrop).ToList();
             Assert.Single(backdrop);
             Assert.Single(backdrop);
-            Assert.Equal("https://assets.fanart.tv/fanart/movies/141052/moviebackground/justice-league-5793f518c6d6e.jpg", backdrop[0].url);
+            Assert.Equal("https://assets.fanart.tv/fanart/movies/141052/moviebackground/justice-league-5793f518c6d6e.jpg", backdrop[0].Url);
 
 
             // Local Image - contains only one item depending on operating system
             // Local Image - contains only one item depending on operating system
             Assert.Single(result.Images);
             Assert.Single(result.Images);
@@ -216,8 +217,8 @@ namespace Jellyfin.XbmcMetadata.Tests.Parsers
 
 
             _parser.Fetch(result, "Test Data/Fanart.nfo", CancellationToken.None);
             _parser.Fetch(result, "Test Data/Fanart.nfo", CancellationToken.None);
 
 
-            Assert.Single(result.RemoteImages.Where(x => x.type == ImageType.Backdrop));
-            Assert.Equal("https://assets.fanart.tv/fanart/movies/141052/moviebackground/justice-league-5a5332c7b5e77.jpg", result.RemoteImages.First(x => x.type == ImageType.Backdrop).url);
+            Assert.Single(result.RemoteImages.Where(x => x.Type == ImageType.Backdrop));
+            Assert.Equal("https://assets.fanart.tv/fanart/movies/141052/moviebackground/justice-league-5a5332c7b5e77.jpg", result.RemoteImages.First(x => x.Type == ImageType.Backdrop).Url);
         }
         }
 
 
         [Fact]
         [Fact]