mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2026-04-19 02:10:26 +00:00
This ensures that we are explicitly declaring the allocator to use when allocating a cell(-inheriting) type, instead of silently falling back to size-based allocation. Since this is done in allocate_cell, this will only be detected for types that are actively being allocated. However, since that means they're _not_ being allocated, that means it's safe to not declare an allocator to use for those. For example, the base TypedArray<T>, which is never directly allocated and only the defined specializations are ever allocated.
54 lines
1.2 KiB
C++
54 lines
1.2 KiB
C++
/*
|
|
* Copyright (c) 2023, Andreas Kling <andreas@ladybird.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/Function.h>
|
|
#include <LibGC/Cell.h>
|
|
#include <LibGC/Heap.h>
|
|
|
|
namespace GC {
|
|
|
|
template<typename T>
|
|
class Function final : public Cell {
|
|
GC_CELL(Function, Cell);
|
|
GC_DECLARE_ALLOCATOR(Function);
|
|
|
|
public:
|
|
static Ref<Function> create(Heap& heap, ESCAPING AK::Function<T> function)
|
|
{
|
|
return heap.allocate<Function>(move(function));
|
|
}
|
|
|
|
virtual ~Function() override = default;
|
|
|
|
[[nodiscard]] AK::Function<T> const& function() const { return m_function; }
|
|
|
|
private:
|
|
Function(AK::Function<T> function)
|
|
: m_function(move(function))
|
|
{
|
|
}
|
|
|
|
virtual void visit_edges(Visitor& visitor) override
|
|
{
|
|
Base::visit_edges(visitor);
|
|
visitor.visit_possible_values(m_function.raw_capture_range());
|
|
}
|
|
|
|
AK::Function<T> m_function;
|
|
};
|
|
|
|
template<typename Callable, typename T = EquivalentFunctionType<Callable>>
|
|
static Ref<Function<T>> create_function(Heap& heap, ESCAPING Callable&& function)
|
|
{
|
|
return Function<T>::create(heap, AK::Function<T> { forward<Callable>(function) });
|
|
}
|
|
|
|
template<typename T>
|
|
GC_DEFINE_ALLOCATOR(Function<T>);
|
|
|
|
}
|