/* * Copyright (c) 2023, Shannon Booth * Copyright (c) 2023, Matthew Olsson * * SPDX-License-Identifier: BSD-2-Clause */ #include #include #include namespace Web::WebIDL { u32 BufferableObjectBase::byte_length() const { return m_bufferable_object.visit( [](JS::NonnullGCPtr typed_array) { auto typed_array_record = JS::make_typed_array_with_buffer_witness_record(typed_array, JS::ArrayBuffer::Order::SeqCst); return JS::typed_array_byte_length(typed_array_record); }, [](JS::NonnullGCPtr data_view) { auto view_record = JS::make_data_view_with_buffer_witness_record(data_view, JS::ArrayBuffer::Order::SeqCst); return JS::get_view_byte_length(view_record); }, [](JS::NonnullGCPtr array_buffer) { return static_cast(array_buffer->byte_length()); }); } JS::NonnullGCPtr BufferableObjectBase::raw_object() { return m_bufferable_object.visit([](auto const& obj) -> JS::NonnullGCPtr { return obj; }); } JS::GCPtr BufferableObjectBase::viewed_array_buffer() { return m_bufferable_object.visit( [](JS::NonnullGCPtr array_buffer) -> JS::GCPtr { return array_buffer; }, [](auto const& view) -> JS::GCPtr { return view->viewed_array_buffer(); }); } BufferableObject BufferableObjectBase::bufferable_object_from_raw_object(JS::NonnullGCPtr object) { if (is(*object)) return JS::NonnullGCPtr { static_cast(*object) }; if (is(*object)) return JS::NonnullGCPtr { static_cast(*object) }; if (is(*object)) return JS::NonnullGCPtr { static_cast(*object) }; VERIFY_NOT_REACHED(); } BufferableObjectBase::BufferableObjectBase(JS::NonnullGCPtr object) : m_bufferable_object(bufferable_object_from_raw_object(object)) { } bool BufferableObjectBase::is_typed_array_base() const { return m_bufferable_object.has>(); } bool BufferableObjectBase::is_data_view() const { return m_bufferable_object.has>(); } bool BufferableObjectBase::is_array_buffer() const { return m_bufferable_object.has>(); } void BufferableObjectBase::visit_edges(Visitor& visitor) { Base::visit_edges(visitor); m_bufferable_object.visit([&](auto& obj) { visitor.visit(obj); }); } ArrayBufferView::~ArrayBufferView() = default; u32 ArrayBufferView::byte_offset() const { return m_bufferable_object.visit( [](JS::NonnullGCPtr) -> u32 { VERIFY_NOT_REACHED(); }, [](auto& view) -> u32 { return static_cast(view->byte_offset()); }); } BufferSource::~BufferSource() = default; }