Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(63)

Side by Side Diff: gin/isolate_holder.cc

Issue 553903003: Refactor IsolateHolder to be able to always create the isolate (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: updates Created 6 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « gin/array_buffer.h ('k') | gin/public/isolate_holder.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "gin/public/isolate_holder.h" 5 #include "gin/public/isolate_holder.h"
6 6
7 #include <stdlib.h> 7 #include <stdlib.h>
8 #include <string.h> 8 #include <string.h>
9 9
10 #include "base/logging.h" 10 #include "base/logging.h"
11 #include "base/rand_util.h" 11 #include "base/rand_util.h"
12 #include "base/sys_info.h" 12 #include "base/sys_info.h"
13 #include "gin/array_buffer.h" 13 #include "gin/array_buffer.h"
14 #include "gin/function_template.h" 14 #include "gin/function_template.h"
15 #include "gin/per_isolate_data.h" 15 #include "gin/per_isolate_data.h"
16 #include "gin/public/v8_platform.h" 16 #include "gin/public/v8_platform.h"
17 17
18 namespace gin { 18 namespace gin {
19 19
20 namespace { 20 namespace {
21 21
22 bool GenerateEntropy(unsigned char* buffer, size_t amount) { 22 bool GenerateEntropy(unsigned char* buffer, size_t amount) {
23 base::RandBytes(buffer, amount); 23 base::RandBytes(buffer, amount);
24 return true; 24 return true;
25 } 25 }
26 26
27 void EnsureV8Initialized(gin::IsolateHolder::ScriptMode mode, 27 void EnsureV8Initialized(bool gin_managed) {
28 bool gin_managed) {
29 static bool v8_is_initialized = false; 28 static bool v8_is_initialized = false;
30 static bool v8_is_gin_managed = false; 29 static bool v8_is_gin_managed = false;
31 if (v8_is_initialized) { 30 if (v8_is_initialized) {
32 CHECK_EQ(v8_is_gin_managed, gin_managed); 31 CHECK_EQ(v8_is_gin_managed, gin_managed);
33 return; 32 return;
34 } 33 }
35 v8_is_initialized = true; 34 v8_is_initialized = true;
36 v8_is_gin_managed = gin_managed; 35 v8_is_gin_managed = gin_managed;
37 if (!gin_managed)
38 return;
39
40 v8::V8::InitializePlatform(V8Platform::Get());
41 v8::V8::SetArrayBufferAllocator(ArrayBufferAllocator::SharedInstance());
42 if (mode == gin::IsolateHolder::kStrictMode) {
43 static const char v8_flags[] = "--use_strict";
44 v8::V8::SetFlagsFromString(v8_flags, sizeof(v8_flags) - 1);
45 }
46 v8::V8::SetEntropySource(&GenerateEntropy);
47 v8::V8::Initialize();
48 } 36 }
49 37
50 } // namespace 38 } // namespace
51 39
52 IsolateHolder::IsolateHolder(ScriptMode mode) 40 IsolateHolder::IsolateHolder()
53 : isolate_owner_(true) { 41 : isolate_owner_(true) {
54 EnsureV8Initialized(mode, true); 42 EnsureV8Initialized(true);
55 isolate_ = v8::Isolate::New(); 43 isolate_ = v8::Isolate::New();
56 v8::ResourceConstraints constraints; 44 v8::ResourceConstraints constraints;
57 constraints.ConfigureDefaults(base::SysInfo::AmountOfPhysicalMemory(), 45 constraints.ConfigureDefaults(base::SysInfo::AmountOfPhysicalMemory(),
58 base::SysInfo::AmountOfVirtualMemory(), 46 base::SysInfo::AmountOfVirtualMemory(),
59 base::SysInfo::NumberOfProcessors()); 47 base::SysInfo::NumberOfProcessors());
60 v8::SetResourceConstraints(isolate_, &constraints); 48 v8::SetResourceConstraints(isolate_, &constraints);
61 Init(ArrayBufferAllocator::SharedInstance()); 49 Init(ArrayBufferAllocator::SharedInstance());
62 } 50 }
63 51
64 IsolateHolder::IsolateHolder(v8::Isolate* isolate, 52 IsolateHolder::IsolateHolder(v8::Isolate* isolate,
65 v8::ArrayBuffer::Allocator* allocator) 53 v8::ArrayBuffer::Allocator* allocator)
66 : isolate_owner_(false), isolate_(isolate) { 54 : isolate_owner_(false), isolate_(isolate) {
67 EnsureV8Initialized(kNonStrictMode, false); 55 EnsureV8Initialized(false);
68 Init(allocator); 56 Init(allocator);
69 } 57 }
70 58
71 IsolateHolder::~IsolateHolder() { 59 IsolateHolder::~IsolateHolder() {
72 isolate_data_.reset(); 60 isolate_data_.reset();
73 if (isolate_owner_) 61 if (isolate_owner_)
74 isolate_->Dispose(); 62 isolate_->Dispose();
75 } 63 }
76 64
65 // static
66 void IsolateHolder::Initialize(ScriptMode mode,
67 v8::ArrayBuffer::Allocator* allocator) {
68 static bool v8_is_initialized = false;
69 if (v8_is_initialized)
70 return;
71 v8::V8::InitializePlatform(V8Platform::Get());
72 v8::V8::SetArrayBufferAllocator(allocator);
73 if (mode == gin::IsolateHolder::kStrictMode) {
74 static const char v8_flags[] = "--use_strict";
75 v8::V8::SetFlagsFromString(v8_flags, sizeof(v8_flags) - 1);
76 }
77 v8::V8::SetEntropySource(&GenerateEntropy);
78 v8::V8::Initialize();
79 v8_is_initialized = true;
80 }
81
77 void IsolateHolder::Init(v8::ArrayBuffer::Allocator* allocator) { 82 void IsolateHolder::Init(v8::ArrayBuffer::Allocator* allocator) {
78 v8::Isolate::Scope isolate_scope(isolate_); 83 v8::Isolate::Scope isolate_scope(isolate_);
79 v8::HandleScope handle_scope(isolate_); 84 v8::HandleScope handle_scope(isolate_);
80 isolate_data_.reset(new PerIsolateData(isolate_, allocator)); 85 isolate_data_.reset(new PerIsolateData(isolate_, allocator));
81 } 86 }
82 87
83 } // namespace gin 88 } // namespace gin
OLDNEW
« no previous file with comments | « gin/array_buffer.h ('k') | gin/public/isolate_holder.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698