PlainTime.cpp 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135
  1. /*
  2. * Copyright (c) 2021, Idan Horowitz <idan.horowitz@serenityos.org>
  3. * Copyright (c) 2021-2023, Linus Groh <linusg@serenityos.org>
  4. * Copyright (c) 2024, Tim Flynn <trflynn89@ladybird.org>
  5. *
  6. * SPDX-License-Identifier: BSD-2-Clause
  7. */
  8. #include <AK/Assertions.h>
  9. #include <LibJS/Runtime/AbstractOperations.h>
  10. #include <LibJS/Runtime/Temporal/PlainTime.h>
  11. #include <math.h>
  12. namespace JS::Temporal {
  13. // 4.5.2 CreateTimeRecord ( hour, minute, second, millisecond, microsecond, nanosecond [ , deltaDays ] ), https://tc39.es/proposal-temporal/#sec-temporal-createtimerecord
  14. Time create_time_record(double hour, double minute, double second, double millisecond, double microsecond, double nanosecond, double delta_days)
  15. {
  16. // 1. If deltaDays is not present, set deltaDays to 0.
  17. // 2. Assert: IsValidTime(hour, minute, second, millisecond, microsecond, nanosecond).
  18. VERIFY(is_valid_time(hour, minute, second, millisecond, microsecond, nanosecond));
  19. // 3. Return Time Record { [[Days]]: deltaDays, [[Hour]]: hour, [[Minute]]: minute, [[Second]]: second, [[Millisecond]]: millisecond, [[Microsecond]]: microsecond, [[Nanosecond]]: nanosecond }.
  20. return {
  21. .days = delta_days,
  22. .hour = static_cast<u8>(hour),
  23. .minute = static_cast<u8>(minute),
  24. .second = static_cast<u8>(second),
  25. .millisecond = static_cast<u16>(millisecond),
  26. .microsecond = static_cast<u16>(microsecond),
  27. .nanosecond = static_cast<u16>(nanosecond),
  28. };
  29. }
  30. // 4.5.3 MidnightTimeRecord ( ), https://tc39.es/proposal-temporal/#sec-temporal-midnighttimerecord
  31. Time midnight_time_record()
  32. {
  33. // 1. Return Time Record { [[Days]]: 0, [[Hour]]: 0, [[Minute]]: 0, [[Second]]: 0, [[Millisecond]]: 0, [[Microsecond]]: 0, [[Nanosecond]]: 0 }.
  34. return { .days = 0, .hour = 0, .minute = 0, .second = 0, .millisecond = 0, .microsecond = 0, .nanosecond = 0 };
  35. }
  36. // 4.5.4 NoonTimeRecord ( ), https://tc39.es/proposal-temporal/#sec-temporal-noontimerecord
  37. Time noon_time_record()
  38. {
  39. // 1. Return Time Record { [[Days]]: 0, [[Hour]]: 12, [[Minute]]: 0, [[Second]]: 0, [[Millisecond]]: 0, [[Microsecond]]: 0, [[Nanosecond]]: 0 }.
  40. return { .days = 0, .hour = 12, .minute = 0, .second = 0, .millisecond = 0, .microsecond = 0, .nanosecond = 0 };
  41. }
  42. // 4.5.9 IsValidTime ( hour, minute, second, millisecond, microsecond, nanosecond ), https://tc39.es/proposal-temporal/#sec-temporal-isvalidtime
  43. bool is_valid_time(double hour, double minute, double second, double millisecond, double microsecond, double nanosecond)
  44. {
  45. // 1. If hour < 0 or hour > 23, then
  46. if (hour < 0 || hour > 23) {
  47. // a. Return false.
  48. return false;
  49. }
  50. // 2. If minute < 0 or minute > 59, then
  51. if (minute < 0 || minute > 59) {
  52. // a. Return false.
  53. return false;
  54. }
  55. // 3. If second < 0 or second > 59, then
  56. if (second < 0 || second > 59) {
  57. // a. Return false.
  58. return false;
  59. }
  60. // 4. If millisecond < 0 or millisecond > 999, then
  61. if (millisecond < 0 || millisecond > 999) {
  62. // a. Return false.
  63. return false;
  64. }
  65. // 5. If microsecond < 0 or microsecond > 999, then
  66. if (microsecond < 0 || microsecond > 999) {
  67. // a. Return false.
  68. return false;
  69. }
  70. // 6. If nanosecond < 0 or nanosecond > 999, then
  71. if (nanosecond < 0 || nanosecond > 999) {
  72. // a. Return false.
  73. return false;
  74. }
  75. // 7. Return true.
  76. return true;
  77. }
  78. // 4.5.10 BalanceTime ( hour, minute, second, millisecond, microsecond, nanosecond ), https://tc39.es/proposal-temporal/#sec-temporal-balancetime
  79. Time balance_time(double hour, double minute, double second, double millisecond, double microsecond, double nanosecond)
  80. {
  81. // 1. Set microsecond to microsecond + floor(nanosecond / 1000).
  82. microsecond += floor(nanosecond / 1000.0);
  83. // 2. Set nanosecond to nanosecond modulo 1000.
  84. nanosecond = modulo(nanosecond, 1000.0);
  85. // 3. Set millisecond to millisecond + floor(microsecond / 1000).
  86. millisecond += floor(microsecond / 1000.0);
  87. // 4. Set microsecond to microsecond modulo 1000.
  88. microsecond = modulo(microsecond, 1000.0);
  89. // 5. Set second to second + floor(millisecond / 1000).
  90. second += floor(millisecond / 1000.0);
  91. // 6. Set millisecond to millisecond modulo 1000.
  92. millisecond = modulo(millisecond, 1000.0);
  93. // 7. Set minute to minute + floor(second / 60).
  94. minute += floor(second / 60.0);
  95. // 8. Set second to second modulo 60.
  96. second = modulo(second, 60.0);
  97. // 9. Set hour to hour + floor(minute / 60).
  98. hour += floor(minute / 60.0);
  99. // 10. Set minute to minute modulo 60.
  100. minute = modulo(minute, 60.0);
  101. // 11. Let deltaDays be floor(hour / 24).
  102. auto delta_days = floor(hour / 24.0);
  103. // 12. Set hour to hour modulo 24.
  104. hour = modulo(hour, 24.0);
  105. // 13. Return CreateTimeRecord(hour, minute, second, millisecond, microsecond, nanosecond, deltaDays).
  106. return create_time_record(hour, minute, second, millisecond, microsecond, nanosecond, delta_days);
  107. }
  108. }