summaryrefslogtreecommitdiffstats
path: root/js/src/jsdate.cpp
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-12 05:35:29 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-06-12 05:35:29 +0000
commit59203c63bb777a3bacec32fb8830fba33540e809 (patch)
tree58298e711c0ff0575818c30485b44a2f21bf28a0 /js/src/jsdate.cpp
parentAdding upstream version 126.0.1. (diff)
downloadfirefox-59203c63bb777a3bacec32fb8830fba33540e809.tar.xz
firefox-59203c63bb777a3bacec32fb8830fba33540e809.zip
Adding upstream version 127.0.upstream/127.0
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to 'js/src/jsdate.cpp')
-rw-r--r--js/src/jsdate.cpp28
1 files changed, 11 insertions, 17 deletions
diff --git a/js/src/jsdate.cpp b/js/src/jsdate.cpp
index a6f8b42040..685886d1b0 100644
--- a/js/src/jsdate.cpp
+++ b/js/src/jsdate.cpp
@@ -1060,7 +1060,11 @@ done:
#undef NEED_NDIGITS
}
-int FixupNonFullYear(int year) {
+/**
+ * Non-ISO years < 100 get fixed up, to allow 2-digit year formats.
+ * year < 50 becomes 2000-2049, 50-99 becomes 1950-1999.
+ */
+int FixupYear(int year) {
if (year < 50) {
year += 2000;
} else if (year >= 50 && year < 100) {
@@ -1203,9 +1207,7 @@ static bool TryParseDashedDatePrefix(const CharT* s, size_t length,
return false;
}
- if (yearDigits < 4) {
- year = FixupNonFullYear(year);
- }
+ year = FixupYear(year);
*indexOut = i;
*yearOut = year;
@@ -1295,9 +1297,7 @@ static bool TryParseDashedNumericDatePrefix(const CharT* s, size_t length,
return false;
}
- if (year < 100) {
- year = FixupNonFullYear(year);
- }
+ year = FixupYear(year);
*indexOut = i;
*yearOut = year;
@@ -1750,7 +1750,7 @@ static bool ParseDate(DateTimeInfo::ForceUTC forceUTC, const CharT* s,
// (again, for Chrome parity)
year = 2001;
} else {
- year = FixupNonFullYear(mon);
+ year = FixupYear(mon);
mon = 1;
}
}
@@ -1810,13 +1810,7 @@ static bool ParseDate(DateTimeInfo::ForceUTC forceUTC, const CharT* s,
}
}
- // If the year is greater than or equal to 50 and less than 100, it is
- // considered to be the number of years after 1900. If the year is less
- // than 50 it is considered to be the number of years after 2000,
- // otherwise it is considered to be the number of years after 0.
- if (!seenFullYear) {
- year = FixupNonFullYear(year);
- }
+ year = FixupYear(year);
if (negativeYear) {
year = -year;
@@ -3669,8 +3663,8 @@ static bool ToDateString(JSContext* cx, const CallArgs& args, ClippedTime t) {
if (!locale) {
return false;
}
- return FormatDate(cx, ForceUTC(cx->realm()), locale,
- t.toDouble(), FormatSpec::DateTime, args.rval());
+ return FormatDate(cx, ForceUTC(cx->realm()), locale, t.toDouble(),
+ FormatSpec::DateTime, args.rval());
}
static bool DateNoArguments(JSContext* cx, const CallArgs& args) {