From 4ff8f377a9448eaec3b5dd7ba5c0b14cc327939d Mon Sep 17 00:00:00 2001 From: Ben Noordhuis Date: Wed, 1 Jul 2015 23:47:37 +0200 Subject: [PATCH] src: enable v8 deprecation warnings and fix them Turn on V8 API deprecation warnings. Fix up the no-arg Isolate::New() calls in src/node.cc and src/debug-agent.cc. PR-URL: https://github.com/nodejs/io.js/pull/2091 Reviewed-By: Trevor Norris --- node.gyp | 2 ++ src/debug-agent.cc | 5 ++++- src/node.cc | 39 ++++----------------------------------- src/node_internals.h | 14 ++++++++++++++ 4 files changed, 24 insertions(+), 36 deletions(-) diff --git a/node.gyp b/node.gyp index 21d2802a2067b0..ff73a93c7ba5ee 100644 --- a/node.gyp +++ b/node.gyp @@ -181,6 +181,8 @@ 'NODE_PLATFORM="<(OS)"', 'NODE_V8_OPTIONS="<(node_v8_options)"', 'NODE_WANT_INTERNALS=1', + # Warn when using deprecated V8 APIs. + 'V8_DEPRECATION_WARNINGS=1', ], diff --git a/src/debug-agent.cc b/src/debug-agent.cc index 39d8bfe9e5afcc..b99446f69c4ca6 100644 --- a/src/debug-agent.cc +++ b/src/debug-agent.cc @@ -160,7 +160,10 @@ void Agent::Stop() { void Agent::WorkerRun() { static const char* argv[] = { "node", "--debug-agent" }; - Isolate* isolate = Isolate::New(); + Isolate::CreateParams params; + ArrayBufferAllocator array_buffer_allocator; + params.array_buffer_allocator = &array_buffer_allocator; + Isolate* isolate = Isolate::New(params); { Locker locker(isolate); Isolate::Scope isolate_scope(isolate); diff --git a/src/node.cc b/src/node.cc index 7a949adfb59cc1..95cfade523f0ae 100644 --- a/src/node.cc +++ b/src/node.cc @@ -147,38 +147,6 @@ static uv_async_t dispatch_debug_messages_async; static Isolate* node_isolate = nullptr; static v8::Platform* default_platform; -class ArrayBufferAllocator : public ArrayBuffer::Allocator { - public: - // Impose an upper limit to avoid out of memory errors that bring down - // the process. - static const size_t kMaxLength = 0x3fffffff; - static ArrayBufferAllocator the_singleton; - virtual ~ArrayBufferAllocator() = default; - virtual void* Allocate(size_t length) override; - virtual void* AllocateUninitialized(size_t length) override; - virtual void Free(void* data, size_t length) override; - private: - ArrayBufferAllocator() = default; - DISALLOW_COPY_AND_ASSIGN(ArrayBufferAllocator); -}; - -ArrayBufferAllocator ArrayBufferAllocator::the_singleton; - - -void* ArrayBufferAllocator::Allocate(size_t length) { - return calloc(length, 1); -} - - -void* ArrayBufferAllocator::AllocateUninitialized(size_t length) { - return malloc(length); -} - - -void ArrayBufferAllocator::Free(void* data, size_t length) { - free(data); -} - static void CheckImmediate(uv_check_t* handle) { Environment* env = Environment::from_immediate_check_handle(handle); @@ -3675,8 +3643,6 @@ void Init(int* argc, V8::SetFlagsFromString(expose_debug_as, sizeof(expose_debug_as) - 1); } - V8::SetArrayBufferAllocator(&ArrayBufferAllocator::the_singleton); - if (!use_debug_agent) { RegisterDebugSignalHandler(); } @@ -3878,7 +3844,10 @@ Environment* CreateEnvironment(Isolate* isolate, // node instance. static void StartNodeInstance(void* arg) { NodeInstanceData* instance_data = static_cast(arg); - Isolate* isolate = Isolate::New(); + Isolate::CreateParams params; + ArrayBufferAllocator array_buffer_allocator; + params.array_buffer_allocator = &array_buffer_allocator; + Isolate* isolate = Isolate::New(params); // Fetch a reference to the main isolate, so we have a reference to it // even when we need it to access it from another (debugger) thread. if (instance_data->is_main()) diff --git a/src/node_internals.h b/src/node_internals.h index c99b2feeb0bdcd..06a8b81aa79c66 100644 --- a/src/node_internals.h +++ b/src/node_internals.h @@ -195,6 +195,20 @@ NODE_DEPRECATED("Use ThrowUVException(isolate)", return ThrowUVException(isolate, errorno, syscall, message, path); }) +struct ArrayBufferAllocator : public v8::ArrayBuffer::Allocator { + virtual void* Allocate(size_t size) { + return calloc(size, 1); + } + + virtual void* AllocateUninitialized(size_t size) { + return malloc(size); + } + + virtual void Free(void* data, size_t) { + free(data); + } +}; + enum NodeInstanceType { MAIN, WORKER }; class NodeInstanceData {