// Copyright 2018 the V8 project authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef V8_INTL_SUPPORT #error Internationalization is expected to be enabled. #endif // V8_INTL_SUPPORT #ifndef V8_OBJECTS_JS_RELATIVE_TIME_FORMAT_H_ #define V8_OBJECTS_JS_RELATIVE_TIME_FORMAT_H_ #include #include #include "src/execution/isolate.h" #include "src/heap/factory.h" #include "src/objects/managed.h" #include "src/objects/objects.h" #include "unicode/uversion.h" // Has to be the last include (doesn't have include guards): #include "src/objects/object-macros.h" namespace U_ICU_NAMESPACE { class RelativeDateTimeFormatter; } namespace v8 { namespace internal { class JSRelativeTimeFormat : public JSObject { public: // Creates relative time format object with properties derived from input // locales and options. V8_WARN_UNUSED_RESULT static MaybeHandle New( Isolate* isolate, Handle map, Handle locales, Handle options); V8_WARN_UNUSED_RESULT static Handle ResolvedOptions( Isolate* isolate, Handle format_holder); Handle StyleAsString() const; Handle NumericAsString() const; // ecma402/#sec-Intl.RelativeTimeFormat.prototype.format V8_WARN_UNUSED_RESULT static MaybeHandle Format( Isolate* isolate, Handle value_obj, Handle unit_obj, Handle format); // ecma402/#sec-Intl.RelativeTimeFormat.prototype.formatToParts V8_WARN_UNUSED_RESULT static MaybeHandle FormatToParts( Isolate* isolate, Handle value_obj, Handle unit_obj, Handle format); V8_EXPORT_PRIVATE static const std::set& GetAvailableLocales(); DECL_CAST(JSRelativeTimeFormat) // RelativeTimeFormat accessors. DECL_ACCESSORS(locale, String) DECL_ACCESSORS(icu_formatter, Managed) // Style: identifying the relative time format style used. // // ecma402/#sec-properties-of-intl-relativetimeformat-instances enum class Style { LONG, // Everything spelled out. SHORT, // Abbreviations used when possible. NARROW // Use the shortest possible form. }; inline void set_style(Style style); inline Style style() const; // Numeric: identifying whether numerical descriptions are always used, or // used only when no more specific version is available (e.g., "1 day ago" vs // "yesterday"). // // ecma402/#sec-properties-of-intl-relativetimeformat-instances enum class Numeric { ALWAYS, // numerical descriptions are always used ("1 day ago") AUTO // numerical descriptions are used only when no more specific // version is available ("yesterday") }; inline void set_numeric(Numeric numeric); inline Numeric numeric() const; // Bit positions in |flags|. #define FLAGS_BIT_FIELDS(V, _) \ V(StyleBits, Style, 2, _) \ V(NumericBits, Numeric, 1, _) DEFINE_BIT_FIELDS(FLAGS_BIT_FIELDS) #undef FLAGS_BIT_FIELDS STATIC_ASSERT(Style::LONG <= StyleBits::kMax); STATIC_ASSERT(Style::SHORT <= StyleBits::kMax); STATIC_ASSERT(Style::NARROW <= StyleBits::kMax); STATIC_ASSERT(Numeric::AUTO <= NumericBits::kMax); STATIC_ASSERT(Numeric::ALWAYS <= NumericBits::kMax); // [flags] Bit field containing various flags about the function. DECL_INT_ACCESSORS(flags) DECL_PRINTER(JSRelativeTimeFormat) DECL_VERIFIER(JSRelativeTimeFormat) // Layout description. DEFINE_FIELD_OFFSET_CONSTANTS(JSObject::kHeaderSize, TORQUE_GENERATED_JSRELATIVE_TIME_FORMAT_FIELDS) private: static Style getStyle(const char* str); static Numeric getNumeric(const char* str); OBJECT_CONSTRUCTORS(JSRelativeTimeFormat, JSObject); }; } // namespace internal } // namespace v8 #include "src/objects/object-macros-undef.h" #endif // V8_OBJECTS_JS_RELATIVE_TIME_FORMAT_H_