OLD | NEW |
---|---|
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2010 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 "pdf/pdf.h" | 5 #include "pdf/pdf.h" |
6 | 6 |
7 #if defined(OS_WIN) | 7 #if defined(OS_WIN) |
8 #include <windows.h> | 8 #include <windows.h> |
9 #endif | 9 #endif |
10 | 10 |
11 #include "base/command_line.h" | 11 #include "base/command_line.h" |
12 #include "base/logging.h" | 12 #include "base/logging.h" |
13 #include "gin/array_buffer.h" | |
14 #include "gin/public/isolate_holder.h" | |
13 #include "pdf/out_of_process_instance.h" | 15 #include "pdf/out_of_process_instance.h" |
14 #include "ppapi/c/ppp.h" | 16 #include "ppapi/c/ppp.h" |
15 #include "ppapi/cpp/private/internal_module.h" | 17 #include "ppapi/cpp/private/internal_module.h" |
16 #include "ppapi/cpp/private/pdf.h" | 18 #include "ppapi/cpp/private/pdf.h" |
17 #include "v8/include/v8.h" | 19 #include "v8/include/v8.h" |
18 | 20 |
19 bool g_sdk_initialized_via_pepper = false; | 21 bool g_sdk_initialized_via_pepper = false; |
20 | 22 |
23 gin::IsolateHolder* g_isolate_holder = nullptr; | |
24 | |
21 namespace chrome_pdf { | 25 namespace chrome_pdf { |
22 | 26 |
23 PDFModule::PDFModule() { | 27 PDFModule::PDFModule() { |
24 } | 28 } |
25 | 29 |
26 PDFModule::~PDFModule() { | 30 PDFModule::~PDFModule() { |
27 if (g_sdk_initialized_via_pepper) { | 31 if (g_sdk_initialized_via_pepper) { |
28 chrome_pdf::ShutdownSDK(); | 32 chrome_pdf::ShutdownSDK(); |
33 if (g_sdk_initialized_via_pepper) { | |
Lei Zhang
2015/09/16 21:22:24
Didn't we just check |g_sdk_initialized_via_pepper
jochen (gone - plz use gerrit)
2015/09/17 06:55:07
done
| |
34 g_isolate_holder->isolate()->Exit(); | |
35 delete g_isolate_holder; | |
36 g_isolate_holder = nullptr; | |
37 } | |
29 g_sdk_initialized_via_pepper = false; | 38 g_sdk_initialized_via_pepper = false; |
30 } | 39 } |
31 } | 40 } |
32 | 41 |
33 bool PDFModule::Init() { | 42 bool PDFModule::Init() { |
34 return true; | 43 return true; |
35 } | 44 } |
36 | 45 |
37 pp::Instance* PDFModule::CreateInstance(PP_Instance instance) { | 46 pp::Instance* PDFModule::CreateInstance(PP_Instance instance) { |
38 if (!g_sdk_initialized_via_pepper) { | 47 if (!g_sdk_initialized_via_pepper) { |
39 v8::StartupData natives; | 48 v8::StartupData natives; |
40 v8::StartupData snapshot; | 49 v8::StartupData snapshot; |
41 pp::PDF::GetV8ExternalSnapshotData(pp::InstanceHandle(instance), | 50 pp::PDF::GetV8ExternalSnapshotData(pp::InstanceHandle(instance), |
42 &natives.data, &natives.raw_size, | 51 &natives.data, &natives.raw_size, |
43 &snapshot.data, &snapshot.raw_size); | 52 &snapshot.data, &snapshot.raw_size); |
44 if (natives.data) { | 53 if (natives.data) { |
45 v8::V8::SetNativesDataBlob(&natives); | 54 v8::V8::SetNativesDataBlob(&natives); |
46 v8::V8::SetSnapshotDataBlob(&snapshot); | 55 v8::V8::SetSnapshotDataBlob(&snapshot); |
47 } | 56 } |
48 if (!chrome_pdf::InitializeSDK()) | 57 gin::IsolateHolder::Initialize(gin::IsolateHolder::kNonStrictMode, |
58 gin::ArrayBufferAllocator::SharedInstance()); | |
59 g_isolate_holder = | |
Lei Zhang
2015/09/16 21:22:24
CreateInstance() only gets called once per process
raymes
2015/09/17 02:30:41
I believe CreateInstance will get called multiple
jochen (gone - plz use gerrit)
2015/09/17 06:55:07
this block is protected by !g_sdk_initialized_via_
| |
60 new gin::IsolateHolder(gin::IsolateHolder::kSingleThread); | |
61 g_isolate_holder->isolate()->Enter(); | |
raymes
2015/09/17 02:30:41
nit: indentation looks funny here.
jochen (gone - plz use gerrit)
2015/09/17 06:55:07
done
| |
62 if (!chrome_pdf::InitializeSDK()) { | |
63 g_isolate_holder->isolate()->Exit(); | |
Lei Zhang
2015/09/16 21:22:24
Write a function for these 3 lines? Then reused on
jochen (gone - plz use gerrit)
2015/09/17 06:55:07
done
| |
64 delete g_isolate_holder; | |
65 g_isolate_holder = nullptr; | |
49 return NULL; | 66 return NULL; |
67 } | |
50 g_sdk_initialized_via_pepper = true; | 68 g_sdk_initialized_via_pepper = true; |
51 } | 69 } |
52 | 70 |
53 return new OutOfProcessInstance(instance); | 71 return new OutOfProcessInstance(instance); |
54 } | 72 } |
55 | 73 |
56 | 74 |
57 // Implementation of Global PPP functions --------------------------------- | 75 // Implementation of Global PPP functions --------------------------------- |
58 int32_t PPP_InitializeModule(PP_Module module_id, | 76 int32_t PPP_InitializeModule(PP_Module module_id, |
59 PPB_GetInterface get_browser_interface) { | 77 PPB_GetInterface get_browser_interface) { |
(...skipping 107 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
167 autorotate); | 185 autorotate); |
168 bool ret = engine_exports->RenderPDFPageToBitmap( | 186 bool ret = engine_exports->RenderPDFPageToBitmap( |
169 pdf_buffer, pdf_buffer_size, page_number, settings, bitmap_buffer); | 187 pdf_buffer, pdf_buffer_size, page_number, settings, bitmap_buffer); |
170 if (!g_sdk_initialized_via_pepper) { | 188 if (!g_sdk_initialized_via_pepper) { |
171 chrome_pdf::ShutdownSDK(); | 189 chrome_pdf::ShutdownSDK(); |
172 } | 190 } |
173 return ret; | 191 return ret; |
174 } | 192 } |
175 | 193 |
176 } // namespace chrome_pdf | 194 } // namespace chrome_pdf |
OLD | NEW |