1
0
Fork 0
mirror of https://github.com/beefytech/Beef.git synced 2025-06-10 20:42:21 +02:00

Hooked up NumberFormatter calls for all int type ToString methods

This commit is contained in:
Alan Stagner 2020-05-31 11:55:36 -07:00
parent f9ee4010cb
commit 0e873f535e
8 changed files with 48 additions and 124 deletions

View file

@ -41,12 +41,14 @@ namespace System
public void ToString(String outString, String format, IFormatProvider formatProvider)
{
if ((format != null) && (format.StartsWith("X")))
if(format == null || format.IsEmpty)
{
((uint64)this).ToString(outString, format, formatProvider);
return;
ToString(outString);
}
else
{
NumberFormatter.NumberToString(format, (int32)this, formatProvider, outString);
}
((int64)this).ToString(outString, format, formatProvider);
}
}
}

View file

@ -104,27 +104,14 @@ namespace System
public void ToString(String outString, String format, IFormatProvider formatProvider)
{
int minNumerals = -1;
//TOTAL HACK:
if (format != null)
if(format == null || format.IsEmpty)
{
if (format.StartsWith("X"))
{
((UInt64)(uint32)this).ToString(outString, format, formatProvider);
return;
}
if ((format.Length > 0) && (format[0] == '0'))
{
if (Int32.Parse(format) case .Ok(let wantLen))
{
minNumerals = wantLen;
}
}
ToString(outString);
}
else
{
NumberFormatter.NumberToString(format, (int32)this, formatProvider, outString);
}
ToString(outString, minNumerals);
}
public static Result<int32, ParseError> Parse(StringView val, NumberStyles style)

View file

@ -55,13 +55,14 @@ namespace System
static String sHexLowerChars = "0123456789abcdef";
public void ToString(String outString, String format, IFormatProvider formatProvider)
{
if ((format != null) && (!format.IsEmpty))
if(format == null || format.IsEmpty)
{
((UInt64)this).ToString(outString, format, formatProvider);
return;
ToString(outString);
}
else
{
NumberFormatter.NumberToString(format, (int64)this, formatProvider, outString);
}
ToString(outString);
}
public override void ToString(String strBuffer)

View file

@ -41,12 +41,14 @@ namespace System
public void ToString(String outString, String format, IFormatProvider formatProvider)
{
if ((format != null) && (format.StartsWith("X")))
if(format == null || format.IsEmpty)
{
((uint64)this).ToString(outString, format, formatProvider);
return;
ToString(outString);
}
else
{
NumberFormatter.NumberToString(format, (int32)this, formatProvider, outString);
}
((int64)this).ToString(outString, format, formatProvider);
}
}
}

View file

@ -41,12 +41,14 @@ namespace System
public void ToString(String outString, String format, IFormatProvider formatProvider)
{
if ((format != null) && (format.StartsWith("X")))
if(format == null || format.IsEmpty)
{
((uint64)this).ToString(outString, format, formatProvider);
return;
ToString(outString);
}
else
{
NumberFormatter.NumberToString(format, (uint32)this, formatProvider, outString);
}
((int64)this).ToString(outString, format, formatProvider);
}
}
}

View file

@ -97,27 +97,14 @@ namespace System
public void ToString(String outString, String format, IFormatProvider formatProvider)
{
int minNumerals = -1;
//TOTAL HACK:
if (format != null)
if(format == null || format.IsEmpty)
{
if (format.StartsWith("X"))
{
((UInt64)(uint32)this).ToString(outString, format, formatProvider);
return;
}
if ((format.Length > 0) && (format[0] == '0'))
{
if (Int32.Parse(format) case .Ok(let wantLen))
{
minNumerals = wantLen;
}
}
ToString(outString);
}
else
{
NumberFormatter.NumberToString(format, (uint32)this, formatProvider, outString);
}
ToString(outString, minNumerals);
}
public static Result<uint32, ParseError> Parse(StringView val)

View file

@ -47,73 +47,14 @@ namespace System
static String sHexLowerChars = "0123456789abcdef";
public void ToString(String outString, String format, IFormatProvider formatProvider)
{
if (format != null)
if(format == null || format.IsEmpty)
{
if (format == "P")
{
String hexChars = (format == "p") ? sHexLowerChars : sHexUpperChars;
const int bufLen = 18;
char8* strChars = scope:: char8[bufLen]* (?);
int32 curLen = 0;
uint64 valLeft = (uint64)this;
while (valLeft > 0)
{
if (curLen == 8)
strChars[bufLen - curLen++ - 1] = '\'';
strChars[bufLen - curLen++ - 1] = hexChars[(int)(valLeft & 0xF)];
valLeft >>= 4;
}
while (curLen < 10)
{
if (curLen == 8)
strChars[bufLen - curLen++ - 1] = '\'';
strChars[bufLen - curLen++ - 1] = '0';
}
char8* char8Ptr = &strChars[bufLen - curLen];
outString.Append(char8Ptr, curLen);
return;
}
if (format.StartsWith("X", StringComparison.OrdinalIgnoreCase))
{
String hexChars = (format == "x") ? sHexLowerChars : sHexUpperChars;
const int bufLen = 18;
char8* strChars = scope:: char8[bufLen]* (?);
int32 curLen = 0;
uint64 valLeft = (uint64)this;
while (valLeft > 0)
{
strChars[bufLen - curLen - 1] = hexChars[(int)(valLeft & 0xF)];
valLeft >>= 4;
curLen++;
}
int32 minChars = 1;
if (format.Length > 0)
{
if (Int32.Parse(StringView(format, 1)) case .Ok(out minChars))
minChars = Math.Max(1, minChars);
}
while (curLen < minChars)
{
strChars[bufLen - curLen - 1] = '0';
curLen++;
}
char8* char8Ptr = &strChars[bufLen - curLen];
outString.Append(char8Ptr, curLen);
return;
}
ToString(outString);
}
else
{
NumberFormatter.NumberToString(format, (uint64)this, formatProvider, outString);
}
ToString(outString);
}
public override void ToString(String strBuffer)

View file

@ -41,12 +41,14 @@ namespace System
public void ToString(String outString, String format, IFormatProvider formatProvider)
{
if ((format != null) && (format.StartsWith("X")))
if(format == null || format.IsEmpty)
{
((uint64)this).ToString(outString, format, formatProvider);
return;
ToString(outString);
}
else
{
NumberFormatter.NumberToString(format, (uint32)this, formatProvider, outString);
}
((int64)this).ToString(outString, format, formatProvider);
}
}
}