ArrayBuffer.cpp 1.1 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546
  1. /*
  2. * Copyright (c) 2020, Linus Groh <linusg@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <LibJS/Runtime/ArrayBuffer.h>
  7. #include <LibJS/Runtime/GlobalObject.h>
  8. namespace JS {
  9. ArrayBuffer* ArrayBuffer::create(GlobalObject& global_object, size_t byte_size)
  10. {
  11. return global_object.heap().allocate<ArrayBuffer>(global_object, byte_size, *global_object.array_buffer_prototype());
  12. }
  13. ArrayBuffer* ArrayBuffer::create(GlobalObject& global_object, ByteBuffer* buffer)
  14. {
  15. return global_object.heap().allocate<ArrayBuffer>(global_object, buffer, *global_object.array_buffer_prototype());
  16. }
  17. ArrayBuffer::ArrayBuffer(size_t byte_size, Object& prototype)
  18. : Object(prototype)
  19. , m_buffer(ByteBuffer::create_zeroed(byte_size).release_value()) // FIXME: Handle this possible OOM failure.
  20. , m_detach_key(js_undefined())
  21. {
  22. }
  23. ArrayBuffer::ArrayBuffer(ByteBuffer* buffer, Object& prototype)
  24. : Object(prototype)
  25. , m_buffer(buffer)
  26. , m_detach_key(js_undefined())
  27. {
  28. }
  29. ArrayBuffer::~ArrayBuffer()
  30. {
  31. }
  32. void ArrayBuffer::visit_edges(Cell::Visitor& visitor)
  33. {
  34. Object::visit_edges(visitor);
  35. visitor.visit(m_detach_key);
  36. }
  37. }