Merge pull request #5276 from Bond-009/minor12
commit
c0c4aff8a6
@ -1,37 +0,0 @@
|
|||||||
#nullable enable
|
|
||||||
|
|
||||||
using System;
|
|
||||||
|
|
||||||
namespace MediaBrowser.Common.Extensions
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// Extensions methods to simplify string operations.
|
|
||||||
/// </summary>
|
|
||||||
public static class StringExtensions
|
|
||||||
{
|
|
||||||
/// <summary>
|
|
||||||
/// Returns the part on the left of the <c>needle</c>.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="haystack">The string to seek.</param>
|
|
||||||
/// <param name="needle">The needle to find.</param>
|
|
||||||
/// <returns>The part left of the <paramref name="needle" />.</returns>
|
|
||||||
public static ReadOnlySpan<char> LeftPart(this ReadOnlySpan<char> haystack, char needle)
|
|
||||||
{
|
|
||||||
var pos = haystack.IndexOf(needle);
|
|
||||||
return pos == -1 ? haystack : haystack[..pos];
|
|
||||||
}
|
|
||||||
|
|
||||||
/// <summary>
|
|
||||||
/// Returns the part on the left of the <c>needle</c>.
|
|
||||||
/// </summary>
|
|
||||||
/// <param name="haystack">The string to seek.</param>
|
|
||||||
/// <param name="needle">The needle to find.</param>
|
|
||||||
/// <param name="stringComparison">One of the enumeration values that specifies the rules for the search.</param>
|
|
||||||
/// <returns>The part left of the <c>needle</c>.</returns>
|
|
||||||
public static ReadOnlySpan<char> LeftPart(this ReadOnlySpan<char> haystack, ReadOnlySpan<char> needle, StringComparison stringComparison = default)
|
|
||||||
{
|
|
||||||
var pos = haystack.IndexOf(needle, stringComparison);
|
|
||||||
return pos == -1 ? haystack : haystack[..pos];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
@ -1,43 +0,0 @@
|
|||||||
using System;
|
|
||||||
using MediaBrowser.Common.Extensions;
|
|
||||||
using Xunit;
|
|
||||||
|
|
||||||
namespace Jellyfin.Common.Tests.Extensions
|
|
||||||
{
|
|
||||||
public class StringExtensionsTests
|
|
||||||
{
|
|
||||||
[Theory]
|
|
||||||
[InlineData("", 'q', "")]
|
|
||||||
[InlineData("Banana split", ' ', "Banana")]
|
|
||||||
[InlineData("Banana split", 'q', "Banana split")]
|
|
||||||
public void LeftPart_ValidArgsCharNeedle_Correct(string str, char needle, string expectedResult)
|
|
||||||
{
|
|
||||||
var result = str.AsSpan().LeftPart(needle).ToString();
|
|
||||||
Assert.Equal(expectedResult, result);
|
|
||||||
}
|
|
||||||
|
|
||||||
[Theory]
|
|
||||||
[InlineData("", "", "")]
|
|
||||||
[InlineData("", "q", "")]
|
|
||||||
[InlineData("Banana split", "", "")]
|
|
||||||
[InlineData("Banana split", " ", "Banana")]
|
|
||||||
[InlineData("Banana split test", " split", "Banana")]
|
|
||||||
public void LeftPart_ValidArgsWithoutStringComparison_Correct(string str, string needle, string expectedResult)
|
|
||||||
{
|
|
||||||
var result = str.AsSpan().LeftPart(needle).ToString();
|
|
||||||
Assert.Equal(expectedResult, result);
|
|
||||||
}
|
|
||||||
|
|
||||||
[Theory]
|
|
||||||
[InlineData("", "", StringComparison.Ordinal, "")]
|
|
||||||
[InlineData("Banana split", " ", StringComparison.Ordinal, "Banana")]
|
|
||||||
[InlineData("Banana split test", " split", StringComparison.Ordinal, "Banana")]
|
|
||||||
[InlineData("Banana split test", " Split", StringComparison.Ordinal, "Banana split test")]
|
|
||||||
[InlineData("Banana split test", " Splït", StringComparison.InvariantCultureIgnoreCase, "Banana split test")]
|
|
||||||
public void LeftPart_ValidArgs_Correct(string str, string needle, StringComparison stringComparison, string expectedResult)
|
|
||||||
{
|
|
||||||
var result = str.AsSpan().LeftPart(needle, stringComparison).ToString();
|
|
||||||
Assert.Equal(expectedResult, result);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
Loading…
Reference in new issue