/* * Copyright (c) 2022, DerpyCrabs * * SPDX-License-Identifier: BSD-2-Clause */ #include #include #include #include #include #include namespace Web::Geometry { GC_DEFINE_ALLOCATOR(DOMRectList); GC::Ref DOMRectList::create(JS::Realm& realm, Vector> rect_handles) { Vector> rects; for (auto& rect : rect_handles) rects.append(*rect); return realm.create(realm, move(rects)); } DOMRectList::DOMRectList(JS::Realm& realm, Vector> rects) : Bindings::PlatformObject(realm) , m_rects(move(rects)) { m_legacy_platform_object_flags = LegacyPlatformObjectFlags { .supports_indexed_properties = 1 }; } DOMRectList::~DOMRectList() = default; void DOMRectList::initialize(JS::Realm& realm) { Base::initialize(realm); WEB_SET_PROTOTYPE_FOR_INTERFACE(DOMRectList); } void DOMRectList::visit_edges(Cell::Visitor& visitor) { Base::visit_edges(visitor); visitor.visit(m_rects); } // https://drafts.fxtf.org/geometry-1/#dom-domrectlist-length u32 DOMRectList::length() const { return m_rects.size(); } // https://drafts.fxtf.org/geometry-1/#dom-domrectlist-item DOMRect const* DOMRectList::item(u32 index) const { // The item(index) method, when invoked, must return null when // index is greater than or equal to the number of DOMRect objects associated with the DOMRectList. // Otherwise, the DOMRect object at index must be returned. Indices are zero-based. if (index >= m_rects.size()) return nullptr; return m_rects[index]; } Optional DOMRectList::item_value(size_t index) const { if (index >= m_rects.size()) return {}; return m_rects[index].ptr(); } }