From e110ccf84d8d9034e82a79bf7abf1fa92b2370be Mon Sep 17 00:00:00 2001 From: Jarred Sumner Date: Fri, 28 Jul 2023 01:33:00 -0700 Subject: Fixes #3795 (#3856) Co-authored-by: Jarred Sumner <709451+Jarred-Sumner@users.noreply.github.com> --- src/bun.js/bindings/ScriptExecutionContext.cpp | 11 +++++++++++ 1 file changed, 11 insertions(+) (limited to 'src/bun.js/bindings/ScriptExecutionContext.cpp') diff --git a/src/bun.js/bindings/ScriptExecutionContext.cpp b/src/bun.js/bindings/ScriptExecutionContext.cpp index d93478ed8..47908b385 100644 --- a/src/bun.js/bindings/ScriptExecutionContext.cpp +++ b/src/bun.js/bindings/ScriptExecutionContext.cpp @@ -5,6 +5,7 @@ #include "webcore/WebSocket.h" #include "libusockets.h" #include "_libusockets.h" +#include "BunClientData.h" extern "C" void Bun__startLoop(us_loop_t* loop); @@ -58,6 +59,16 @@ us_socket_context_t* ScriptExecutionContext::webSocketContextSSL() return m_ssl_client_websockets_ctx; } +extern "C" void Bun__eventLoop__incrementRefConcurrently(void* bunVM, int delta); + +void ScriptExecutionContext::refEventLoop() +{ + Bun__eventLoop__incrementRefConcurrently(WebCore::clientData(vm())->bunVM, 1); +} +void ScriptExecutionContext::unrefEventLoop() +{ + Bun__eventLoop__incrementRefConcurrently(WebCore::clientData(vm())->bunVM, -1); +} bool ScriptExecutionContext::postTaskTo(ScriptExecutionContextIdentifier identifier, Function&& task) { -- cgit v1.2.3