/* * Copyright (c) 2022, Andreas Kling * Copyright (c) 2022, Sam Atkins * * SPDX-License-Identifier: BSD-2-Clause */ #include #include #include #include namespace Web::Geometry { JS_DEFINE_ALLOCATOR(DOMPointReadOnly); JS::NonnullGCPtr DOMPointReadOnly::construct_impl(JS::Realm& realm, double x, double y, double z, double w) { return realm.heap().allocate(realm, realm, x, y, z, w); } DOMPointReadOnly::DOMPointReadOnly(JS::Realm& realm, double x, double y, double z, double w) : PlatformObject(realm) , m_x(x) , m_y(y) , m_z(z) , m_w(w) { } // https://drafts.fxtf.org/geometry/#dom-dompointreadonly-frompoint JS::NonnullGCPtr DOMPointReadOnly::from_point(JS::VM& vm, DOMPointInit const& other) { // The fromPoint(other) static method on DOMPointReadOnly must create a DOMPointReadOnly from the dictionary other. return construct_impl(*vm.current_realm(), other.x, other.y, other.z, other.w); } DOMPointReadOnly::~DOMPointReadOnly() = default; // https://drafts.fxtf.org/geometry/#dom-dompointreadonly-matrixtransform WebIDL::ExceptionOr> DOMPointReadOnly::matrix_transform(DOMMatrixInit& matrix) const { // 1. Let matrixObject be the result of invoking create a DOMMatrix from the dictionary matrix. auto matrix_object = TRY(DOMMatrix::create_from_dom_matrix_init(realm(), matrix)); // 2. Return the result of invoking transform a point with a matrix, given the current point and matrixObject. The current point does not get modified. return matrix_object->transform_point(*this); } void DOMPointReadOnly::initialize(JS::Realm& realm) { Base::initialize(realm); WEB_SET_PROTOTYPE_FOR_INTERFACE(DOMPointReadOnly); } }