| OLD | NEW |
| (Empty) |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #ifndef CONTENT_SHELL_RENDERER_TEST_RUNNER_UNSAFE_PERSISTENT_H_ | |
| 6 #define CONTENT_SHELL_RENDERER_TEST_RUNNER_UNSAFE_PERSISTENT_H_ | |
| 7 | |
| 8 #include "v8/include/v8.h" | |
| 9 | |
| 10 namespace content { | |
| 11 | |
| 12 // An unsafe way to pass Persistent handles around. Do not use unless you know | |
| 13 // what you're doing. UnsafePersistent is only safe to use when we know that the | |
| 14 // memory pointed by it is not going away: 1) When GC cannot happen while the | |
| 15 // UnsafePersistent is alive or 2) when there is a strong Persistent keeping the | |
| 16 // memory alive while the UnsafePersistent is alive. | |
| 17 template<typename T> class UnsafePersistent { | |
| 18 public: | |
| 19 UnsafePersistent() : value_(0) { } | |
| 20 | |
| 21 explicit UnsafePersistent(v8::Persistent<T>* handle) { | |
| 22 value_ = handle->ClearAndLeak(); | |
| 23 } | |
| 24 | |
| 25 UnsafePersistent(v8::Isolate* isolate, const v8::Handle<T>& handle) { | |
| 26 v8::Persistent<T> persistent(isolate, handle); | |
| 27 value_ = persistent.ClearAndLeak(); | |
| 28 } | |
| 29 | |
| 30 // Usage of this function requires | |
| 31 // V8_ALLOW_ACCESS_TO_RAW_HANDLE_CONSTRUCTOR to be defined | |
| 32 void Dispose() { | |
| 33 v8::Persistent<T> handle(value_); | |
| 34 handle.Reset(); | |
| 35 value_ = 0; | |
| 36 } | |
| 37 | |
| 38 // Usage of this function requires | |
| 39 // V8_ALLOW_ACCESS_TO_RAW_HANDLE_CONSTRUCTOR to be defined | |
| 40 v8::Local<T> NewLocal(v8::Isolate* isolate) { | |
| 41 return v8::Local<T>::New(isolate, v8::Local<T>(value_)); | |
| 42 } | |
| 43 | |
| 44 private: | |
| 45 T* value_; | |
| 46 }; | |
| 47 | |
| 48 } // namespace content | |
| 49 | |
| 50 #endif // CONTENT_SHELL_RENDERER_TEST_RUNNER_UNSAFE_PERSISTENT_H_ | |
| OLD | NEW |