diff options
author | Linus Groh <mail@linusgroh.de> | 2021-07-16 00:07:49 +0100 |
---|---|---|
committer | Linus Groh <mail@linusgroh.de> | 2021-07-16 01:07:01 +0100 |
commit | be5254dcacc3c9f84842fda84dc95fd9c32f2c05 (patch) | |
tree | ca2134738a619919ced55232642ec92418819f7f /Userland | |
parent | 04e2d215a1aec0aeecd9a1b43265d96deb18bf7f (diff) | |
download | serenity-be5254dcacc3c9f84842fda84dc95fd9c32f2c05.zip |
LibJS: Implement Temporal.Duration.prototype.nanoseconds
Diffstat (limited to 'Userland')
4 files changed, 30 insertions, 0 deletions
diff --git a/Userland/Libraries/LibJS/Runtime/CommonPropertyNames.h b/Userland/Libraries/LibJS/Runtime/CommonPropertyNames.h index 4a8f7bf19e..82e304e8e1 100644 --- a/Userland/Libraries/LibJS/Runtime/CommonPropertyNames.h +++ b/Userland/Libraries/LibJS/Runtime/CommonPropertyNames.h @@ -244,6 +244,7 @@ namespace JS { P(months) \ P(multiline) \ P(name) \ + P(nanoseconds) \ P(next) \ P(now) \ P(of) \ diff --git a/Userland/Libraries/LibJS/Runtime/Temporal/DurationPrototype.cpp b/Userland/Libraries/LibJS/Runtime/Temporal/DurationPrototype.cpp index 7277bcac20..805e53b4a9 100644 --- a/Userland/Libraries/LibJS/Runtime/Temporal/DurationPrototype.cpp +++ b/Userland/Libraries/LibJS/Runtime/Temporal/DurationPrototype.cpp @@ -34,6 +34,7 @@ void DurationPrototype::initialize(GlobalObject& global_object) define_native_accessor(vm.names.seconds, seconds_getter, {}, Attribute::Configurable); define_native_accessor(vm.names.milliseconds, milliseconds_getter, {}, Attribute::Configurable); define_native_accessor(vm.names.microseconds, microseconds_getter, {}, Attribute::Configurable); + define_native_accessor(vm.names.nanoseconds, nanoseconds_getter, {}, Attribute::Configurable); } static Duration* typed_this(GlobalObject& global_object) @@ -166,4 +167,17 @@ JS_DEFINE_NATIVE_FUNCTION(DurationPrototype::microseconds_getter) return Value(duration->microseconds()); } +// 7.3.12 get Temporal.Duration.prototype.nanoseconds, https://tc39.es/proposal-temporal/#sec-get-temporal.duration.prototype.nanoseconds +JS_DEFINE_NATIVE_FUNCTION(DurationPrototype::nanoseconds_getter) +{ + // 1. Let duration be the this value. + // 2. Perform ? RequireInternalSlot(duration, [[InitializedTemporalDuration]]). + auto* duration = typed_this(global_object); + if (vm.exception()) + return {}; + + // 3. Return duration.[[Nanoseconds]]. + return Value(duration->nanoseconds()); +} + } diff --git a/Userland/Libraries/LibJS/Runtime/Temporal/DurationPrototype.h b/Userland/Libraries/LibJS/Runtime/Temporal/DurationPrototype.h index 2ca56107f9..6494d75e9d 100644 --- a/Userland/Libraries/LibJS/Runtime/Temporal/DurationPrototype.h +++ b/Userland/Libraries/LibJS/Runtime/Temporal/DurationPrototype.h @@ -28,6 +28,7 @@ private: JS_DECLARE_NATIVE_FUNCTION(seconds_getter); JS_DECLARE_NATIVE_FUNCTION(milliseconds_getter); JS_DECLARE_NATIVE_FUNCTION(microseconds_getter); + JS_DECLARE_NATIVE_FUNCTION(nanoseconds_getter); }; } diff --git a/Userland/Libraries/LibJS/Tests/builtins/Temporal/Duration/Duration.prototype.nanoseconds.js b/Userland/Libraries/LibJS/Tests/builtins/Temporal/Duration/Duration.prototype.nanoseconds.js new file mode 100644 index 0000000000..53faa248b0 --- /dev/null +++ b/Userland/Libraries/LibJS/Tests/builtins/Temporal/Duration/Duration.prototype.nanoseconds.js @@ -0,0 +1,14 @@ +describe("correct behavior", () => { + test("basic functionality", () => { + const duration = new Temporal.Duration(0, 0, 0, 0, 0, 0, 0, 0, 0, 123); + expect(duration.nanoseconds).toBe(123); + }); +}); + +test("errors", () => { + test("this value must be a Temporal.Duration object", () => { + expect(() => { + Reflect.get(Temporal.Duration.prototype, "nanoseconds", "foo"); + }).toThrowWithMessage(TypeError, "Not a Temporal.Duration"); + }); +}); |