// Copyright 2013 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #ifndef GIN_PUBLIC_ISOLATE_HOLDER_H_ #define GIN_PUBLIC_ISOLATE_HOLDER_H_ #include "base/basictypes.h" #include "base/memory/scoped_ptr.h" #include "gin/gin_export.h" #include "v8/include/v8.h" namespace gin { class PerIsolateData; // To embed Gin, first create an instance of IsolateHolder to hold the // v8::Isolate in which you will execute JavaScript. You might wish to subclass // IsolateHolder if you want to tie more state to the lifetime of the isolate. // // You can use gin in two modes: either gin manages V8, or the gin-embedder // manages gin. If gin manages V8, use the IsolateHolder constructor that does // not take an v8::Isolate parameter, otherwise, the gin-embedder needs to // create v8::Isolates and pass them to IsolateHolder. // // It is not possible to mix the two. class GIN_EXPORT IsolateHolder { public: // Controls whether or not V8 should only accept strict mode scripts. enum ScriptMode { kNonStrictMode, kStrictMode }; explicit IsolateHolder(ScriptMode mode); IsolateHolder(v8::Isolate* isolate, v8::ArrayBuffer::Allocator* allocator); ~IsolateHolder(); v8::Isolate* isolate() { return isolate_; } private: void Init(v8::ArrayBuffer::Allocator* allocator); bool isolate_owner_; v8::Isolate* isolate_; scoped_ptr isolate_data_; DISALLOW_COPY_AND_ASSIGN(IsolateHolder); }; } // namespace gin #endif // GIN_PUBLIC_ISOLATE_HOLDER_H_