From fb265eb8229eac6b3a90d0e2c2839fc3bafdcacd Mon Sep 17 00:00:00 2001 From: Jan Kotas Date: Sun, 6 Dec 2020 06:26:04 -0800 Subject: [PATCH 1/2] Delete redundant DivMod implementation --- .../Text/Utf8Formatter/FormattingHelpers.cs | 26 ------------------- .../Utf8Formatter/Utf8Formatter.TimeSpan.cs | 9 ++++--- 2 files changed, 5 insertions(+), 30 deletions(-) diff --git a/src/libraries/System.Private.CoreLib/src/System/Buffers/Text/Utf8Formatter/FormattingHelpers.cs b/src/libraries/System.Private.CoreLib/src/System/Buffers/Text/Utf8Formatter/FormattingHelpers.cs index 2a6019da191db..6316a19b33559 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Buffers/Text/Utf8Formatter/FormattingHelpers.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Buffers/Text/Utf8Formatter/FormattingHelpers.cs @@ -149,32 +149,6 @@ public static void WriteTwoDecimalDigits(uint value, Span buffer, int star #endregion UTF-8 Helper methods - #region Math Helper methods - - /// - /// We don't have access to Math.DivRem, so this is a copy of the implementation. - /// - [MethodImpl(MethodImplOptions.AggressiveInlining)] - public static ulong DivMod(ulong numerator, ulong denominator, out ulong modulo) - { - ulong div = numerator / denominator; - modulo = numerator - (div * denominator); - return div; - } - - /// - /// We don't have access to Math.DivRem, so this is a copy of the implementation. - /// - [MethodImpl(MethodImplOptions.AggressiveInlining)] - public static uint DivMod(uint numerator, uint denominator, out uint modulo) - { - uint div = numerator / denominator; - modulo = numerator - (div * denominator); - return div; - } - - #endregion Math Helper methods - // // Enable use of ThrowHelper from TryFormat() routines without introducing dozens of non-code-coveraged "bytesWritten = 0; return false" boilerplate. // diff --git a/src/libraries/System.Private.CoreLib/src/System/Buffers/Text/Utf8Formatter/Utf8Formatter.TimeSpan.cs b/src/libraries/System.Private.CoreLib/src/System/Buffers/Text/Utf8Formatter/Utf8Formatter.TimeSpan.cs index 6e4fc4f89c9f6..3fa8e67c02c5d 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Buffers/Text/Utf8Formatter/Utf8Formatter.TimeSpan.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Buffers/Text/Utf8Formatter/Utf8Formatter.TimeSpan.cs @@ -70,7 +70,8 @@ public static bool TryFormat(TimeSpan value, Span destination, out int byt } } - totalSecondsRemaining = FormattingHelpers.DivMod((ulong)Math.Abs(value.Ticks), TimeSpan.TicksPerSecond, out ulong fraction64); + ulong fraction64; + (totalSecondsRemaining, fraction64) = Math.DivRem((ulong)Math.Abs(value.Ticks), TimeSpan.TicksPerSecond); fraction = (uint)fraction64; } @@ -114,7 +115,7 @@ public static bool TryFormat(TimeSpan value, Span destination, out int byt if (totalSecondsRemaining > 0) { // Only compute minutes if the TimeSpan has an absolute value of >= 1 minute. - totalMinutesRemaining = FormattingHelpers.DivMod(totalSecondsRemaining, 60 /* seconds per minute */, out seconds); + (totalMinutesRemaining, seconds) = Math.DivRem(totalSecondsRemaining, 60 /* seconds per minute */); } Debug.Assert(seconds < 60); @@ -124,7 +125,7 @@ public static bool TryFormat(TimeSpan value, Span destination, out int byt if (totalMinutesRemaining > 0) { // Only compute hours if the TimeSpan has an absolute value of >= 1 hour. - totalHoursRemaining = FormattingHelpers.DivMod(totalMinutesRemaining, 60 /* minutes per hour */, out minutes); + (totalHoursRemaining, minutes) = Math.DivRem(totalMinutesRemaining, 60 /* minutes per hour */); } Debug.Assert(minutes < 60); @@ -137,7 +138,7 @@ public static bool TryFormat(TimeSpan value, Span destination, out int byt if (totalHoursRemaining > 0) { // Only compute days if the TimeSpan has an absolute value of >= 1 day. - days = FormattingHelpers.DivMod((uint)totalHoursRemaining, 24 /* hours per day */, out hours); + (days, hours) = Math.DivRem((uint)totalHoursRemaining, 24 /* hours per day */); } Debug.Assert(hours < 24); From 2b97fb9f69c5b9990f1302e455e2b3faea685216 Mon Sep 17 00:00:00 2001 From: Jan Kotas Date: Sun, 6 Dec 2020 09:43:10 -0800 Subject: [PATCH 2/2] Feedback --- .../System/Text/Json/Writer/JsonWriterHelper.Date.cs | 11 +++++------ 1 file changed, 5 insertions(+), 6 deletions(-) diff --git a/src/libraries/System.Text.Json/src/System/Text/Json/Writer/JsonWriterHelper.Date.cs b/src/libraries/System.Text.Json/src/System/Text/Json/Writer/JsonWriterHelper.Date.cs index d153241c753c7..6cf35610d0b50 100644 --- a/src/libraries/System.Text.Json/src/System/Text/Json/Writer/JsonWriterHelper.Date.cs +++ b/src/libraries/System.Text.Json/src/System/Text/Json/Writer/JsonWriterHelper.Date.cs @@ -69,7 +69,7 @@ public static void TrimDateTimeOffset(Span buffer, out int bytesWritten) // Remove trailing zeros while (true) { - uint quotient = DivMod(fraction, 10, out uint remainder); + (uint quotient, uint remainder) = DivRem(fraction, 10); if (remainder != 0) { break; @@ -132,14 +132,13 @@ public static void TrimDateTimeOffset(Span buffer, out int bytesWritten) } } - // We don't have access to System.Buffers.Text.FormattingHelpers.DivMod, + // We don't always have access to System.Math.DivRem, // so this is a copy of the implementation. [MethodImpl(MethodImplOptions.AggressiveInlining)] - private static uint DivMod(uint numerator, uint denominator, out uint modulo) + public static (uint Quotient, uint Remainder) DivRem(uint left, uint right) { - uint div = numerator / denominator; - modulo = numerator - (div * denominator); - return div; + uint quotient = left / right; + return (quotient, left - (quotient * right)); } } }