Skip to content

Commit

Permalink
Parse positive/negative sign
Browse files Browse the repository at this point in the history
  • Loading branch information
dahlbyk committed May 3, 2021
1 parent 94694af commit 8db043d
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 3 deletions.
8 changes: 6 additions & 2 deletions src/Humanizer.Tests.Shared/Bytes/ParsingTests.cs
Original file line number Diff line number Diff line change
Expand Up @@ -56,10 +56,13 @@ public void TryParse()
[Theory]
[InlineData("2000.01KB", "")] // Invariant
[InlineData("2,000.01KB", "")]
[InlineData("+2000.01KB", "")]
[InlineData("2000.01KB", "en")]
[InlineData("2,000.01KB", "en")]
[InlineData("+2000.01KB", "en")]
[InlineData("2000,01KB", "de")]
[InlineData("2.000,01KB", "de")]
[InlineData("+2000,01KB", "de")]
public void TryParseWithCultureInfo(string value, string cultureName)
{
var culture = new CultureInfo(cultureName);
Expand All @@ -77,12 +80,13 @@ public void TryParseWithNumberFormatInfo()
{
NumberDecimalSeparator = "_",
NumberGroupSeparator = ";",
NegativeSign = "−", // proper minus, not hyphen-minus
};

var value = "2;000_01KB";
var value = "2;000_01KB";

Assert.True(ByteSize.TryParse(value, numberFormat, out var resultByteSize));
Assert.Equal(ByteSize.FromKilobytes(2000.01), resultByteSize);
Assert.Equal(ByteSize.FromKilobytes(-2000.01), resultByteSize);

Assert.Equal(resultByteSize, ByteSize.Parse(value, numberFormat));
}
Expand Down
4 changes: 3 additions & 1 deletion src/Humanizer/Bytes/ByteSize.cs
Original file line number Diff line number Diff line change
Expand Up @@ -485,11 +485,13 @@ public static bool TryParse(string s, IFormatProvider formatProvider, out ByteSi
// Acquiring culture-specific parsing info
var numberFormat = GetNumberFormatInfo(formatProvider);

const NumberStyles numberStyles = AllowDecimalPoint | AllowThousands;
const NumberStyles numberStyles = AllowDecimalPoint | AllowThousands | AllowLeadingSign;
var numberSpecialChars = new[]
{
Convert.ToChar(numberFormat.NumberDecimalSeparator),
Convert.ToChar(numberFormat.NumberGroupSeparator),
Convert.ToChar(numberFormat.PositiveSign),
Convert.ToChar(numberFormat.NegativeSign),
};

// Setup the result
Expand Down

0 comments on commit 8db043d

Please sign in to comment.