
This helps us avoid from needing to construct a Function<T> when invoking `create_heap_function` with a lambda. Co-Authored-By: Ali Mohammad Pur <mpfard@serenityos.org>
50 lines
1.2 KiB
C++
50 lines
1.2 KiB
C++
/*
|
|
* Copyright (c) 2023, Andreas Kling <kling@serenityos.org>
|
|
*
|
|
* SPDX-License-Identifier: BSD-2-Clause
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
#include <AK/Function.h>
|
|
#include <LibJS/Heap/Cell.h>
|
|
#include <LibJS/Heap/Heap.h>
|
|
|
|
namespace JS {
|
|
|
|
template<typename T>
|
|
class HeapFunction final : public JS::Cell {
|
|
JS_CELL(HeapFunction, Cell);
|
|
|
|
public:
|
|
static NonnullGCPtr<HeapFunction> create(Heap& heap, Function<T> function)
|
|
{
|
|
return heap.allocate_without_realm<HeapFunction>(move(function));
|
|
}
|
|
|
|
virtual ~HeapFunction() override = default;
|
|
|
|
[[nodiscard]] Function<T> const& function() const { return m_function; }
|
|
|
|
private:
|
|
HeapFunction(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());
|
|
}
|
|
|
|
Function<T> m_function;
|
|
};
|
|
|
|
template<typename Callable, typename T = EquivalentFunctionType<Callable>>
|
|
static NonnullGCPtr<HeapFunction<T>> create_heap_function(Heap& heap, Callable&& function)
|
|
{
|
|
return HeapFunction<T>::create(heap, Function<T> { forward<Callable>(function) });
|
|
}
|
|
|
|
}
|