Buffers.cpp 3.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091
  1. /*
  2. * Copyright (c) 2023, Shannon Booth <shannon@serenityos.org>
  3. * Copyright (c) 2023, Matthew Olsson <mattco@serenityos.org>
  4. *
  5. * SPDX-License-Identifier: BSD-2-Clause
  6. */
  7. #include <LibJS/Runtime/DataView.h>
  8. #include <LibJS/Runtime/TypedArray.h>
  9. #include <LibWeb/WebIDL/Buffers.h>
  10. namespace Web::WebIDL {
  11. u32 BufferableObjectBase::byte_length() const
  12. {
  13. return m_bufferable_object.visit(
  14. [](JS::NonnullGCPtr<JS::TypedArrayBase> typed_array) {
  15. auto typed_array_record = JS::make_typed_array_with_buffer_witness_record(typed_array, JS::ArrayBuffer::Order::SeqCst);
  16. return JS::typed_array_byte_length(typed_array_record);
  17. },
  18. [](JS::NonnullGCPtr<JS::DataView> data_view) {
  19. auto view_record = JS::make_data_view_with_buffer_witness_record(data_view, JS::ArrayBuffer::Order::SeqCst);
  20. return JS::get_view_byte_length(view_record);
  21. },
  22. [](JS::NonnullGCPtr<JS::ArrayBuffer> array_buffer) { return static_cast<u32>(array_buffer->byte_length()); });
  23. }
  24. JS::NonnullGCPtr<JS::Object> BufferableObjectBase::raw_object()
  25. {
  26. return m_bufferable_object.visit([](auto const& obj) -> JS::NonnullGCPtr<JS::Object> { return obj; });
  27. }
  28. JS::GCPtr<JS::ArrayBuffer> BufferableObjectBase::viewed_array_buffer()
  29. {
  30. return m_bufferable_object.visit(
  31. [](JS::NonnullGCPtr<JS::ArrayBuffer> array_buffer) -> JS::GCPtr<JS::ArrayBuffer> { return array_buffer; },
  32. [](auto const& view) -> JS::GCPtr<JS::ArrayBuffer> { return view->viewed_array_buffer(); });
  33. }
  34. BufferableObject BufferableObjectBase::bufferable_object_from_raw_object(JS::NonnullGCPtr<JS::Object> object)
  35. {
  36. if (is<JS::TypedArrayBase>(*object))
  37. return JS::NonnullGCPtr { static_cast<JS::TypedArrayBase&>(*object) };
  38. if (is<JS::DataView>(*object))
  39. return JS::NonnullGCPtr { static_cast<JS::DataView&>(*object) };
  40. if (is<JS::ArrayBuffer>(*object))
  41. return JS::NonnullGCPtr { static_cast<JS::ArrayBuffer&>(*object) };
  42. VERIFY_NOT_REACHED();
  43. }
  44. BufferableObjectBase::BufferableObjectBase(JS::NonnullGCPtr<JS::Object> object)
  45. : m_bufferable_object(bufferable_object_from_raw_object(object))
  46. {
  47. }
  48. bool BufferableObjectBase::is_typed_array_base() const
  49. {
  50. return m_bufferable_object.has<JS::NonnullGCPtr<JS::TypedArrayBase>>();
  51. }
  52. bool BufferableObjectBase::is_data_view() const
  53. {
  54. return m_bufferable_object.has<JS::NonnullGCPtr<JS::DataView>>();
  55. }
  56. bool BufferableObjectBase::is_array_buffer() const
  57. {
  58. return m_bufferable_object.has<JS::NonnullGCPtr<JS::ArrayBuffer>>();
  59. }
  60. void BufferableObjectBase::visit_edges(Visitor& visitor)
  61. {
  62. Base::visit_edges(visitor);
  63. m_bufferable_object.visit([&](auto& obj) { visitor.visit(obj); });
  64. }
  65. ArrayBufferView::~ArrayBufferView() = default;
  66. u32 ArrayBufferView::byte_offset() const
  67. {
  68. return m_bufferable_object.visit(
  69. [](JS::NonnullGCPtr<JS::ArrayBuffer>) -> u32 { VERIFY_NOT_REACHED(); },
  70. [](auto& view) -> u32 { return static_cast<u32>(view->byte_offset()); });
  71. }
  72. BufferSource::~BufferSource() = default;
  73. }