ListOfAvailableImages.cpp 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. /*
  2. * Copyright (c) 2023, Andreas Kling <kling@serenityos.org>
  3. *
  4. * SPDX-License-Identifier: BSD-2-Clause
  5. */
  6. #include <LibWeb/HTML/DecodedImageData.h>
  7. #include <LibWeb/HTML/ListOfAvailableImages.h>
  8. namespace Web::HTML {
  9. JS_DEFINE_ALLOCATOR(ListOfAvailableImages);
  10. ListOfAvailableImages::ListOfAvailableImages() = default;
  11. ListOfAvailableImages::~ListOfAvailableImages() = default;
  12. bool ListOfAvailableImages::Key::operator==(Key const& other) const
  13. {
  14. return url == other.url && mode == other.mode && origin == other.origin;
  15. }
  16. u32 ListOfAvailableImages::Key::hash() const
  17. {
  18. if (!cached_hash.has_value()) {
  19. u32 url_hash = Traits<URL>::hash(url);
  20. u32 mode_hash = static_cast<u32>(mode);
  21. u32 origin_hash = 0;
  22. if (origin.has_value())
  23. origin_hash = Traits<HTML::Origin>::hash(origin.value());
  24. cached_hash = pair_int_hash(url_hash, pair_int_hash(mode_hash, origin_hash));
  25. }
  26. return cached_hash.value();
  27. }
  28. void ListOfAvailableImages::visit_edges(JS::Cell::Visitor& visitor)
  29. {
  30. Base::visit_edges(visitor);
  31. for (auto& it : m_images)
  32. visitor.visit(it.value->image_data);
  33. }
  34. void ListOfAvailableImages::add(Key const& key, JS::NonnullGCPtr<DecodedImageData> image_data, bool ignore_higher_layer_caching)
  35. {
  36. m_images.set(key, make<Entry>(image_data, ignore_higher_layer_caching));
  37. }
  38. void ListOfAvailableImages::remove(Key const& key)
  39. {
  40. m_images.remove(key);
  41. }
  42. ListOfAvailableImages::Entry* ListOfAvailableImages::get(Key const& key)
  43. {
  44. auto it = m_images.find(key);
  45. if (it == m_images.end())
  46. return nullptr;
  47. return it->value.ptr();
  48. }
  49. }