AbstractOperations.h 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172
  1. /*
  2. * Copyright (c) 2021-2024, Tim Flynn <trflynn89@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #pragma once
  7. #include <AK/Span.h>
  8. #include <AK/String.h>
  9. #include <AK/Variant.h>
  10. #include <AK/Vector.h>
  11. #include <LibJS/Forward.h>
  12. #include <LibJS/Runtime/Completion.h>
  13. #include <LibJS/Runtime/Temporal/AbstractOperations.h>
  14. #include <LibJS/Runtime/Value.h>
  15. #include <LibLocale/Forward.h>
  16. namespace JS::Intl {
  17. using LocaleKey = Variant<Empty, String>;
  18. Optional<LocaleKey> locale_key_from_value(Value);
  19. struct LocaleOptions {
  20. Value locale_matcher;
  21. Optional<LocaleKey> ca; // [[Calendar]]
  22. Optional<LocaleKey> co; // [[Collation]]
  23. Optional<LocaleKey> hc; // [[HourCycle]]
  24. Optional<LocaleKey> kf; // [[CaseFirst]]
  25. Optional<LocaleKey> kn; // [[Numeric]]
  26. Optional<LocaleKey> nu; // [[NumberingSystem]]
  27. };
  28. struct LocaleResult {
  29. String locale;
  30. String data_locale;
  31. LocaleKey ca; // [[Calendar]]
  32. LocaleKey co; // [[Collation]]
  33. LocaleKey hc; // [[HourCycle]]
  34. LocaleKey kf; // [[CaseFirst]]
  35. LocaleKey kn; // [[Numeric]]
  36. LocaleKey nu; // [[NumberingSystem]]
  37. };
  38. using StringOrBoolean = Variant<StringView, bool>;
  39. bool is_structurally_valid_language_tag(StringView locale);
  40. String canonicalize_unicode_locale_id(StringView locale);
  41. bool is_well_formed_currency_code(StringView currency);
  42. bool is_well_formed_unit_identifier(StringView unit_identifier);
  43. ThrowCompletionOr<Vector<String>> canonicalize_locale_list(VM&, Value locales);
  44. Optional<StringView> best_available_locale(StringView locale);
  45. String insert_unicode_extension_and_canonicalize(::Locale::LocaleID locale_id, ::Locale::LocaleExtension extension);
  46. LocaleResult resolve_locale(Vector<String> const& requested_locales, LocaleOptions const& options, ReadonlySpan<StringView> relevant_extension_keys);
  47. ThrowCompletionOr<Array*> supported_locales(VM&, Vector<String> const& requested_locales, Value options);
  48. ThrowCompletionOr<Object*> coerce_options_to_object(VM&, Value options);
  49. ThrowCompletionOr<StringOrBoolean> get_boolean_or_string_number_format_option(VM& vm, Object const& options, PropertyKey const& property, ReadonlySpan<StringView> string_values, StringOrBoolean fallback);
  50. ThrowCompletionOr<Optional<int>> default_number_option(VM&, Value value, int minimum, int maximum, Optional<int> fallback);
  51. ThrowCompletionOr<Optional<int>> get_number_option(VM&, Object const& options, PropertyKey const& property, int minimum, int maximum, Optional<int> fallback);
  52. template<size_t Size>
  53. ThrowCompletionOr<StringOrBoolean> get_boolean_or_string_number_format_option(VM& vm, Object const& options, PropertyKey const& property, StringView const (&string_values)[Size], StringOrBoolean fallback)
  54. {
  55. return get_boolean_or_string_number_format_option(vm, options, property, ReadonlySpan<StringView> { string_values }, move(fallback));
  56. }
  57. // NOTE: ECMA-402's GetOption is being removed in favor of a shared ECMA-262 GetOption in the Temporal proposal.
  58. // Until Temporal is merged into ECMA-262, our implementation lives in the Temporal-specific AO file & namespace.
  59. using Temporal::get_option;
  60. using Temporal::OptionType;
  61. }