mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2024-11-21 23:20:20 +00:00
LibJS+js: Add a debug option (js -g) to GC after every allocation
This is very useful for discovering collector bugs.
This commit is contained in:
parent
ab404a2f88
commit
cb2e7d1c5f
Notes:
sideshowbarker
2024-07-19 08:16:27 +09:00
Author: https://github.com/awesomekling Commit: https://github.com/SerenityOS/serenity/commit/cb2e7d1c5f7
3 changed files with 11 additions and 0 deletions
|
@ -49,6 +49,9 @@ Heap::~Heap()
|
|||
|
||||
Cell* Heap::allocate_cell(size_t size)
|
||||
{
|
||||
if (should_collect_on_every_allocation())
|
||||
collect_garbage();
|
||||
|
||||
for (auto& block : m_blocks) {
|
||||
if (size > block->cell_size())
|
||||
continue;
|
||||
|
|
|
@ -55,6 +55,9 @@ public:
|
|||
|
||||
Interpreter& interpreter() { return m_interpreter; }
|
||||
|
||||
bool should_collect_on_every_allocation() const { return m_should_collect_on_every_allocation; }
|
||||
void set_should_collect_on_every_allocation(bool b) { m_should_collect_on_every_allocation = b; }
|
||||
|
||||
private:
|
||||
Cell* allocate_cell(size_t);
|
||||
|
||||
|
@ -65,6 +68,8 @@ private:
|
|||
|
||||
Cell* cell_from_possible_pointer(FlatPtr);
|
||||
|
||||
bool m_should_collect_on_every_allocation { false };
|
||||
|
||||
Interpreter& m_interpreter;
|
||||
Vector<NonnullOwnPtr<HeapBlock>> m_blocks;
|
||||
};
|
||||
|
|
|
@ -41,10 +41,12 @@
|
|||
int main(int argc, char** argv)
|
||||
{
|
||||
bool dump_ast = false;
|
||||
bool gc_on_every_allocation = false;
|
||||
const char* script_path = nullptr;
|
||||
|
||||
Core::ArgsParser args_parser;
|
||||
args_parser.add_option(dump_ast, "Dump the AST", "ast-dump", 'A');
|
||||
args_parser.add_option(gc_on_every_allocation, "GC on every allocation", "gc-on-every-allocation", 'g');
|
||||
args_parser.add_positional_argument(script_path, "Path to script file", "script");
|
||||
args_parser.parse(argc, argv);
|
||||
|
||||
|
@ -56,6 +58,7 @@ int main(int argc, char** argv)
|
|||
auto file_contents = file->read_all();
|
||||
|
||||
JS::Interpreter interpreter;
|
||||
interpreter.heap().set_should_collect_on_every_allocation(gc_on_every_allocation);
|
||||
|
||||
auto program = JS::Parser(JS::Lexer(file_contents)).parse_program();
|
||||
|
||||
|
|
Loading…
Reference in a new issue