From 7ded5ae60517b66bf1d5f695d066b13fca093a0c Mon Sep 17 00:00:00 2001 From: Marc Brooks Date: Fri, 14 Jun 2024 18:58:15 -0500 Subject: [PATCH 1/5] Expose the useful constant values in TimeSpan Make the useful constants that TimeSpan has internally declare public because they're rooted in hard reality and not changeable, and quite useful elsewhere. Update reference assembly and use the newly exposed values in all the places in Calendar and DateTime and related classes. Fixes #94545 --- .../System/Diagnostics/EventLogInternal.cs | 5 +- .../src/System/DateTime.Windows.cs | 24 +-- .../src/System/DateTime.cs | 141 ++++++++---------- .../src/System/DateTimeOffset.cs | 4 +- .../src/System/Diagnostics/Stopwatch.cs | 7 +- .../src/System/Globalization/Calendar.cs | 33 ++-- .../CalendricalCalculationsHelper.cs | 13 +- .../System/Globalization/DateTimeFormat.cs | 6 +- .../src/System/Globalization/DateTimeParse.cs | 14 +- .../System/Globalization/GregorianCalendar.cs | 4 +- .../System/Globalization/HebrewCalendar.cs | 8 +- .../src/System/Globalization/HijriCalendar.cs | 6 +- .../System/Globalization/JulianCalendar.cs | 12 +- .../System/Globalization/PersianCalendar.cs | 10 +- .../System/Globalization/UmAlQuraCalendar.cs | 6 +- .../src/System/IO/FileStatus.Unix.cs | 4 +- .../src/System/TimeSpan.cs | 30 ++-- .../src/System/Xml/XmlConverter.cs | 4 +- .../src/System/Xml/Schema/XsdDateTime.cs | 12 +- .../System.Runtime/ref/System.Runtime.cs | 16 ++ 20 files changed, 163 insertions(+), 196 deletions(-) diff --git a/src/libraries/System.Diagnostics.EventLog/src/System/Diagnostics/EventLogInternal.cs b/src/libraries/System.Diagnostics.EventLog/src/System/Diagnostics/EventLogInternal.cs index f34da4ccf018c..9b50d78ebc91f 100644 --- a/src/libraries/System.Diagnostics.EventLog/src/System/Diagnostics/EventLogInternal.cs +++ b/src/libraries/System.Diagnostics.EventLog/src/System/Diagnostics/EventLogInternal.cs @@ -55,7 +55,6 @@ internal sealed class EventLogInternal : IDisposable, ISupportInitialize private const string EventLogKey = "SYSTEM\\CurrentControlSet\\Services\\EventLog"; private const string eventLogMutexName = "netfxeventlog.1.0"; - private const int SecondsPerDay = 60 * 60 * 24; private const int Flag_notifying = 0x1; // keeps track of whether we're notifying our listeners - to prevent double notifications private const int Flag_forwards = 0x2; // whether the cache contains entries in forwards order (true) or backwards (false) @@ -317,7 +316,7 @@ public int MinimumRetentionDays if (retention == 0 || retention == -1) return retention; else - return (int)(((double)retention) / SecondsPerDay); + return (int)(((double)retention) / TimeSpan.SecondsPerDay); } return 7; @@ -1030,7 +1029,7 @@ public void ModifyOverflowPolicy(OverflowAction action, int retentionDays) if (retentionDays < 1 || retentionDays > 365) throw new ArgumentOutOfRangeException(SR.RentionDaysOutOfRange); - retentionvalue = (long)retentionDays * SecondsPerDay; + retentionvalue = (long)retentionDays * TimeSpan.SecondsPerDay; } using (RegistryKey logkey = GetLogRegKey(currentMachineName, true)) diff --git a/src/libraries/System.Private.CoreLib/src/System/DateTime.Windows.cs b/src/libraries/System.Private.CoreLib/src/System/DateTime.Windows.cs index e435255365e8f..1c0ac9210d2f9 100644 --- a/src/libraries/System.Private.CoreLib/src/System/DateTime.Windows.cs +++ b/src/libraries/System.Private.CoreLib/src/System/DateTime.Windows.cs @@ -77,7 +77,7 @@ private static unsafe DateTime FromFileTimeLeapSecondsAware(ulong fileTime) { throw new ArgumentOutOfRangeException(nameof(fileTime), SR.ArgumentOutOfRange_DateTimeBadTicks); } - return CreateDateTimeFromSystemTime(in time, fileTime % TicksPerMillisecond); + return CreateDateTimeFromSystemTime(in time, fileTime % TimeSpan.TicksPerMillisecond); } private static unsafe ulong ToFileTimeLeapSecondsAware(long ticks) @@ -112,20 +112,20 @@ private static DateTime CreateDateTimeFromSystemTime(in Interop.Kernel32.SYSTEMT ReadOnlySpan days = IsLeapYear((int)year) ? DaysToMonth366 : DaysToMonth365; int month = time.Month - 1; uint n = DaysToYear(year) + days[month] + time.Day - 1; - ulong ticks = n * (ulong)TicksPerDay; + ulong ticks = n * (ulong)TimeSpan.TicksPerDay; - ticks += time.Hour * (ulong)TicksPerHour; - ticks += time.Minute * (ulong)TicksPerMinute; + ticks += time.Hour * (ulong)TimeSpan.TicksPerHour; + ticks += time.Minute * (ulong)TimeSpan.TicksPerMinute; uint second = time.Second; if (second <= 59) { - ulong tmp = second * (uint)TicksPerSecond + time.Milliseconds * (uint)TicksPerMillisecond + hundredNanoSecond; + ulong tmp = second * (uint)TimeSpan.TicksPerSecond + time.Milliseconds * (uint)TimeSpan.TicksPerMillisecond + hundredNanoSecond; return new DateTime(ticks + tmp | KindUtc); } // we have a leap second, force it to last second in the minute as DateTime doesn't account for leap seconds in its calculation. // we use the maxvalue from the milliseconds and the 100-nano seconds to avoid reporting two out of order 59 seconds - ticks += TicksPerMinute - 1 | KindUtc; + ticks += TimeSpan.TicksPerMinute - 1 | KindUtc; return new DateTime(ticks); } @@ -166,7 +166,7 @@ private static unsafe bool GetSystemSupportsLeapSeconds() ((delegate* unmanaged[SuppressGCTransition])pfnGetSystemTime)(&systemTimeResult); ((delegate* unmanaged[SuppressGCTransition])pfnGetSystemTimePrecise)(&preciseSystemTimeResult); - if (Math.Abs(preciseSystemTimeResult - systemTimeResult) <= 100 * TicksPerMillisecond) + if (Math.Abs(preciseSystemTimeResult - systemTimeResult) <= 100 * TimeSpan.TicksPerMillisecond) { pfnGetSystemTime = pfnGetSystemTimePrecise; // use the precise version break; @@ -194,7 +194,7 @@ private static unsafe DateTime UpdateLeapSecondCacheAndReturnUtcNow() // cache will return incorrect values. Debug.Assert(SystemSupportsLeapSeconds); - Debug.Assert(LeapSecondCache.ValidityPeriodInTicks < TicksPerDay - TicksPerSecond, "Leap second cache validity window should be less than 23:59:59."); + Debug.Assert(LeapSecondCache.ValidityPeriodInTicks < TimeSpan.TicksPerDay - TimeSpan.TicksPerSecond, "Leap second cache validity window should be less than 23:59:59."); ulong fileTimeNow; LeapSecondCache.s_pfnGetSystemTimeAsFileTime(&fileTimeNow); @@ -203,7 +203,7 @@ private static unsafe DateTime UpdateLeapSecondCacheAndReturnUtcNow() // First, convert the FILETIME to a SYSTEMTIME. Interop.Kernel32.SYSTEMTIME systemTimeNow; - ulong hundredNanoSecondNow = fileTimeNow % TicksPerMillisecond; + ulong hundredNanoSecondNow = fileTimeNow % TimeSpan.TicksPerMillisecond; // We need the FILETIME and the SYSTEMTIME to reflect each other's values. // If FileTimeToSystemTime fails, call GetSystemTime and try again until it succeeds. @@ -267,7 +267,7 @@ private static unsafe DateTime UpdateLeapSecondCacheAndReturnUtcNow() } // StartOfValidityWindow = MidnightUtc + 23:59:59 - ValidityPeriod - fileTimeAtStartOfValidityWindow = fileTimeAtBeginningOfDay + (TicksPerDay - TicksPerSecond) - LeapSecondCache.ValidityPeriodInTicks; + fileTimeAtStartOfValidityWindow = fileTimeAtBeginningOfDay + (TimeSpan.TicksPerDay - TimeSpan.TicksPerSecond) - LeapSecondCache.ValidityPeriodInTicks; if (fileTimeNow - fileTimeAtStartOfValidityWindow >= LeapSecondCache.ValidityPeriodInTicks) { // If we're inside this block, then we slid the validity window back so far that the current time is no @@ -295,7 +295,7 @@ private static unsafe DateTime UpdateLeapSecondCacheAndReturnUtcNow() return CreateDateTimeFromSystemTime(systemTimeNow, hundredNanoSecondNow); } - dotnetDateDataAtStartOfValidityWindow = CreateDateTimeFromSystemTime(systemTimeAtBeginningOfDay, 0)._dateData + (TicksPerDay - TicksPerSecond) - LeapSecondCache.ValidityPeriodInTicks; + dotnetDateDataAtStartOfValidityWindow = CreateDateTimeFromSystemTime(systemTimeAtBeginningOfDay, 0)._dateData + (TimeSpan.TicksPerDay - TimeSpan.TicksPerSecond) - LeapSecondCache.ValidityPeriodInTicks; } // Finally, update the cache and return UtcNow. @@ -330,7 +330,7 @@ static DateTime LowGranularityNonCachedFallback() private sealed class LeapSecondCache { // The length of the validity window. Must be less than 23:59:59. - internal const ulong ValidityPeriodInTicks = TicksPerMinute * 5; + internal const ulong ValidityPeriodInTicks = TimeSpan.TicksPerMinute * 5; // The FILETIME value at the beginning of the validity window. internal ulong OSFileTimeTicksAtStartOfValidityWindow; diff --git a/src/libraries/System.Private.CoreLib/src/System/DateTime.cs b/src/libraries/System.Private.CoreLib/src/System/DateTime.cs index 3eeaaabbd358a..4a3a3a28e3c99 100644 --- a/src/libraries/System.Private.CoreLib/src/System/DateTime.cs +++ b/src/libraries/System.Private.CoreLib/src/System/DateTime.cs @@ -56,23 +56,6 @@ public readonly partial struct DateTime ISpanParsable, IUtf8SpanFormattable { - // Number of 100ns ticks per time unit - internal const int MicrosecondsPerMillisecond = 1000; - private const long TicksPerMicrosecond = 10; - private const long TicksPerMillisecond = TicksPerMicrosecond * MicrosecondsPerMillisecond; - - private const int HoursPerDay = 24; - private const long TicksPerSecond = TicksPerMillisecond * 1000; - private const long TicksPerMinute = TicksPerSecond * 60; - private const long TicksPerHour = TicksPerMinute * 60; - private const long TicksPerDay = TicksPerHour * HoursPerDay; - - // Number of milliseconds per time unit - private const int MillisPerSecond = 1000; - private const int MillisPerMinute = MillisPerSecond * 60; - private const int MillisPerHour = MillisPerMinute * 60; - private const int MillisPerDay = MillisPerHour * HoursPerDay; - // Number of days in a non-leap year private const int DaysPerYear = 365; // Number of days in 4 years @@ -92,20 +75,20 @@ public readonly partial struct DateTime private const int DaysTo10000 = DaysPer400Years * 25 - 366; // 3652059 internal const long MinTicks = 0; - internal const long MaxTicks = DaysTo10000 * TicksPerDay - 1; - private const long MaxMicroseconds = MaxTicks / TicksPerMicrosecond; - private const long MaxMillis = MaxTicks / TicksPerMillisecond; - private const long MaxSeconds = MaxTicks / TicksPerSecond; - private const long MaxMinutes = MaxTicks / TicksPerMinute; - private const long MaxHours = MaxTicks / TicksPerHour; + internal const long MaxTicks = DaysTo10000 * TimeSpan.TicksPerDay - 1; + private const long MaxMicroseconds = MaxTicks / TimeSpan.TicksPerMicrosecond; + private const long MaxMillis = MaxTicks / TimeSpan.TicksPerMillisecond; + private const long MaxSeconds = MaxTicks / TimeSpan.TicksPerSecond; + private const long MaxMinutes = MaxTicks / TimeSpan.TicksPerMinute; + private const long MaxHours = MaxTicks / TimeSpan.TicksPerHour; private const long MaxDays = (long)DaysTo10000 - 1; - internal const long UnixEpochTicks = DaysTo1970 * TicksPerDay; - private const long FileTimeOffset = DaysTo1601 * TicksPerDay; - private const long DoubleDateOffset = DaysTo1899 * TicksPerDay; + internal const long UnixEpochTicks = DaysTo1970 * TimeSpan.TicksPerDay; + private const long FileTimeOffset = DaysTo1601 * TimeSpan.TicksPerDay; + private const long DoubleDateOffset = DaysTo1899 * TimeSpan.TicksPerDay; // The minimum OA date is 0100/01/01 (Note it's year 100). // The maximum OA date is 9999/12/31 - private const long OADateMinAsTicks = (DaysPer100Years - DaysPerYear) * TicksPerDay; + private const long OADateMinAsTicks = (DaysPer100Years - DaysPerYear) * TimeSpan.TicksPerDay; // All OA dates must be greater than (not >=) OADateMinAsDouble private const double OADateMinAsDouble = -657435.0; // All OA dates must be less than (not <=) OADateMaxAsDouble @@ -119,7 +102,7 @@ public readonly partial struct DateTime private const uint EafMultiplier = (uint)(((1UL << 32) + DaysPer4Years - 1) / DaysPer4Years); // 2,939,745 private const uint EafDivider = EafMultiplier * 4; // 11,758,980 - private const ulong TicksPer6Hours = TicksPerHour * 6; + private const ulong TicksPer6Hours = TimeSpan.TicksPerHour * 6; private const int March1BasedDayOfNewYear = 306; // Days between March 1 and January 1 internal static ReadOnlySpan DaysToMonth365 => [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334, 365]; @@ -221,8 +204,8 @@ internal DateTime(long ticks, DateTimeKind kind, bool isAmbiguousDst) private static void ThrowTicksOutOfRange() => throw new ArgumentOutOfRangeException("ticks", SR.ArgumentOutOfRange_DateTimeBadTicks); private static void ThrowInvalidKind() => throw new ArgumentException(SR.Argument_InvalidDateTimeKind, "kind"); - private static void ThrowMillisecondOutOfRange() => throw new ArgumentOutOfRangeException("millisecond", SR.Format(SR.ArgumentOutOfRange_Range, 0, MillisPerSecond - 1)); - private static void ThrowMicrosecondOutOfRange() => throw new ArgumentOutOfRangeException("microsecond", SR.Format(SR.ArgumentOutOfRange_Range, 0, MicrosecondsPerMillisecond - 1)); + private static void ThrowMillisecondOutOfRange() => throw new ArgumentOutOfRangeException("millisecond", SR.Format(SR.ArgumentOutOfRange_Range, 0, TimeSpan.MillisecondsPerSecond - 1)); + private static void ThrowMicrosecondOutOfRange() => throw new ArgumentOutOfRangeException("microsecond", SR.Format(SR.ArgumentOutOfRange_Range, 0, TimeSpan.MicrosecondsPerMillisecond - 1)); private static void ThrowDateArithmetic(int param) => throw new ArgumentOutOfRangeException(param switch { 0 => "value", 1 => "t", _ => "months" }, SR.ArgumentOutOfRange_DateArithmetic); private static void ThrowAddOutOfRange() => throw new ArgumentOutOfRangeException("value", SR.ArgumentOutOfRange_AddValue); @@ -304,7 +287,7 @@ public DateTime(int year, int month, int day, int hour, int minute, int second, { ArgumentNullException.ThrowIfNull(calendar); - if ((uint)millisecond >= MillisPerSecond) ThrowMillisecondOutOfRange(); + if ((uint)millisecond >= TimeSpan.MillisecondsPerSecond) ThrowMillisecondOutOfRange(); if ((uint)kind > (uint)DateTimeKind.Local) ThrowInvalidKind(); if (second != 60 || !SystemSupportsLeapSeconds) @@ -666,9 +649,9 @@ public DateTime(int year, int month, int day, int hour, int minute, int second, public DateTime(int year, int month, int day, int hour, int minute, int second, int millisecond, int microsecond, DateTimeKind kind) { ulong ticks = Init(year, month, day, hour, minute, second, millisecond, kind); - if ((uint)microsecond >= MicrosecondsPerMillisecond) ThrowMicrosecondOutOfRange(); + if ((uint)microsecond >= TimeSpan.MicrosecondsPerMillisecond) ThrowMicrosecondOutOfRange(); - ulong newTicks = (ticks & TicksMask) + (ulong)(microsecond * TicksPerMicrosecond); + ulong newTicks = (ticks & TicksMask) + (ulong)(microsecond * TimeSpan.TicksPerMicrosecond); Debug.Assert(newTicks <= MaxTicks); _dateData = newTicks | (ticks & FlagsMask); @@ -799,7 +782,7 @@ public DateTime(int year, int month, int day, int hour, int minute, int second, public DateTime(int year, int month, int day, int hour, int minute, int second, int millisecond, int microsecond, Calendar calendar, DateTimeKind kind) : this(year, month, day, hour, minute, second, millisecond, calendar, kind) { - if ((uint)microsecond >= MicrosecondsPerMillisecond) + if ((uint)microsecond >= TimeSpan.MicrosecondsPerMillisecond) { ThrowMicrosecondOutOfRange(); } @@ -809,13 +792,13 @@ public DateTime(int year, int month, int day, int hour, int minute, int second, [MethodImpl(MethodImplOptions.AggressiveInlining)] private static ulong Init(int year, int month, int day, int hour, int minute, int second, int millisecond, DateTimeKind kind = DateTimeKind.Unspecified) { - if ((uint)millisecond >= MillisPerSecond) ThrowMillisecondOutOfRange(); + if ((uint)millisecond >= TimeSpan.MillisecondsPerSecond) ThrowMillisecondOutOfRange(); if ((uint)kind > (uint)DateTimeKind.Local) ThrowInvalidKind(); if (second != 60 || !SystemSupportsLeapSeconds) { ulong ticks = DateToTicks(year, month, day) + TimeToTicks(hour, minute, second); - ticks += (uint)millisecond * (uint)TicksPerMillisecond; + ticks += (uint)millisecond * (uint)TimeSpan.TicksPerMillisecond; Debug.Assert(ticks <= MaxTicks, "Input parameters validated already"); return ticks | ((ulong)kind << KindShift); } @@ -906,7 +889,7 @@ private DateTime AddUnits(double value, long maxUnitCount, long ticksPerUnit) /// /// An object whose value is the sum of the date and time represented by this instance and the number of days represented by value. /// - public DateTime AddDays(double value) => AddUnits(value, MaxDays, TicksPerDay); + public DateTime AddDays(double value) => AddUnits(value, MaxDays, TimeSpan.TicksPerDay); /// /// Returns a new that adds the specified number of hours to the value of this instance. @@ -915,7 +898,7 @@ private DateTime AddUnits(double value, long maxUnitCount, long ticksPerUnit) /// /// An object whose value is the sum of the date and time represented by this instance and the number of hours represented by value. /// - public DateTime AddHours(double value) => AddUnits(value, MaxHours, TicksPerHour); + public DateTime AddHours(double value) => AddUnits(value, MaxHours, TimeSpan.TicksPerHour); /// /// Returns a new that adds the specified number of milliseconds to the value of this instance. @@ -924,7 +907,7 @@ private DateTime AddUnits(double value, long maxUnitCount, long ticksPerUnit) /// /// An object whose value is the sum of the date and time represented by this instance and the number of milliseconds represented by value. /// - public DateTime AddMilliseconds(double value) => AddUnits(value, MaxMillis, TicksPerMillisecond); + public DateTime AddMilliseconds(double value) => AddUnits(value, MaxMillis, TimeSpan.TicksPerMillisecond); /// /// Returns a new that adds the specified number of microseconds to the value of this instance. @@ -950,7 +933,7 @@ private DateTime AddUnits(double value, long maxUnitCount, long ticksPerUnit) /// /// The resulting is less than or greater than . /// - public DateTime AddMicroseconds(double value) => AddUnits(value, MaxMicroseconds, TicksPerMicrosecond); + public DateTime AddMicroseconds(double value) => AddUnits(value, MaxMicroseconds, TimeSpan.TicksPerMicrosecond); /// /// Returns a new that adds the specified number of minutes to the value of this instance. @@ -959,7 +942,7 @@ private DateTime AddUnits(double value, long maxUnitCount, long ticksPerUnit) /// /// An object whose value is the sum of the date and time represented by this instance and the number of minutes represented by value. /// - public DateTime AddMinutes(double value) => AddUnits(value, MaxMinutes, TicksPerMinute); + public DateTime AddMinutes(double value) => AddUnits(value, MaxMinutes, TimeSpan.TicksPerMinute); // Returns the DateTime resulting from adding the given number of // months to this DateTime. The result is computed by incrementing @@ -993,7 +976,7 @@ public DateTime AddMonths(int months) int days = (int)(daysTo[m] - daysToMonth); if (d > days) d = days; uint n = DaysToYear((uint)y) + daysToMonth + (uint)d - 1; - return new DateTime(n * (ulong)TicksPerDay + UTicks % TicksPerDay | InternalKind); + return new DateTime(n * (ulong)TimeSpan.TicksPerDay + UTicks % TimeSpan.TicksPerDay | InternalKind); } /// @@ -1003,7 +986,7 @@ public DateTime AddMonths(int months) /// /// An object whose value is the sum of the date and time represented by this instance and the number of seconds represented by value. /// - public DateTime AddSeconds(double value) => AddUnits(value, MaxSeconds, TicksPerSecond); + public DateTime AddSeconds(double value) => AddUnits(value, MaxSeconds, TimeSpan.TicksPerSecond); // Returns the DateTime resulting from adding the given number of // 100-nanosecond ticks to this DateTime. The value argument @@ -1059,7 +1042,7 @@ public DateTime AddYears(int value) n += DaysToMonth365[m]; } n += (uint)d; - return new DateTime(n * (ulong)TicksPerDay + UTicks % TicksPerDay | InternalKind); + return new DateTime(n * (ulong)TimeSpan.TicksPerDay + UTicks % TimeSpan.TicksPerDay | InternalKind); } // Compares two DateTime values, returning an integer that indicates @@ -1113,7 +1096,7 @@ private static ulong DateToTicks(int year, int month, int day) } uint n = DaysToYear((uint)year) + days[month - 1] + (uint)day - 1; - return n * (ulong)TicksPerDay; + return n * (ulong)TimeSpan.TicksPerDay; } [MethodImpl(MethodImplOptions.AggressiveInlining)] @@ -1135,16 +1118,16 @@ private static ulong TimeToTicks(int hour, int minute, int second) } int totalSeconds = hour * 3600 + minute * 60 + second; - return (uint)totalSeconds * (ulong)TicksPerSecond; + return (uint)totalSeconds * (ulong)TimeSpan.TicksPerSecond; } internal static ulong TimeToTicks(int hour, int minute, int second, int millisecond) { ulong ticks = TimeToTicks(hour, minute, second); - if ((uint)millisecond >= MillisPerSecond) ThrowMillisecondOutOfRange(); + if ((uint)millisecond >= TimeSpan.MillisecondsPerSecond) ThrowMillisecondOutOfRange(); - ticks += (uint)millisecond * (uint)TicksPerMillisecond; + ticks += (uint)millisecond * (uint)TimeSpan.TicksPerMillisecond; Debug.Assert(ticks <= MaxTicks, "Input parameters validated already"); @@ -1155,9 +1138,9 @@ internal static ulong TimeToTicks(int hour, int minute, int second, int millisec { ulong ticks = TimeToTicks(hour, minute, second, millisecond); - if ((uint)microsecond >= MicrosecondsPerMillisecond) ThrowMicrosecondOutOfRange(); + if ((uint)microsecond >= TimeSpan.MicrosecondsPerMillisecond) ThrowMicrosecondOutOfRange(); - ticks += (uint)microsecond * (uint)TicksPerMicrosecond; + ticks += (uint)microsecond * (uint)TimeSpan.TicksPerMicrosecond; Debug.Assert(ticks <= MaxTicks, "Input parameters validated already"); @@ -1183,19 +1166,19 @@ internal static long DoubleDateToTicks(double value) throw new ArgumentException(SR.Arg_OleAutDateInvalid); // Conversion to long will not cause an overflow here, as at this point the "value" is in between OADateMinAsDouble and OADateMaxAsDouble - long millis = (long)(value * MillisPerDay + (value >= 0 ? 0.5 : -0.5)); + long millis = (long)(value * TimeSpan.MillisecondsPerDay + (value >= 0 ? 0.5 : -0.5)); // The interesting thing here is when you have a value like 12.5 it all positive 12 days and 12 hours from 01/01/1899 // However if you a value of -12.25 it is minus 12 days but still positive 6 hours, almost as though you meant -11.75 all negative - // This line below fixes up the millis in the negative case + // This line below fixes up the milliseconds in the negative case if (millis < 0) { - millis -= (millis % MillisPerDay) * 2; + millis -= (millis % TimeSpan.MillisecondsPerDay) * 2; } - millis += DoubleDateOffset / TicksPerMillisecond; + millis += DoubleDateOffset / TimeSpan.TicksPerMillisecond; if (millis < 0 || millis > MaxMillis) throw new ArgumentException(SR.Arg_OleAutDateScale); - return millis * TicksPerMillisecond; + return millis * TimeSpan.TicksPerMillisecond; } // Checks if this DateTime is equal to a given object. Returns @@ -1232,7 +1215,7 @@ public static DateTime FromBinary(long dateData) // local date. long ticks = dateData & (unchecked((long)TicksMask)); // Negative ticks are stored in the top part of the range and should be converted back into a negative number - if (ticks > TicksCeiling - TicksPerDay) + if (ticks > TicksCeiling - TimeSpan.TicksPerDay) { ticks -= TicksCeiling; } @@ -1260,7 +1243,7 @@ public static DateTime FromBinary(long dateData) // to compare times of day if (ticks < 0) { - ticks += TicksPerDay; + ticks += TimeSpan.TicksPerDay; } if ((ulong)ticks > MaxTicks) { @@ -1371,7 +1354,7 @@ public DateTime Date get { ulong ticks = UTicks; - return new DateTime((ticks - ticks % TicksPerDay) | InternalKind); + return new DateTime((ticks - ticks % TimeSpan.TicksPerDay) | InternalKind); } } @@ -1405,7 +1388,7 @@ internal void GetDate(out int year, out int month, out int day) [MethodImpl(MethodImplOptions.AggressiveInlining)] internal void GetTime(out int hour, out int minute, out int second) { - ulong seconds = UTicks / TicksPerSecond; + ulong seconds = UTicks / TimeSpan.TicksPerSecond; ulong minutes = seconds / 60; second = (int)(seconds - (minutes * 60)); ulong hours = minutes / 60; @@ -1416,7 +1399,7 @@ internal void GetTime(out int hour, out int minute, out int second) [MethodImpl(MethodImplOptions.AggressiveInlining)] internal void GetTime(out int hour, out int minute, out int second, out int millisecond) { - ulong milliseconds = UTicks / TicksPerMillisecond; + ulong milliseconds = UTicks / TimeSpan.TicksPerMillisecond; ulong seconds = milliseconds / 1000; millisecond = (int)(milliseconds - (seconds * 1000)); ulong minutes = seconds / 60; @@ -1430,8 +1413,8 @@ internal void GetTime(out int hour, out int minute, out int second, out int mill internal void GetTimePrecise(out int hour, out int minute, out int second, out int tick) { ulong ticks = UTicks; - ulong seconds = ticks / TicksPerSecond; - tick = (int)(ticks - (seconds * TicksPerSecond)); + ulong seconds = ticks / TimeSpan.TicksPerSecond; + tick = (int)(ticks - (seconds * TimeSpan.TicksPerSecond)); ulong minutes = seconds / 60; second = (int)(seconds - (minutes * 60)); ulong hours = minutes / 60; @@ -1461,7 +1444,7 @@ public int Day // Monday, 2 indicates Tuesday, 3 indicates Wednesday, 4 indicates // Thursday, 5 indicates Friday, and 6 indicates Saturday. // - public DayOfWeek DayOfWeek => (DayOfWeek)(((uint)(UTicks / TicksPerDay) + 1) % 7); + public DayOfWeek DayOfWeek => (DayOfWeek)(((uint)(UTicks / TimeSpan.TicksPerDay) + 1) % 7); // Returns the day-of-year part of this DateTime. The returned value // is an integer between 1 and 366. @@ -1480,7 +1463,7 @@ public override int GetHashCode() // Returns the hour part of this DateTime. The returned value is an // integer between 0 and 23. // - public int Hour => (int)((uint)(UTicks / TicksPerHour) % 24); + public int Hour => (int)((uint)(UTicks / TimeSpan.TicksPerHour) % 24); internal bool IsAmbiguousDaylightSavingTime() => InternalKind == KindLocalAmbiguousDst; @@ -1499,22 +1482,22 @@ public DateTimeKind Kind // Returns the millisecond part of this DateTime. The returned value // is an integer between 0 and 999. // - public int Millisecond => (int)((UTicks / TicksPerMillisecond) % 1000); + public int Millisecond => (int)((UTicks / TimeSpan.TicksPerMillisecond) % 1000); /// /// The microseconds component, expressed as a value between 0 and 999. /// - public int Microsecond => (int)((UTicks / TicksPerMicrosecond) % 1000); + public int Microsecond => (int)((UTicks / TimeSpan.TicksPerMicrosecond) % 1000); /// /// The nanoseconds component, expressed as a value between 0 and 900 (in increments of 100 nanoseconds). /// - public int Nanosecond => (int)(UTicks % TicksPerMicrosecond) * 100; + public int Nanosecond => (int)(UTicks % TimeSpan.TicksPerMicrosecond) * 100; // Returns the minute part of this DateTime. The returned value is // an integer between 0 and 59. // - public int Minute => (int)((UTicks / TicksPerMinute) % 60); + public int Minute => (int)((UTicks / TimeSpan.TicksPerMinute) % 60); // Returns the month part of this DateTime. The returned value is an // integer between 1 and 12. @@ -1556,7 +1539,7 @@ public static DateTime Now // Returns the second part of this DateTime. The returned value is // an integer between 0 and 59. // - public int Second => (int)((UTicks / TicksPerSecond) % 60); + public int Second => (int)((UTicks / TimeSpan.TicksPerSecond) % 60); // Returns the tick count for this DateTime. The returned value is // the number of 100-nanosecond intervals that have elapsed since 1/1/0001 @@ -1567,7 +1550,7 @@ public static DateTime Now // Returns the time-of-day part of this DateTime. The returned value // is a TimeSpan that indicates the time elapsed since midnight. // - public TimeSpan TimeOfDay => new TimeSpan((long)(UTicks % TicksPerDay)); + public TimeSpan TimeOfDay => new TimeSpan((long)(UTicks % TimeSpan.TicksPerDay)); // Returns a DateTime representing the current date. The date part // of the returned value is the current date, and the time-of-day part of @@ -1696,19 +1679,19 @@ private static double TicksToOADate(long value) { if (value == 0) return 0.0; // Returns OleAut's zero'ed date value. - if (value < TicksPerDay) // This is a fix for VB. They want the default day to be 1/1/0001 rathar then 12/30/1899. + if (value < TimeSpan.TicksPerDay) // This is a fix for VB. They want the default day to be 1/1/0001 rathar then 12/30/1899. value += DoubleDateOffset; // We could have moved this fix down but we would like to keep the bounds check. if (value < OADateMinAsTicks) throw new OverflowException(SR.Arg_OleAutDateInvalid); // Currently, our max date == OA's max date (12/31/9999), so we don't // need an overflow check in that direction. - long millis = (value - DoubleDateOffset) / TicksPerMillisecond; + long millis = (value - DoubleDateOffset) / TimeSpan.TicksPerMillisecond; if (millis < 0) { - long frac = millis % MillisPerDay; - if (frac != 0) millis -= (MillisPerDay + frac) * 2; + long frac = millis % TimeSpan.MillisecondsPerDay; + if (frac != 0) millis -= (TimeSpan.MillisecondsPerDay + frac) * 2; } - return (double)millis / MillisPerDay; + return (double)millis / TimeSpan.MillisecondsPerDay; } // Converts the DateTime instance into an OLE Automation compatible @@ -2020,7 +2003,7 @@ internal static bool TryCreate(int year, int month, int day, int hour, int minut { return false; } - if ((uint)hour >= 24 || (uint)minute >= 60 || (uint)millisecond >= MillisPerSecond) + if ((uint)hour >= 24 || (uint)minute >= 60 || (uint)millisecond >= TimeSpan.MillisecondsPerSecond) { return false; } @@ -2030,11 +2013,11 @@ internal static bool TryCreate(int year, int month, int day, int hour, int minut { return false; } - ulong ticks = (DaysToYear((uint)year) + days[month - 1] + (uint)day - 1) * (ulong)TicksPerDay; + ulong ticks = (DaysToYear((uint)year) + days[month - 1] + (uint)day - 1) * (ulong)TimeSpan.TicksPerDay; if ((uint)second < 60) { - ticks += TimeToTicks(hour, minute, second) + (uint)millisecond * (uint)TicksPerMillisecond; + ticks += TimeToTicks(hour, minute, second) + (uint)millisecond * (uint)TimeSpan.TicksPerMillisecond; } else if (second == 60 && SystemSupportsLeapSeconds && IsValidTimeWithLeapSeconds(year, month, day, hour, minute, DateTimeKind.Unspecified)) { @@ -2043,7 +2026,7 @@ internal static bool TryCreate(int year, int month, int day, int hour, int minut // of this minute. // if it is not valid time, we'll eventually throw. // although this is unspecified datetime kind, we'll assume the passed time is UTC to check the leap seconds. - ticks += TimeToTicks(hour, minute, 59) + 999 * TicksPerMillisecond; + ticks += TimeToTicks(hour, minute, 59) + 999 * TimeSpan.TicksPerMillisecond; } else { diff --git a/src/libraries/System.Private.CoreLib/src/System/DateTimeOffset.cs b/src/libraries/System.Private.CoreLib/src/System/DateTimeOffset.cs index 5baf1e5076b6e..73fe858885e9b 100644 --- a/src/libraries/System.Private.CoreLib/src/System/DateTimeOffset.cs +++ b/src/libraries/System.Private.CoreLib/src/System/DateTimeOffset.cs @@ -250,7 +250,7 @@ public DateTimeOffset(int year, int month, int day, int hour, int minute, int se public DateTimeOffset(int year, int month, int day, int hour, int minute, int second, int millisecond, int microsecond, TimeSpan offset) : this(year, month, day, hour, minute, second, millisecond, offset) { - if ((uint)microsecond >= DateTime.MicrosecondsPerMillisecond) + if ((uint)microsecond >= TimeSpan.MicrosecondsPerMillisecond) { throw new ArgumentOutOfRangeException(nameof(microsecond), SR.ArgumentOutOfRange_BadHourMinuteSecond); } @@ -327,7 +327,7 @@ public DateTimeOffset(int year, int month, int day, int hour, int minute, int se public DateTimeOffset(int year, int month, int day, int hour, int minute, int second, int millisecond, int microsecond, Calendar calendar, TimeSpan offset) : this(year, month, day, hour, minute, second, millisecond, calendar, offset) { - if ((uint)microsecond >= DateTime.MicrosecondsPerMillisecond) + if ((uint)microsecond >= TimeSpan.MicrosecondsPerMillisecond) { throw new ArgumentOutOfRangeException(nameof(microsecond), SR.ArgumentOutOfRange_BadHourMinuteSecond); } diff --git a/src/libraries/System.Private.CoreLib/src/System/Diagnostics/Stopwatch.cs b/src/libraries/System.Private.CoreLib/src/System/Diagnostics/Stopwatch.cs index 8c27526555092..33f5998a96248 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Diagnostics/Stopwatch.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Diagnostics/Stopwatch.cs @@ -10,9 +10,6 @@ namespace System.Diagnostics [DebuggerDisplay("{DebuggerDisplay,nq}")] public partial class Stopwatch { - private const long TicksPerMillisecond = 10000; - private const long TicksPerSecond = TicksPerMillisecond * 1000; - private long _elapsed; private long _startTimeStamp; private bool _isRunning; @@ -27,7 +24,7 @@ public partial class Stopwatch // performance-counter frequency, in counts per ticks. // This can speed up conversion from high frequency performance-counter // to ticks. - private static readonly double s_tickFrequency = (double)TicksPerSecond / Frequency; + private static readonly double s_tickFrequency = (double)TimeSpan.TicksPerSecond / Frequency; public Stopwatch() { @@ -109,7 +106,7 @@ public TimeSpan Elapsed public long ElapsedMilliseconds { - get { return GetElapsedDateTimeTicks() / TicksPerMillisecond; } + get { return GetElapsedDateTimeTicks() / TimeSpan.TicksPerMillisecond; } } public long ElapsedTicks diff --git a/src/libraries/System.Private.CoreLib/src/System/Globalization/Calendar.cs b/src/libraries/System.Private.CoreLib/src/System/Globalization/Calendar.cs index 2b9f984da91d6..ed8aa88db428e 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Globalization/Calendar.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Globalization/Calendar.cs @@ -28,19 +28,6 @@ namespace System.Globalization public abstract class Calendar : ICloneable { - // Number of 100ns (10E-7 second) ticks per time unit - internal const long TicksPerMillisecond = 10000; - internal const long TicksPerSecond = TicksPerMillisecond * 1000; - internal const long TicksPerMinute = TicksPerSecond * 60; - internal const long TicksPerHour = TicksPerMinute * 60; - internal const long TicksPerDay = TicksPerHour * 24; - - // Number of milliseconds per time unit - internal const int MillisPerSecond = 1000; - internal const int MillisPerMinute = MillisPerSecond * 60; - internal const int MillisPerHour = MillisPerMinute * 60; - internal const int MillisPerDay = MillisPerHour * 24; - // Number of days in a non-leap year internal const int DaysPerYear = 365; // Number of days in 4 years @@ -53,7 +40,7 @@ public abstract class Calendar : ICloneable // Number of days from 1/1/0001 to 1/1/10000 internal const int DaysTo10000 = DaysPer400Years * 25 - 366; - internal const long MaxMillis = (long)DaysTo10000 * MillisPerDay; + internal const long MaxMillis = (long)DaysTo10000 * TimeSpan.MillisecondsPerDay; private int _currentEraValue = -1; @@ -140,7 +127,7 @@ internal static void CheckAddResult(long ticks, DateTime minValue, DateTime maxV } } - internal DateTime Add(DateTime time, double value, int scale) + internal DateTime Add(DateTime time, double value, long scale) { // From ECMA CLI spec, Partition III, section 3.27: // @@ -156,7 +143,7 @@ internal DateTime Add(DateTime time, double value, int scale) } long millis = (long)tempMillis; - long ticks = time.Ticks + millis * TicksPerMillisecond; + long ticks = time.Ticks + millis * TimeSpan.TicksPerMillisecond; CheckAddResult(ticks, MinSupportedDateTime, MaxSupportedDateTime); return new DateTime(ticks); } @@ -182,7 +169,7 @@ public virtual DateTime AddMilliseconds(DateTime time, double milliseconds) /// public virtual DateTime AddDays(DateTime time, int days) { - return Add(time, days, MillisPerDay); + return Add(time, days, TimeSpan.MillisecondsPerDay); } /// @@ -194,7 +181,7 @@ public virtual DateTime AddDays(DateTime time, int days) /// public virtual DateTime AddHours(DateTime time, int hours) { - return Add(time, hours, MillisPerHour); + return Add(time, hours, TimeSpan.MillisecondsPerHour); } /// @@ -206,7 +193,7 @@ public virtual DateTime AddHours(DateTime time, int hours) /// public virtual DateTime AddMinutes(DateTime time, int minutes) { - return Add(time, minutes, MillisPerMinute); + return Add(time, minutes, TimeSpan.MillisecondsPerMinute); } /// @@ -238,7 +225,7 @@ public virtual DateTime AddMinutes(DateTime time, int minutes) /// public virtual DateTime AddSeconds(DateTime time, int seconds) { - return Add(time, seconds, MillisPerSecond); + return Add(time, seconds, TimeSpan.MillisecondsPerSecond); } // Returns the DateTime resulting from adding a number of @@ -695,16 +682,16 @@ internal static long TimeToTicks(int hour, int minute, int second, int milliseco { throw new ArgumentOutOfRangeException(null, SR.ArgumentOutOfRange_BadHourMinuteSecond); } - if ((uint)millisecond >= MillisPerSecond) + if ((uint)millisecond >= TimeSpan.MillisecondsPerSecond) { throw new ArgumentOutOfRangeException( nameof(millisecond), millisecond, - SR.Format(SR.ArgumentOutOfRange_Range, 0, MillisPerSecond - 1)); + SR.Format(SR.ArgumentOutOfRange_Range, 0, TimeSpan.MillisecondsPerSecond - 1)); } int totalSeconds = hour * 3600 + minute * 60 + second; - return totalSeconds * TicksPerSecond + millisecond * TicksPerMillisecond; + return totalSeconds * TimeSpan.TicksPerSecond + millisecond * TimeSpan.TicksPerMillisecond; } internal static int GetSystemTwoDigitYearSetting(CalendarId CalID, int defaultYearValue) diff --git a/src/libraries/System.Private.CoreLib/src/System/Globalization/CalendricalCalculationsHelper.cs b/src/libraries/System.Private.CoreLib/src/System/Globalization/CalendricalCalculationsHelper.cs index 2da0a19372b89..c50bbfd491f51 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Globalization/CalendricalCalculationsHelper.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Globalization/CalendricalCalculationsHelper.cs @@ -15,7 +15,6 @@ internal static class CalendricalCalculationsHelper private const double MeanSpeedOfSun = MeanTropicalYearInDays / FullCircleOfArc; private const double LongitudeSpring = 0.0; private const double TwoDegreesAfterSpring = 2.0; - private const int SecondsPerDay = 24 * 60 * 60; // 24 hours * 60 minutes * 60 seconds private const int DaysInUniformLengthCentury = 36525; private static readonly long s_startOf1810 = GetNumberOfDays(new DateTime(1810, 1, 1)); @@ -59,12 +58,12 @@ private static double Obliquity(double julianCenturies) internal static long GetNumberOfDays(DateTime date) { - return date.Ticks / Calendar.TicksPerDay; + return date.Ticks / TimeSpan.TicksPerDay; } private static int GetGregorianYear(double numberOfDays) { - return new DateTime(Math.Min((long)(Math.Floor(numberOfDays) * Calendar.TicksPerDay), DateTime.MaxValue.Ticks)).Year; + return new DateTime(Math.Min((long)(Math.Floor(numberOfDays) * TimeSpan.TicksPerDay), DateTime.MaxValue.Ticks)).Year; } private enum CorrectionAlgorithm @@ -148,13 +147,13 @@ private static double DefaultEphemerisCorrection(int gregorianYear) long january1stOfYear = GetNumberOfDays(new DateTime(gregorianYear, 1, 1)); double daysSinceStartOf1810 = january1stOfYear - s_startOf1810; double x = TwelveHours + daysSinceStartOf1810; - return ((Math.Pow(x, 2) / 41048480) - 15) / SecondsPerDay; + return ((Math.Pow(x, 2) / 41048480) - 15) / TimeSpan.SecondsPerDay; } private static double EphemerisCorrection1988to2019(int gregorianYear) { Debug.Assert(1988 <= gregorianYear && gregorianYear <= 2019); - return (double)(gregorianYear - 1933) / SecondsPerDay; + return (double)(gregorianYear - 1933) / TimeSpan.SecondsPerDay; } private static double EphemerisCorrection1900to1987(int gregorianYear) @@ -175,14 +174,14 @@ private static double EphemerisCorrection1700to1799(int gregorianYear) { Debug.Assert(1700 <= gregorianYear && gregorianYear <= 1799); double yearsSince1700 = gregorianYear - 1700; - return PolynomialSum(Coefficients1700to1799, yearsSince1700) / SecondsPerDay; + return PolynomialSum(Coefficients1700to1799, yearsSince1700) / TimeSpan.SecondsPerDay; } private static double EphemerisCorrection1620to1699(int gregorianYear) { Debug.Assert(1620 <= gregorianYear && gregorianYear <= 1699); double yearsSince1600 = gregorianYear - 1600; - return PolynomialSum(Coefficients1620to1699, yearsSince1600) / SecondsPerDay; + return PolynomialSum(Coefficients1620to1699, yearsSince1600) / TimeSpan.SecondsPerDay; } // ephemeris-correction: correction to account for the slowing down of the rotation of the earth diff --git a/src/libraries/System.Private.CoreLib/src/System/Globalization/DateTimeFormat.cs b/src/libraries/System.Private.CoreLib/src/System/Globalization/DateTimeFormat.cs index 5192820e1a4d5..27901d8744813 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Globalization/DateTimeFormat.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Globalization/DateTimeFormat.cs @@ -484,7 +484,7 @@ private static void FormatCustomized( tokenLen = ParseRepeatPattern(format, i, ch); if (tokenLen <= MaxSecondsFractionDigits) { - int fraction = (int)(dateTime.Ticks % Calendar.TicksPerSecond); + int fraction = (int)(dateTime.Ticks % TimeSpan.TicksPerSecond); fraction /= TimeSpanParse.Pow10UpToMaxFractionDigits(MaxSecondsFractionDigits - tokenLen); if (ch == 'f') { @@ -792,7 +792,7 @@ private static unsafe void FormatCustomizedTimeZone(DateTime dateTime, Ti { // No offset. The instance is a DateTime and the output should be the local time zone - if (timeOnly && dateTime.Ticks < Calendar.TicksPerDay) + if (timeOnly && dateTime.Ticks < TimeSpan.TicksPerDay) { // For time only format and a time only input, the time offset on 0001/01/01 is less // accurate than the system's current offset because of daylight saving time. @@ -1144,7 +1144,7 @@ private static bool IsTimeOnlySpecialCase(DateTime dateTime, DateTimeFormatInfo // Gregorian year 0001, an exception will be thrown when we try to get the Japanese year for // Gregorian year 0001. Therefore, the workaround allows them to call ToString() for time of // day from a DateTime by formatting as ISO 8601 format. - dateTime.Ticks < Calendar.TicksPerDay && + dateTime.Ticks < TimeSpan.TicksPerDay && dtfi.Calendar.ID is CalendarId.JAPAN or CalendarId.TAIWAN or diff --git a/src/libraries/System.Private.CoreLib/src/System/Globalization/DateTimeParse.cs b/src/libraries/System.Private.CoreLib/src/System/Globalization/DateTimeParse.cs index 9613bddf43549..ce0d92fdcc099 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Globalization/DateTimeParse.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Globalization/DateTimeParse.cs @@ -2710,7 +2710,7 @@ internal static bool TryParse(ReadOnlySpan s, DateTimeFormatInfo dtfi, Dat if (raw.fraction > 0) { - if (!time.TryAddTicks((long)Math.Round(raw.fraction * Calendar.TicksPerSecond), out time)) + if (!time.TryAddTicks((long)Math.Round(raw.fraction * TimeSpan.TicksPerSecond), out time)) { result.SetBadDateTimeFailure(); TPTraceExit("0100 (time.TryAddTicks)", dps); @@ -2897,7 +2897,7 @@ private static bool AdjustTimeZoneToUniversal(ref DateTimeResult result) resultTicks -= result.timeZoneOffset.Ticks; if (resultTicks < 0) { - resultTicks += Calendar.TicksPerDay; + resultTicks += TimeSpan.TicksPerDay; } if (resultTicks < DateTime.MinTicks || resultTicks > DateTime.MaxTicks) @@ -2922,7 +2922,7 @@ private static bool AdjustTimeZoneToLocal(ref DateTimeResult result, bool bTimeO // Convert to local ticks TimeZoneInfo tz = TimeZoneInfo.Local; bool isAmbiguousLocalDst = false; - if (resultTicks < Calendar.TicksPerDay) + if (resultTicks < TimeSpan.TicksPerDay) { // // This is time of day. @@ -2935,7 +2935,7 @@ private static bool AdjustTimeZoneToLocal(ref DateTimeResult result, bool bTimeO if (resultTicks < 0) { - resultTicks += Calendar.TicksPerDay; + resultTicks += TimeSpan.TicksPerDay; } } else @@ -3071,7 +3071,7 @@ private static bool ParseISO8601(scoped ref DateTimeRawInfo raw, ref __DTString return false; } - if (!time.TryAddTicks((long)Math.Round(partSecond * Calendar.TicksPerSecond), out time)) + if (!time.TryAddTicks((long)Math.Round(partSecond * TimeSpan.TicksPerSecond), out time)) { result.SetBadDateTimeFailure(); return false; @@ -4739,7 +4739,7 @@ private static bool DoStrictParse( } if (result.fraction > 0) { - if (!result.parsedDate.TryAddTicks((long)Math.Round(result.fraction * Calendar.TicksPerSecond), out result.parsedDate)) + if (!result.parsedDate.TryAddTicks((long)Math.Round(result.fraction * TimeSpan.TicksPerSecond), out result.parsedDate)) { result.SetBadDateTimeFailure(); return false; @@ -5084,7 +5084,7 @@ private static bool TryParseFormatO(ReadOnlySpan source, scoped ref DateTi return false; } - if (!dateTime.TryAddTicks((long)Math.Round(fraction * Calendar.TicksPerSecond), out result.parsedDate)) + if (!dateTime.TryAddTicks((long)Math.Round(fraction * TimeSpan.TicksPerSecond), out result.parsedDate)) { result.SetBadDateTimeFailure(); return false; diff --git a/src/libraries/System.Private.CoreLib/src/System/Globalization/GregorianCalendar.cs b/src/libraries/System.Private.CoreLib/src/System/Globalization/GregorianCalendar.cs index ee5919bae506b..04baa4944bc73 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Globalization/GregorianCalendar.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Globalization/GregorianCalendar.cs @@ -113,7 +113,7 @@ internal static long GetAbsoluteDate(int year, int month, int day) /// private static long DateToTicks(int year, int month, int day) { - return GetAbsoluteDate(year, month, day) * TicksPerDay; + return GetAbsoluteDate(year, month, day) * TimeSpan.TicksPerDay; } /// @@ -164,7 +164,7 @@ public override DateTime AddMonths(DateTime time, int months) { d = days; } - long ticks = DateToTicks(y, m, d) + time.Ticks % TicksPerDay; + long ticks = DateToTicks(y, m, d) + time.Ticks % TimeSpan.TicksPerDay; CheckAddResult(ticks, MinSupportedDateTime, MaxSupportedDateTime); return new DateTime(ticks); diff --git a/src/libraries/System.Private.CoreLib/src/System/Globalization/HebrewCalendar.cs b/src/libraries/System.Private.CoreLib/src/System/Globalization/HebrewCalendar.cs index 15fab14712d03..53dde1baa37df 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Globalization/HebrewCalendar.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Globalization/HebrewCalendar.cs @@ -566,7 +566,7 @@ public override DateTime AddMonths(DateTime time, int months) d = days; } - return new DateTime(ToDateTime(y, i, d, 0, 0, 0, 0).Ticks + (time.Ticks % TicksPerDay)); + return new DateTime(ToDateTime(y, i, d, 0, 0, 0, 0).Ticks + (time.Ticks % TimeSpan.TicksPerDay)); } // We expect ArgumentException and ArgumentOutOfRangeException (which is subclass of ArgumentException) // If exception is thrown in the calls above, we are out of the supported range of this calendar. @@ -597,7 +597,7 @@ public override DateTime AddYears(DateTime time, int years) d = days; } - long ticks = ToDateTime(y, m, d, 0, 0, 0, 0).Ticks + (time.Ticks % TicksPerDay); + long ticks = ToDateTime(y, m, d, 0, 0, 0, 0).Ticks + (time.Ticks % TimeSpan.TicksPerDay); CheckAddResult(ticks, MinSupportedDateTime, MaxSupportedDateTime); return new DateTime(ticks); } @@ -647,7 +647,7 @@ public override int GetDayOfYear(DateTime time) beginOfYearDate = ToDateTime(year, 1, 1, 0, 0, 0, 0, CurrentEra); } - return (int)((time.Ticks - beginOfYearDate.Ticks) / TicksPerDay) + 1; + return (int)((time.Ticks - beginOfYearDate.Ticks) / TimeSpan.TicksPerDay) + 1; } public override int GetDaysInMonth(int year, int month, int era) @@ -825,7 +825,7 @@ private static DateTime HebrewToGregorian(int hebrewYear, int hebrewMonth, int h int days = GetDayDifference(lunarYearType, hebrewMonth, hebrewDay, hebrewDateOfJan1.month, hebrewDateOfJan1.day); DateTime gregorianNewYear = new DateTime(gregorianYear, 1, 1); - return new DateTime(gregorianNewYear.Ticks + days * TicksPerDay + TimeToTicks(hour, minute, second, millisecond)); + return new DateTime(gregorianNewYear.Ticks + days * TimeSpan.TicksPerDay + TimeToTicks(hour, minute, second, millisecond)); } public override DateTime ToDateTime(int year, int month, int day, int hour, int minute, int second, int millisecond, int era) diff --git a/src/libraries/System.Private.CoreLib/src/System/Globalization/HijriCalendar.cs b/src/libraries/System.Private.CoreLib/src/System/Globalization/HijriCalendar.cs index 3ac1cb75ad306..6f8b39be18dc2 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Globalization/HijriCalendar.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Globalization/HijriCalendar.cs @@ -198,7 +198,7 @@ internal virtual int GetDatePart(long ticks, int part) // Get the absolute date. The absolute date is the number of days from January 1st, 1 A.D. // 1/1/0001 is absolute date 1. - long numDays = ticks / TicksPerDay + 1; + long numDays = ticks / TimeSpan.TicksPerDay + 1; // See how much we need to backup or advance numDays += HijriAdjustment; @@ -296,7 +296,7 @@ public override DateTime AddMonths(DateTime time, int months) d = days; } - long ticks = GetAbsoluteDateHijri(y, m, d) * TicksPerDay + (time.Ticks % TicksPerDay); + long ticks = GetAbsoluteDateHijri(y, m, d) * TimeSpan.TicksPerDay + (time.Ticks % TimeSpan.TicksPerDay); CheckAddResult(ticks, MinSupportedDateTime, MaxSupportedDateTime); return new DateTime(ticks); } @@ -413,7 +413,7 @@ public override DateTime ToDateTime(int year, int month, int day, int hour, int throw new ArgumentOutOfRangeException(null, SR.ArgumentOutOfRange_BadYearMonthDay); } - return new DateTime(lDate * TicksPerDay + TimeToTicks(hour, minute, second, millisecond)); + return new DateTime(lDate * TimeSpan.TicksPerDay + TimeToTicks(hour, minute, second, millisecond)); } private const int DefaultTwoDigitYearMax = 1451; diff --git a/src/libraries/System.Private.CoreLib/src/System/Globalization/JulianCalendar.cs b/src/libraries/System.Private.CoreLib/src/System/Globalization/JulianCalendar.cs index 8a86fc14e1c7e..0d14372214b78 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Globalization/JulianCalendar.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Globalization/JulianCalendar.cs @@ -115,9 +115,9 @@ internal static int GetDatePart(long ticks, int part) { // Gregorian 1/1/0001 is Julian 1/3/0001. Remember DateTime(0) is referred to Gregorian 1/1/0001. // The following line convert Gregorian ticks to Julian ticks. - long julianTicks = ticks + TicksPerDay * 2; + long julianTicks = ticks + TimeSpan.TicksPerDay * 2; // n = number of days since 1/1/0001 - int n = (int)(julianTicks / TicksPerDay); + int n = (int)(julianTicks / TimeSpan.TicksPerDay); // y4 = number of whole 4-year periods within 100-year period int y4 = n / JulianDaysPer4Years; // n = day number within 4-year period @@ -174,7 +174,7 @@ internal static long DateToTicks(int year, int month, int day) // Gregorian 1/1/0001 is Julian 1/3/0001. n * TicksPerDay is the ticks in JulianCalendar. // Therefore, we subtract two days in the following to convert the ticks in JulianCalendar // to ticks in Gregorian calendar. - return (n - 2) * TicksPerDay; + return (n - 2) * TimeSpan.TicksPerDay; } public override DateTime AddMonths(DateTime time, int months) @@ -209,7 +209,7 @@ public override DateTime AddMonths(DateTime time, int months) d = days; } - long ticks = DateToTicks(y, m, d) + time.Ticks % TicksPerDay; + long ticks = DateToTicks(y, m, d) + time.Ticks % TimeSpan.TicksPerDay; CheckAddResult(ticks, MinSupportedDateTime, MaxSupportedDateTime); return new DateTime(ticks); } @@ -303,12 +303,12 @@ public override DateTime ToDateTime(int year, int month, int day, int hour, int CheckYearEraRange(year, era); CheckMonthRange(month); CheckDayRange(year, month, day); - if (millisecond < 0 || millisecond >= MillisPerSecond) + if (millisecond < 0 || millisecond >= TimeSpan.MillisecondsPerSecond) { throw new ArgumentOutOfRangeException( nameof(millisecond), millisecond, - SR.Format(SR.ArgumentOutOfRange_Range, 0, MillisPerSecond - 1)); + SR.Format(SR.ArgumentOutOfRange_Range, 0, TimeSpan.MillisecondsPerSecond - 1)); } if (hour < 0 || hour >= 24 || minute < 0 || minute >= 60 || second < 0 || second >= 60) diff --git a/src/libraries/System.Private.CoreLib/src/System/Globalization/PersianCalendar.cs b/src/libraries/System.Private.CoreLib/src/System/Globalization/PersianCalendar.cs index d61caee9faecd..89b0e6a4c8091 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Globalization/PersianCalendar.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Globalization/PersianCalendar.cs @@ -21,7 +21,7 @@ public class PersianCalendar : Calendar { public static readonly int PersianEra = 1; - private static readonly long s_persianEpoch = new DateTime(622, 3, 22).Ticks / TicksPerDay; + private static readonly long s_persianEpoch = new DateTime(622, 3, 22).Ticks / TimeSpan.TicksPerDay; private const int ApproximateHalfYear = 180; private const int DatePartYear = 0; @@ -147,7 +147,7 @@ internal int GetDatePart(long ticks, int part) // Get the absolute date. The absolute date is the number of days from January 1st, 1 A.D. // 1/1/0001 is absolute date 1. - long numDays = ticks / TicksPerDay + 1; + long numDays = ticks / TimeSpan.TicksPerDay + 1; // Calculate the appromixate Persian Year. long yearStart = CalendricalCalculationsHelper.PersianNewYearOnOrBefore(numDays); @@ -197,7 +197,7 @@ internal void GetDate(long ticks, out int year, out int month, out int day) // Get the absolute date. The absolute date is the number of days from January 1st, 1 A.D. // 1/1/0001 is absolute date 1. - long numDays = ticks / TicksPerDay + 1; + long numDays = ticks / TimeSpan.TicksPerDay + 1; // Calculate the appromixate Persian Year. long yearStart = CalendricalCalculationsHelper.PersianNewYearOnOrBefore(numDays); @@ -245,7 +245,7 @@ public override DateTime AddMonths(DateTime time, int months) d = days; } - long ticks = GetAbsoluteDatePersian(y, m, d) * TicksPerDay + time.Ticks % TicksPerDay; + long ticks = GetAbsoluteDatePersian(y, m, d) * TimeSpan.TicksPerDay + time.Ticks % TimeSpan.TicksPerDay; CheckAddResult(ticks, MinSupportedDateTime, MaxSupportedDateTime); return new DateTime(ticks); } @@ -384,7 +384,7 @@ public override DateTime ToDateTime(int year, int month, int day, int hour, int throw new ArgumentOutOfRangeException(null, SR.ArgumentOutOfRange_BadYearMonthDay); } - return new DateTime(lDate * TicksPerDay + TimeToTicks(hour, minute, second, millisecond)); + return new DateTime(lDate * TimeSpan.TicksPerDay + TimeToTicks(hour, minute, second, millisecond)); } private const int DefaultTwoDigitYearMax = 1410; diff --git a/src/libraries/System.Private.CoreLib/src/System/Globalization/UmAlQuraCalendar.cs b/src/libraries/System.Private.CoreLib/src/System/Globalization/UmAlQuraCalendar.cs index 5b2c08d093eff..c90fd203c211b 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Globalization/UmAlQuraCalendar.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Globalization/UmAlQuraCalendar.cs @@ -341,7 +341,7 @@ private static void ConvertGregorianToHijri(DateTime time, out int HijriYear, ou // Find the index where we should start our search by quessing the Hijri year that we will be in HijriYearInfo. // A Hijri year is 354 or 355 days. Use 355 days so that we will search from a lower index. - int index = (int)((time.Ticks - s_minDate.Ticks) / TicksPerDay) / 355; + int index = (int)((time.Ticks - s_minDate.Ticks) / TimeSpan.TicksPerDay) / 355; do { } while (time.CompareTo(s_hijriYearInfo[++index].GregorianDate) > 0); // while greater @@ -444,7 +444,7 @@ public override DateTime AddMonths(DateTime time, int months) } CheckYearRange(y, UmAlQuraEra); - DateTime dt = new DateTime(GetAbsoluteDateUmAlQura(y, m, d) * TicksPerDay + time.Ticks % TicksPerDay); + DateTime dt = new DateTime(GetAbsoluteDateUmAlQura(y, m, d) * TimeSpan.TicksPerDay + time.Ticks % TimeSpan.TicksPerDay); CheckAddResult(dt.Ticks, MinSupportedDateTime, MaxSupportedDateTime); return dt; } @@ -591,7 +591,7 @@ public override DateTime ToDateTime(int year, int month, int day, int hour, int throw new ArgumentOutOfRangeException(null, SR.ArgumentOutOfRange_BadYearMonthDay); } - return new DateTime(lDate * TicksPerDay + TimeToTicks(hour, minute, second, millisecond)); + return new DateTime(lDate * TimeSpan.TicksPerDay + TimeToTicks(hour, minute, second, millisecond)); } private const int DefaultTwoDigitYearMax = 1451; diff --git a/src/libraries/System.Private.CoreLib/src/System/IO/FileStatus.Unix.cs b/src/libraries/System.Private.CoreLib/src/System/IO/FileStatus.Unix.cs index a7b9da7e9197d..4ffd7cd8cd811 100644 --- a/src/libraries/System.Private.CoreLib/src/System/IO/FileStatus.Unix.cs +++ b/src/libraries/System.Private.CoreLib/src/System/IO/FileStatus.Unix.cs @@ -582,9 +582,7 @@ private void ThrowOnCacheInitializationError(ReadOnlySpan path) private static long UnixTimeSecondsToNanoseconds(DateTimeOffset time, long seconds) { - const long TicksPerMillisecond = 10000; - const long TicksPerSecond = TicksPerMillisecond * 1000; - return (time.UtcDateTime.Ticks - DateTimeOffset.UnixEpoch.Ticks - seconds * TicksPerSecond) * NanosecondsPerTick; + return (time.UtcDateTime.Ticks - DateTimeOffset.UnixEpoch.Ticks - seconds * TimeSpan.TicksPerSecond) * NanosecondsPerTick; } private void ThrowNotFound(string? path) diff --git a/src/libraries/System.Private.CoreLib/src/System/TimeSpan.cs b/src/libraries/System.Private.CoreLib/src/System/TimeSpan.cs index 98d6b9523f229..7ffc13bb107bb 100644 --- a/src/libraries/System.Private.CoreLib/src/System/TimeSpan.cs +++ b/src/libraries/System.Private.CoreLib/src/System/TimeSpan.cs @@ -62,25 +62,25 @@ public readonly struct TimeSpan public const long TicksPerHour = TicksPerMinute * 60; // 36,000,000,000 public const long TicksPerDay = TicksPerHour * 24; // 864,000,000,000 - internal const long MicrosecondsPerMillisecond = TicksPerMillisecond / TicksPerMicrosecond; // 1,000 - internal const long MicrosecondsPerSecond = TicksPerSecond / TicksPerMicrosecond; // 1,000,000 - internal const long MicrosecondsPerMinute = TicksPerMinute / TicksPerMicrosecond; // 60,000,000 - internal const long MicrosecondsPerHour = TicksPerHour / TicksPerMicrosecond; // 3,600,000,000 - internal const long MicrosecondsPerDay = TicksPerDay / TicksPerMicrosecond; // 86,400,000,000 + public const long MicrosecondsPerMillisecond = TicksPerMillisecond / TicksPerMicrosecond; // 1,000 + public const long MicrosecondsPerSecond = TicksPerSecond / TicksPerMicrosecond; // 1,000,000 + public const long MicrosecondsPerMinute = TicksPerMinute / TicksPerMicrosecond; // 60,000,000 + public const long MicrosecondsPerHour = TicksPerHour / TicksPerMicrosecond; // 3,600,000,000 + public const long MicrosecondsPerDay = TicksPerDay / TicksPerMicrosecond; // 86,400,000,000 - internal const long MillisecondsPerSecond = TicksPerSecond / TicksPerMillisecond; // 1,000 - internal const long MillisecondsPerMinute = TicksPerMinute / TicksPerMillisecond; // 60,000 - internal const long MillisecondsPerHour = TicksPerHour / TicksPerMillisecond; // 3,600,000 - internal const long MillisecondsPerDay = TicksPerDay / TicksPerMillisecond; // 86,400,000 + public const long MillisecondsPerSecond = TicksPerSecond / TicksPerMillisecond; // 1,000 + public const long MillisecondsPerMinute = TicksPerMinute / TicksPerMillisecond; // 60,000 + public const long MillisecondsPerHour = TicksPerHour / TicksPerMillisecond; // 3,600,000 + public const long MillisecondsPerDay = TicksPerDay / TicksPerMillisecond; // 86,400,000 - internal const long SecondsPerMinute = TicksPerMinute / TicksPerSecond; // 60 - internal const long SecondsPerHour = TicksPerHour / TicksPerSecond; // 3,600 - internal const long SecondsPerDay = TicksPerDay / TicksPerSecond; // 86,400 + public const long SecondsPerMinute = TicksPerMinute / TicksPerSecond; // 60 + public const long SecondsPerHour = TicksPerHour / TicksPerSecond; // 3,600 + public const long SecondsPerDay = TicksPerDay / TicksPerSecond; // 86,400 - internal const long MinutesPerHour = TicksPerHour / TicksPerMinute; // 60 - internal const long MinutesPerDay = TicksPerDay / TicksPerMinute; // 1,440 + public const long MinutesPerHour = TicksPerHour / TicksPerMinute; // 60 + public const long MinutesPerDay = TicksPerDay / TicksPerMinute; // 1,440 - internal const long HoursPerDay = TicksPerDay / TicksPerHour; // 24 + public const long HoursPerDay = TicksPerDay / TicksPerHour; // 24 internal const long MinTicks = long.MinValue; // -9,223,372,036,854,775,808 internal const long MaxTicks = long.MaxValue; // +9,223,372,036,854,775,807 diff --git a/src/libraries/System.Private.DataContractSerialization/src/System/Xml/XmlConverter.cs b/src/libraries/System.Private.DataContractSerialization/src/System/Xml/XmlConverter.cs index c8a1dc03515db..66039997b1570 100644 --- a/src/libraries/System.Private.DataContractSerialization/src/System/Xml/XmlConverter.cs +++ b/src/libraries/System.Private.DataContractSerialization/src/System/Xml/XmlConverter.cs @@ -1038,8 +1038,6 @@ private static int ToCharsD7(int value, byte[] chars, int offset) public static int ToChars(DateTime value, byte[] chars, int offset) { - const long TicksPerMillisecond = 10000; - const long TicksPerSecond = TicksPerMillisecond * 1000; int offsetMin = offset; // "yyyy-MM-ddTHH:mm:ss.fffffff"; offset += ToCharsD4(value.Year, chars, offset); @@ -1053,7 +1051,7 @@ public static int ToChars(DateTime value, byte[] chars, int offset) offset += ToCharsD2(value.Minute, chars, offset); chars[offset++] = (byte)':'; offset += ToCharsD2(value.Second, chars, offset); - int ms = (int)(value.Ticks % TicksPerSecond); + int ms = (int)(value.Ticks % TimeSpan.TicksPerSecond); if (ms != 0) { chars[offset++] = (byte)'.'; diff --git a/src/libraries/System.Private.Xml/src/System/Xml/Schema/XsdDateTime.cs b/src/libraries/System.Private.Xml/src/System/Xml/Schema/XsdDateTime.cs index 7e75cc55afada..c8c301cf32383 100644 --- a/src/libraries/System.Private.Xml/src/System/Xml/Schema/XsdDateTime.cs +++ b/src/libraries/System.Private.Xml/src/System/Xml/Schema/XsdDateTime.cs @@ -108,16 +108,6 @@ private enum XsdDateTimeKind private static readonly int s_Lz___ = "---".Length; private static readonly int s_lz___dd = "---dd".Length; - // These values were copied from the DateTime class and are - // needed to convert ticks to year, month and day. See comment - // for method GetYearMonthDay for rationale. - // Number of 100ns ticks per time unit - private const long TicksPerMillisecond = 10000; - private const long TicksPerSecond = TicksPerMillisecond * 1000; - private const long TicksPerMinute = TicksPerSecond * 60; - private const long TicksPerHour = TicksPerMinute * 60; - private const long TicksPerDay = TicksPerHour * 24; - // Number of days in a non-leap year private const int DaysPerYear = 365; // Number of days in 4 years @@ -575,7 +565,7 @@ private void GetYearMonthDay(out int year, out int month, out int day) { long ticks = _dt.Ticks; // n = number of days since 1/1/0001 - int n = (int)(ticks / TicksPerDay); + int n = (int)(ticks / TimeSpan.TicksPerDay); // y400 = number of whole 400-year periods since 1/1/0001 int y400 = n / DaysPer400Years; // n = day number within 400-year period diff --git a/src/libraries/System.Runtime/ref/System.Runtime.cs b/src/libraries/System.Runtime/ref/System.Runtime.cs index e779be152f6cf..5140a0c6c783c 100644 --- a/src/libraries/System.Runtime/ref/System.Runtime.cs +++ b/src/libraries/System.Runtime/ref/System.Runtime.cs @@ -5947,6 +5947,22 @@ protected TimeProvider() { } public const long TicksPerMillisecond = (long)10000; public const long TicksPerMinute = (long)600000000; public const long TicksPerSecond = (long)10000000; + public const long MicrosecondsPerMillisecond = (long)1000; + public const long MicrosecondsPerSecond = (long)1000000; + public const long MicrosecondsPerMinute = (long)60000000; + public const long MicrosecondsPerHour = (long)3600000000; + public const long MicrosecondsPerDay = (long)86400000000; + public const long MillisecondsPerSecond = (long)1000; + public const long MillisecondsPerMinute = (long)60000; + public const long MillisecondsPerHour = (long)3600000; + public const long MillisecondsPerDay = (long)86400000; + public const long SecondsPerMinute = (long)60; + public const long SecondsPerHour = (long)3600; + public const long SecondsPerDay = (long)86400; + public const long MinutesPerHour = (long)60; + public const long MinutesPerDay = (long)1440; + public const long HoursPerDay = (long)24; + public static readonly System.TimeSpan Zero; public TimeSpan(int hours, int minutes, int seconds) { throw null; } public TimeSpan(int days, int hours, int minutes, int seconds) { throw null; } From 6bb6ba9112db3dbff65675fa4b986839973608ac Mon Sep 17 00:00:00 2001 From: Marc Brooks Date: Fri, 14 Jun 2024 19:47:52 -0500 Subject: [PATCH 2/5] Added /// documentation for newly public constants --- .../src/System/TimeSpan.cs | 128 ++++++++++++++++++ 1 file changed, 128 insertions(+) diff --git a/src/libraries/System.Private.CoreLib/src/System/TimeSpan.cs b/src/libraries/System.Private.CoreLib/src/System/TimeSpan.cs index 7ffc13bb107bb..eb73f472b71cc 100644 --- a/src/libraries/System.Private.CoreLib/src/System/TimeSpan.cs +++ b/src/libraries/System.Private.CoreLib/src/System/TimeSpan.cs @@ -57,29 +57,157 @@ public readonly struct TimeSpan /// The value of this constant is 10 thousand; that is, 10,000. /// public const long TicksPerMillisecond = TicksPerMicrosecond * 1000; // 10,000 + + /// + /// Represents the number of ticks in 1 second. This field is constant. + /// + /// + /// The value of this constant is 10 million; that is, 10,000,000. + /// public const long TicksPerSecond = TicksPerMillisecond * 1000; // 10,000,000 + + /// + /// Represents the number of ticks in 1 minute. This field is constant. + /// + /// + /// The value of this constant is 600 million; that is, 600,000,000. + /// public const long TicksPerMinute = TicksPerSecond * 60; // 600,000,000 + + /// + /// Represents the number of ticks in 1 hour. This field is constant. + /// + /// + /// The value of this constant is 36 billion; that is, 36,000,000,000. + /// public const long TicksPerHour = TicksPerMinute * 60; // 36,000,000,000 + + /// + /// Represents the number of ticks in 1 day. This field is constant. + /// + /// + /// The value of this constant is 864 billion; that is, 864,000,000,000. + /// public const long TicksPerDay = TicksPerHour * 24; // 864,000,000,000 + /// + /// Represents the number of microseconds in 1 millisecond. This field is constant. + /// + /// + /// The value of this constant is 1 thousand; that is, 1,000. + /// public const long MicrosecondsPerMillisecond = TicksPerMillisecond / TicksPerMicrosecond; // 1,000 + + /// + /// Represents the number of microseconds in 1 second. This field is constant. + /// + /// + /// The value of this constant is 1 million; that is, 1,000,000. + /// public const long MicrosecondsPerSecond = TicksPerSecond / TicksPerMicrosecond; // 1,000,000 + + /// + /// Represents the number of microseconds in 1 minute. This field is constant. + /// + /// + /// The value of this constant is 60 million; that is, 60,000,000. + /// public const long MicrosecondsPerMinute = TicksPerMinute / TicksPerMicrosecond; // 60,000,000 + + /// + /// Represents the number of microseconds in 1 hour. This field is constant. + /// + /// + /// The value of this constant is 3.6 billion; that is, 3,600,000,000. + /// public const long MicrosecondsPerHour = TicksPerHour / TicksPerMicrosecond; // 3,600,000,000 + + /// + /// Represents the number of microseconds in 1 day. This field is constant. + /// + /// + /// The value of this constant is 86.4 billion; that is, 86,400,000,000. + /// public const long MicrosecondsPerDay = TicksPerDay / TicksPerMicrosecond; // 86,400,000,000 + /// + /// Represents the number of milliseconds in 1 second. This field is constant. + /// + /// + /// The value of this constant is 86.4 billion; that is, 86,400,000,000. + /// public const long MillisecondsPerSecond = TicksPerSecond / TicksPerMillisecond; // 1,000 + + /// + /// Represents the number of milliseconds in 1 minute. This field is constant. + /// + /// + /// The value of this constant is 60 thousand; that is, 60,000. + /// public const long MillisecondsPerMinute = TicksPerMinute / TicksPerMillisecond; // 60,000 + + /// + /// Represents the number of milliseconds in 1 hour. This field is constant. + /// + /// + /// The value of this constant is 3.6 million; that is, 3,600,000. + /// public const long MillisecondsPerHour = TicksPerHour / TicksPerMillisecond; // 3,600,000 + + /// + /// Represents the number of milliseconds in 1 day. This field is constant. + /// + /// + /// The value of this constant is 86.4 million; that is, 86,400,000. + /// public const long MillisecondsPerDay = TicksPerDay / TicksPerMillisecond; // 86,400,000 + /// + /// Represents the number of seconds in 1 minute. This field is constant. + /// + /// + /// The value of this constant is 60. + /// public const long SecondsPerMinute = TicksPerMinute / TicksPerSecond; // 60 + + /// + /// Represents the number of seconds in 1 hour. This field is constant. + /// + /// + /// The value of this constant is 3.6 thousand; that is, 3,600. + /// public const long SecondsPerHour = TicksPerHour / TicksPerSecond; // 3,600 + + /// + /// Represents the number of seconds in 1 day. This field is constant. + /// + /// + /// The value of this constant is 86.4 thousand; that is, 86,400. + /// public const long SecondsPerDay = TicksPerDay / TicksPerSecond; // 86,400 + /// + /// Represents the number of minutes in 1 hour. This field is constant. + /// + /// + /// The value of this constant is 60. + /// public const long MinutesPerHour = TicksPerHour / TicksPerMinute; // 60 + + /// + /// Represents the number of minutes in 1 day. This field is constant. + /// + /// + /// The value of this constant is 1440. + /// public const long MinutesPerDay = TicksPerDay / TicksPerMinute; // 1,440 + /// + /// Represents the number of hours in 1 day. This field is constant. + /// + /// + /// The value of this constant is 24. + /// public const long HoursPerDay = TicksPerDay / TicksPerHour; // 24 internal const long MinTicks = long.MinValue; // -9,223,372,036,854,775,808 From e20e1fe02eb14385baf91bd0610e0db2975f5aff Mon Sep 17 00:00:00 2001 From: Marc Brooks Date: Sun, 16 Jun 2024 19:20:28 -0500 Subject: [PATCH 3/5] Revert to internal constant Since this source is also built for older frameworks, leave the constant here. --- .../src/System/Diagnostics/EventLogInternal.cs | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/src/libraries/System.Diagnostics.EventLog/src/System/Diagnostics/EventLogInternal.cs b/src/libraries/System.Diagnostics.EventLog/src/System/Diagnostics/EventLogInternal.cs index 9b50d78ebc91f..f32c41f3041a9 100644 --- a/src/libraries/System.Diagnostics.EventLog/src/System/Diagnostics/EventLogInternal.cs +++ b/src/libraries/System.Diagnostics.EventLog/src/System/Diagnostics/EventLogInternal.cs @@ -55,6 +55,7 @@ internal sealed class EventLogInternal : IDisposable, ISupportInitialize private const string EventLogKey = "SYSTEM\\CurrentControlSet\\Services\\EventLog"; private const string eventLogMutexName = "netfxeventlog.1.0"; + private const int SecondsPerDay = 60 * 60 * 24; // can't pull in the new TimeSpan constant because this builds in older CLR versions private const int Flag_notifying = 0x1; // keeps track of whether we're notifying our listeners - to prevent double notifications private const int Flag_forwards = 0x2; // whether the cache contains entries in forwards order (true) or backwards (false) @@ -316,7 +317,7 @@ public int MinimumRetentionDays if (retention == 0 || retention == -1) return retention; else - return (int)(((double)retention) / TimeSpan.SecondsPerDay); + return (int)(((double)retention) / SecondsPerDay); } return 7; @@ -1029,7 +1030,7 @@ public void ModifyOverflowPolicy(OverflowAction action, int retentionDays) if (retentionDays < 1 || retentionDays > 365) throw new ArgumentOutOfRangeException(SR.RentionDaysOutOfRange); - retentionvalue = (long)retentionDays * TimeSpan.SecondsPerDay; + retentionvalue = (long)retentionDays * SecondsPerDay; } using (RegistryKey logkey = GetLogRegKey(currentMachineName, true)) From cb7004a36f7486defdd17903af0e5dfeb45a4b5a Mon Sep 17 00:00:00 2001 From: Marc Brooks Date: Mon, 17 Jun 2024 21:01:46 -0500 Subject: [PATCH 4/5] Fixed comment. --- src/libraries/System.Private.CoreLib/src/System/TimeSpan.cs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/libraries/System.Private.CoreLib/src/System/TimeSpan.cs b/src/libraries/System.Private.CoreLib/src/System/TimeSpan.cs index eb73f472b71cc..2d9ea4d127b8d 100644 --- a/src/libraries/System.Private.CoreLib/src/System/TimeSpan.cs +++ b/src/libraries/System.Private.CoreLib/src/System/TimeSpan.cs @@ -134,7 +134,7 @@ public readonly struct TimeSpan /// Represents the number of milliseconds in 1 second. This field is constant. /// /// - /// The value of this constant is 86.4 billion; that is, 86,400,000,000. + /// The value of this constant is 1 thousand; that is, 1,000. /// public const long MillisecondsPerSecond = TicksPerSecond / TicksPerMillisecond; // 1,000 From 8683434caf487adb2293c8ac58ecf74dbbac5d28 Mon Sep 17 00:00:00 2001 From: Marc Brooks Date: Tue, 18 Jun 2024 11:15:05 -0500 Subject: [PATCH 5/5] Revert Add to int argument Cast at call-site to prevent performance degradation. --- .../src/System/Globalization/Calendar.cs | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/libraries/System.Private.CoreLib/src/System/Globalization/Calendar.cs b/src/libraries/System.Private.CoreLib/src/System/Globalization/Calendar.cs index ed8aa88db428e..49eb9e8cec98e 100644 --- a/src/libraries/System.Private.CoreLib/src/System/Globalization/Calendar.cs +++ b/src/libraries/System.Private.CoreLib/src/System/Globalization/Calendar.cs @@ -127,7 +127,7 @@ internal static void CheckAddResult(long ticks, DateTime minValue, DateTime maxV } } - internal DateTime Add(DateTime time, double value, long scale) + internal DateTime Add(DateTime time, double value, int scale) { // From ECMA CLI spec, Partition III, section 3.27: // @@ -169,7 +169,7 @@ public virtual DateTime AddMilliseconds(DateTime time, double milliseconds) /// public virtual DateTime AddDays(DateTime time, int days) { - return Add(time, days, TimeSpan.MillisecondsPerDay); + return Add(time, days, (int)TimeSpan.MillisecondsPerDay); } /// @@ -181,7 +181,7 @@ public virtual DateTime AddDays(DateTime time, int days) /// public virtual DateTime AddHours(DateTime time, int hours) { - return Add(time, hours, TimeSpan.MillisecondsPerHour); + return Add(time, hours, (int)TimeSpan.MillisecondsPerHour); } /// @@ -193,7 +193,7 @@ public virtual DateTime AddHours(DateTime time, int hours) /// public virtual DateTime AddMinutes(DateTime time, int minutes) { - return Add(time, minutes, TimeSpan.MillisecondsPerMinute); + return Add(time, minutes, (int)TimeSpan.MillisecondsPerMinute); } /// @@ -225,7 +225,7 @@ public virtual DateTime AddMinutes(DateTime time, int minutes) /// public virtual DateTime AddSeconds(DateTime time, int seconds) { - return Add(time, seconds, TimeSpan.MillisecondsPerSecond); + return Add(time, seconds, (int)TimeSpan.MillisecondsPerSecond); } // Returns the DateTime resulting from adding a number of