
This commit un-deprecates DeprecatedString, and repurposes it as a byte string. As the null state has already been removed, there are no other particularly hairy blockers in repurposing this type as a byte string (what it _really_ is). This commit is auto-generated: $ xs=$(ack -l \bDeprecatedString\b\|deprecated_string AK Userland \ Meta Ports Ladybird Tests Kernel) $ perl -pie 's/\bDeprecatedString\b/ByteString/g; s/deprecated_string/byte_string/g' $xs $ clang-format --style=file -i \ $(git diff --name-only | grep \.cpp\|\.h) $ gn format $(git ls-files '*.gn' '*.gni')
71 lines
1.9 KiB
C++
71 lines
1.9 KiB
C++
/*
|
|
* Copyright (c) 2022-2023, networkException <networkexception@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#include <LibWeb/HTML/Scripting/ModuleMap.h>
|
|
|
|
namespace Web::HTML {
|
|
|
|
JS_DEFINE_ALLOCATOR(ModuleMap);
|
|
|
|
void ModuleMap::visit_edges(Visitor& visitor)
|
|
{
|
|
Base::visit_edges(visitor);
|
|
for (auto& it : m_values)
|
|
visitor.visit(it.value.module_script);
|
|
|
|
for (auto const& it : m_callbacks)
|
|
for (auto const& callback : it.value)
|
|
visitor.visit(callback);
|
|
}
|
|
|
|
bool ModuleMap::is_fetching(AK::URL const& url, ByteString const& type) const
|
|
{
|
|
return is(url, type, EntryType::Fetching);
|
|
}
|
|
|
|
bool ModuleMap::is_failed(AK::URL const& url, ByteString const& type) const
|
|
{
|
|
return is(url, type, EntryType::Failed);
|
|
}
|
|
|
|
bool ModuleMap::is(AK::URL const& url, ByteString const& type, EntryType entry_type) const
|
|
{
|
|
auto value = m_values.get({ url, type });
|
|
if (!value.has_value())
|
|
return false;
|
|
|
|
return value->type == entry_type;
|
|
}
|
|
|
|
Optional<ModuleMap::Entry> ModuleMap::get(AK::URL const& url, ByteString const& type) const
|
|
{
|
|
return m_values.get({ url, type });
|
|
}
|
|
|
|
AK::HashSetResult ModuleMap::set(AK::URL const& url, ByteString const& type, Entry entry)
|
|
{
|
|
// NOTE: Re-entering this function while firing wait_for_change callbacks is not allowed.
|
|
VERIFY(!m_firing_callbacks);
|
|
|
|
auto value = m_values.set({ url, type }, entry);
|
|
|
|
auto callbacks = m_callbacks.get({ url, type });
|
|
if (callbacks.has_value()) {
|
|
m_firing_callbacks = true;
|
|
for (auto const& callback : *callbacks)
|
|
callback->function()(entry);
|
|
m_firing_callbacks = false;
|
|
}
|
|
|
|
return value;
|
|
}
|
|
|
|
void ModuleMap::wait_for_change(JS::Heap& heap, AK::URL const& url, ByteString const& type, Function<void(Entry)> callback)
|
|
{
|
|
m_callbacks.ensure({ url, type }).append(JS::create_heap_function(heap, move(callback)));
|
|
}
|
|
|
|
}
|