diff options
author | Linus Groh <mail@linusgroh.de> | 2021-09-16 17:58:24 +0100 |
---|---|---|
committer | Linus Groh <mail@linusgroh.de> | 2021-09-16 22:34:24 +0100 |
commit | 14f16d9ed445fe22472e9c5313b75b3de9a8ac79 (patch) | |
tree | 96381cbbcf5c519fc50ddd95e9d83cf41f19942c /Userland/Libraries/LibJS | |
parent | 0ccd11ba5f292a62eb8eb41a510207cc1da75a56 (diff) | |
download | serenity-14f16d9ed445fe22472e9c5313b75b3de9a8ac79.zip |
LibJS: Convert parse_temporal_time_zone_string() to ThrowCompletionOr
Diffstat (limited to 'Userland/Libraries/LibJS')
3 files changed, 11 insertions, 20 deletions
diff --git a/Userland/Libraries/LibJS/Runtime/Temporal/AbstractOperations.cpp b/Userland/Libraries/LibJS/Runtime/Temporal/AbstractOperations.cpp index 59e0a90e7c..c9e414c649 100644 --- a/Userland/Libraries/LibJS/Runtime/Temporal/AbstractOperations.cpp +++ b/Userland/Libraries/LibJS/Runtime/Temporal/AbstractOperations.cpp @@ -798,8 +798,6 @@ ThrowCompletionOr<ISODateTime> parse_iso_date_time(GlobalObject& global_object, // 13.35 ParseTemporalInstantString ( isoString ), https://tc39.es/proposal-temporal/#sec-temporal-parsetemporalinstantstring ThrowCompletionOr<TemporalInstant> parse_temporal_instant_string(GlobalObject& global_object, String const& iso_string) { - auto& vm = global_object.vm(); - // 1. Assert: Type(isoString) is String. // 2. If isoString does not satisfy the syntax of a TemporalInstantString (see 13.33), then @@ -810,15 +808,13 @@ ThrowCompletionOr<TemporalInstant> parse_temporal_instant_string(GlobalObject& g auto result = parse_iso_date_time(global_object, iso_string).release_value(); // 4. Let timeZoneResult be ? ParseTemporalTimeZoneString(isoString). - auto time_zone_result = parse_temporal_time_zone_string(global_object, iso_string); - if (auto* exception = vm.exception()) - return throw_completion(exception->value()); + auto time_zone_result = TRY(parse_temporal_time_zone_string(global_object, iso_string)); // 5. Let offsetString be timeZoneResult.[[OffsetString]]. - auto offset_string = time_zone_result->offset; + auto offset_string = time_zone_result.offset; // 6. If timeZoneResult.[[Z]] is true, then - if (time_zone_result->z) { + if (time_zone_result.z) { // a. Set offsetString to "+00:00". offset_string = "+00:00"sv; } @@ -916,7 +912,7 @@ ThrowCompletionOr<TemporalTime> parse_temporal_time_string(GlobalObject& global_ } // 13.44 ParseTemporalTimeZoneString ( isoString ), https://tc39.es/proposal-temporal/#sec-temporal-parsetemporaltimezonestring -Optional<TemporalTimeZone> parse_temporal_time_zone_string(GlobalObject& global_object, [[maybe_unused]] String const& iso_string) +ThrowCompletionOr<TemporalTimeZone> parse_temporal_time_zone_string(GlobalObject& global_object, [[maybe_unused]] String const& iso_string) { auto& vm = global_object.vm(); @@ -996,10 +992,9 @@ Optional<TemporalTimeZone> parse_temporal_time_zone_string(GlobalObject& global_ // 7. If name is not undefined, then if (name_part.has_value()) { // a. If ! IsValidTimeZoneName(name) is false, throw a RangeError exception. - if (!is_valid_time_zone_name(*name_part)) { - vm.throw_exception<RangeError>(global_object, ErrorType::TemporalInvalidTimeZoneName); - return {}; - } + if (!is_valid_time_zone_name(*name_part)) + return vm.throw_completion<RangeError>(global_object, ErrorType::TemporalInvalidTimeZoneName); + // b. Set name to ! CanonicalizeTimeZoneName(name). name = canonicalize_time_zone_name(*name_part); } diff --git a/Userland/Libraries/LibJS/Runtime/Temporal/AbstractOperations.h b/Userland/Libraries/LibJS/Runtime/Temporal/AbstractOperations.h index dc7e4b274f..915eda15ce 100644 --- a/Userland/Libraries/LibJS/Runtime/Temporal/AbstractOperations.h +++ b/Userland/Libraries/LibJS/Runtime/Temporal/AbstractOperations.h @@ -110,7 +110,7 @@ ThrowCompletionOr<TemporalDate> parse_temporal_date_string(GlobalObject&, String ThrowCompletionOr<ISODateTime> parse_temporal_date_time_string(GlobalObject&, String const& iso_string); ThrowCompletionOr<TemporalDuration> parse_temporal_duration_string(GlobalObject&, String const& iso_string); ThrowCompletionOr<TemporalTime> parse_temporal_time_string(GlobalObject&, String const& iso_string); -Optional<TemporalTimeZone> parse_temporal_time_zone_string(GlobalObject&, String const& iso_string); +ThrowCompletionOr<TemporalTimeZone> parse_temporal_time_zone_string(GlobalObject&, String const& iso_string); Optional<TemporalYearMonth> parse_temporal_year_month_string(GlobalObject&, String const& iso_string); double to_positive_integer(GlobalObject&, Value argument); Object* prepare_temporal_fields(GlobalObject&, Object const& fields, Vector<String> const& field_names, Vector<StringView> const& required_fields); diff --git a/Userland/Libraries/LibJS/Runtime/Temporal/TimeZone.cpp b/Userland/Libraries/LibJS/Runtime/Temporal/TimeZone.cpp index 45255ef4c1..70af79258f 100644 --- a/Userland/Libraries/LibJS/Runtime/Temporal/TimeZone.cpp +++ b/Userland/Libraries/LibJS/Runtime/Temporal/TimeZone.cpp @@ -68,21 +68,17 @@ String default_time_zone() // 11.6.1 ParseTemporalTimeZone ( string ), https://tc39.es/proposal-temporal/#sec-temporal-parsetemporaltimezone ThrowCompletionOr<String> parse_temporal_time_zone(GlobalObject& global_object, String const& string) { - auto& vm = global_object.vm(); - // 1. Assert: Type(string) is String. // 2. Let result be ? ParseTemporalTimeZoneString(string). - auto result = parse_temporal_time_zone_string(global_object, string); - if (auto* exception = vm.exception()) - return throw_completion(exception->value()); + auto result = TRY(parse_temporal_time_zone_string(global_object, string)); // 3. If result.[[Z]] is not undefined, return "UTC". - if (result->z) + if (result.z) return String { "UTC" }; // 4. Return result.[[Name]]. - return *result->name; + return *result.name; } // 11.6.2 CreateTemporalTimeZone ( identifier [ , newTarget ] ), https://tc39.es/proposal-temporal/#sec-temporal-createtemporaltimezone |