Skip to content

Commit

Permalink
Create and use FormattingStreamWriter
Browse files Browse the repository at this point in the history
Prevents bugs causes by system cultures with different formatting
  • Loading branch information
Bond-009 committed Aug 30, 2024
1 parent 2fe13f5 commit 3b94cfa
Show file tree
Hide file tree
Showing 5 changed files with 64 additions and 7 deletions.
5 changes: 1 addition & 4 deletions MediaBrowser.Controller/Entities/TV/Episode.cs
Original file line number Diff line number Diff line change
Expand Up @@ -180,10 +180,7 @@ public override List<string> GetUserDataKeys()
}

public string FindSeriesPresentationUniqueKey()
{
var series = Series;
return series is null ? null : series.PresentationUniqueKey;
}
=> Series?.PresentationUniqueKey;

public string FindSeasonName()
{
Expand Down
2 changes: 0 additions & 2 deletions MediaBrowser.Controller/Entities/UserViewBuilder.cs
Original file line number Diff line number Diff line change
Expand Up @@ -430,8 +430,6 @@ public static QueryResult<BaseItem> PostFilterAndSort(
InternalItemsQuery query,
ILibraryManager libraryManager)
{
var user = query.User;

// This must be the last filter
if (!query.AdjacentTo.IsNullOrEmpty())
{
Expand Down
3 changes: 2 additions & 1 deletion MediaBrowser.MediaEncoding/Encoder/MediaEncoder.cs
Original file line number Diff line number Diff line change
Expand Up @@ -1207,7 +1207,8 @@ public void GenerateConcatConfig(MediaSourceInfo source, string concatFilePath)
}

// Generate concat configuration entries for each file and write to file
using StreamWriter sw = new StreamWriter(concatFilePath);
Directory.CreateDirectory(Path.GetDirectoryName(concatFilePath));
using StreamWriter sw = new FormattingStreamWriter(concatFilePath, CultureInfo.InvariantCulture);
foreach (var path in files)
{
var mediaInfoResult = GetMediaInfo(
Expand Down
38 changes: 38 additions & 0 deletions src/Jellyfin.Extensions/FormattingStreamWriter.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,38 @@
using System;
using System.IO;

namespace Jellyfin.Extensions;

/// <summary>
/// A custom StreamWriter which supports setting a IFormatProvider.
/// </summary>
public class FormattingStreamWriter : StreamWriter
{
private readonly IFormatProvider _formatProvider;

/// <summary>
/// Initializes a new instance of the <see cref="FormattingStreamWriter"/> class.
/// </summary>
/// <param name="stream">The stream to write to.</param>
/// <param name="formatProvider">The format provider to use.</param>
public FormattingStreamWriter(Stream stream, IFormatProvider formatProvider)
: base(stream)
{
_formatProvider = formatProvider;
}

/// <summary>
/// Initializes a new instance of the <see cref="FormattingStreamWriter"/> class.
/// </summary>
/// <param name="path">The complete file path to write to.</param>
/// <param name="formatProvider">The format provider to use.</param>
public FormattingStreamWriter(string path, IFormatProvider formatProvider)
: base(path)
{
_formatProvider = formatProvider;
}

/// <inheritdoc />
public override IFormatProvider FormatProvider
=> _formatProvider;
}
23 changes: 23 additions & 0 deletions tests/Jellyfin.Extensions.Tests/FormattingStreamWriterTests.cs
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
using System.Globalization;
using System.IO;
using System.Text;
using System.Threading;
using Xunit;

namespace Jellyfin.Extensions.Tests;

public static class FormattingStreamWriterTests
{
[Fact]
public static void Shuffle_Valid_Correct()
{
Thread.CurrentThread.CurrentCulture = new CultureInfo("de-DE", false);
using (var ms = new MemoryStream())
using (var txt = new FormattingStreamWriter(ms, CultureInfo.InvariantCulture))
{
txt.Write("{0}", 3.14159);
txt.Close();
Assert.Equal("3.14159", Encoding.UTF8.GetString(ms.ToArray()));
}
}
}

0 comments on commit 3b94cfa

Please sign in to comment.