From 7e02e46c3c7cd55112ac123bbf8b4a588bd60444 Mon Sep 17 00:00:00 2001 From: Pavel Medvedev Date: Mon, 16 Oct 2023 13:45:22 +0200 Subject: [PATCH 1/2] Call `NewDefaultAllocator()` for `CreateParams` field Fallback to own implementation for old V8 versions prior to 5.4 Store created allocator as unique_ptr in`v8pp::context` to avoid memory leaks. --- v8pp/context.cpp | 17 +++++++++++++++-- v8pp/context.hpp | 1 + 2 files changed, 16 insertions(+), 2 deletions(-) diff --git a/v8pp/context.cpp b/v8pp/context.cpp index 2723dab8..9eff7fc0 100644 --- a/v8pp/context.cpp +++ b/v8pp/context.cpp @@ -129,6 +129,7 @@ void context::run_file(v8::FunctionCallbackInfo const& args) args.GetReturnValue().Set(scope.Escape(result)); } +#if V8_MAJOR_VERSION < 5 || (V8_MAJOR_VERSION == 5 && V8_MINOR_VERSION < 4) struct array_buffer_allocator : v8::ArrayBuffer::Allocator { void* Allocate(size_t length) @@ -145,12 +146,16 @@ struct array_buffer_allocator : v8::ArrayBuffer::Allocator (void)length; } }; -static array_buffer_allocator array_buffer_allocator_; +#endif v8::Isolate* context::create_isolate(v8::ArrayBuffer::Allocator* allocator) { v8::Isolate::CreateParams create_params; - create_params.array_buffer_allocator = allocator ? allocator : &array_buffer_allocator_; +#if V8_MAJOR_VERSION < 5 || (V8_MAJOR_VERSION == 5 && V8_MINOR_VERSION < 4) + create_params.array_buffer_allocator = allocator ? allocator : new array_buffer_allocator; +#else + create_params.array_buffer_allocator = allocator ? allocator : v8::ArrayBuffer::Allocator::NewDefaultAllocator(); +#endif return v8::Isolate::New(create_params); } @@ -165,6 +170,11 @@ context::context(v8::Isolate* isolate, v8::ArrayBuffer::Allocator* allocator, if (own_isolate_) { isolate_->Enter(); + if (!allocator) + { + // take ownership over the new allocator created in create_isolate() + array_buffer_allocator_.reset(isolate_->GetArrayBufferAllocator()); + } } v8::HandleScope scope(isolate_); @@ -195,6 +205,7 @@ context::context(context&& src) noexcept : own_isolate_(std::exchange(src.own_isolate_, false)) , enter_context_(std::exchange(src.enter_context_, false)) , isolate_(std::exchange(src.isolate_, nullptr)) + , array_buffer_allocator_(std::move(src.array_buffer_allocator_)) , impl_(std::move(src.impl_)) , modules_(std::move(src.modules_)) , lib_path_(std::move(src.lib_path_)) @@ -210,6 +221,7 @@ context& context::operator=(context&& src) noexcept own_isolate_ = std::exchange(src.own_isolate_, false); enter_context_ = std::exchange(src.enter_context_, false); isolate_ = std::exchange(src.isolate_, nullptr); + array_buffer_allocator_ = std::move(src.array_buffer_allocator_); impl_ = std::move(src.impl_); modules_ = std::move(src.modules_); lib_path_ = std::move(src.lib_path_); @@ -260,6 +272,7 @@ void context::destroy() isolate_->Dispose(); } isolate_ = nullptr; + array_buffer_allocator_.reset(); } context& context::value(std::string_view name, v8::Local value) diff --git a/v8pp/context.hpp b/v8pp/context.hpp index e67fc82e..4a0c8c4b 100644 --- a/v8pp/context.hpp +++ b/v8pp/context.hpp @@ -108,6 +108,7 @@ class context bool enter_context_; v8::Isolate* isolate_; v8::Global impl_; + std::unique_ptr array_buffer_allocator_; static void load_module(v8::FunctionCallbackInfo const& args); static void run_file(v8::FunctionCallbackInfo const& args); From fa8fe96e776d3347ba695767587e30d3b0d07472 Mon Sep 17 00:00:00 2001 From: Pavel Medvedev Date: Mon, 16 Oct 2023 17:27:25 +0200 Subject: [PATCH 2/2] fix -Wreorder warning in `context` ctor --- v8pp/context.cpp | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/v8pp/context.cpp b/v8pp/context.cpp index 9eff7fc0..0cbc67f9 100644 --- a/v8pp/context.cpp +++ b/v8pp/context.cpp @@ -205,8 +205,8 @@ context::context(context&& src) noexcept : own_isolate_(std::exchange(src.own_isolate_, false)) , enter_context_(std::exchange(src.enter_context_, false)) , isolate_(std::exchange(src.isolate_, nullptr)) - , array_buffer_allocator_(std::move(src.array_buffer_allocator_)) , impl_(std::move(src.impl_)) + , array_buffer_allocator_(std::move(src.array_buffer_allocator_)) , modules_(std::move(src.modules_)) , lib_path_(std::move(src.lib_path_)) {