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

Side by Side Diff: fpdfsdk/fpdfxfa/cpdfxfa_app.cpp

Issue 2418653003: Reland: Make the CPDFXFA_App non-global (Closed)
Patch Set: Dispose of the isolate Created 4 years, 2 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 | « fpdfsdk/fpdfxfa/cpdfxfa_app.h ('k') | fpdfsdk/fpdfxfa/cpdfxfa_document.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 2014 PDFium Authors. All rights reserved. 1 // Copyright 2014 PDFium 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 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com 5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com
6 6
7 #include "fpdfsdk/fpdfxfa/cpdfxfa_app.h" 7 #include "fpdfsdk/fpdfxfa/cpdfxfa_app.h"
8 8
9 #include <memory> 9 #include <memory>
10 10
11 #include "fpdfsdk/cpdfsdk_formfillenvironment.h" 11 #include "fpdfsdk/cpdfsdk_formfillenvironment.h"
12 #include "fpdfsdk/fpdfxfa/cxfa_fwladaptertimermgr.h" 12 #include "fpdfsdk/fpdfxfa/cxfa_fwladaptertimermgr.h"
13 #include "fpdfsdk/fsdk_define.h" 13 #include "fpdfsdk/fsdk_define.h"
14 #include "fxjs/fxjs_v8.h"
14 #include "third_party/base/ptr_util.h" 15 #include "third_party/base/ptr_util.h"
15 #include "xfa/fxbarcode/BC_Library.h"
16 #include "xfa/fxfa/xfa_ffapp.h" 16 #include "xfa/fxfa/xfa_ffapp.h"
17 #include "xfa/fxfa/xfa_fontmgr.h" 17 #include "xfa/fxfa/xfa_fontmgr.h"
18 18
19 namespace { 19 CPDFXFA_App::CPDFXFA_App() : m_pIsolate(nullptr) {
20 m_bOwnsIsolate = FXJS_GetIsolate(&m_pIsolate);
Tom Sepez 2016/10/13 20:01:33 thinking more about this ... Can we now call CJS_
20 21
21 CPDFXFA_App* g_pApp = nullptr; 22 m_pXFAApp = pdfium::MakeUnique<CXFA_FFApp>(this);
22 23 m_pXFAApp->SetDefaultFontMgr(pdfium::MakeUnique<CXFA_DefFontMgr>());
23 } // namespace
24
25 CPDFXFA_App* CPDFXFA_App::GetInstance() {
26 if (!g_pApp) {
27 g_pApp = new CPDFXFA_App();
28 }
29 return g_pApp;
30 }
31
32 void CPDFXFA_App::ReleaseInstance() {
33 delete g_pApp;
34 g_pApp = nullptr;
35 }
36
37 CPDFXFA_App::CPDFXFA_App()
38 : m_bJavaScriptInitialized(FALSE), m_pIsolate(nullptr) {
39 m_pFormFillEnvList.RemoveAll();
40 } 24 }
41 25
42 CPDFXFA_App::~CPDFXFA_App() { 26 CPDFXFA_App::~CPDFXFA_App() {
43 FXJSE_Runtime_Release(m_pIsolate); 27 if (m_bOwnsIsolate)
44 m_pIsolate = nullptr; 28 m_pIsolate->Dispose();
45
46 FXJSE_Finalize();
47 BC_Library_Destory();
48 }
49
50 FX_BOOL CPDFXFA_App::Initialize(v8::Isolate* pIsolate) {
51 BC_Library_Init();
52 FXJSE_Initialize();
53
54 m_pIsolate = pIsolate ? pIsolate : FXJSE_Runtime_Create_Own();
55 if (!m_pIsolate)
56 return FALSE;
57
58 m_pXFAApp = pdfium::MakeUnique<CXFA_FFApp>(this);
59 m_pXFAApp->SetDefaultFontMgr(
60 std::unique_ptr<CXFA_DefFontMgr>(new CXFA_DefFontMgr));
61
62 return TRUE;
63 }
64
65 FX_BOOL CPDFXFA_App::AddFormFillEnv(CPDFSDK_FormFillEnvironment* pFormFillEnv) {
66 if (!pFormFillEnv)
67 return FALSE;
68
69 m_pFormFillEnvList.Add(pFormFillEnv);
70 return TRUE;
71 }
72
73 FX_BOOL CPDFXFA_App::RemoveFormFillEnv(
74 CPDFSDK_FormFillEnvironment* pFormFillEnv) {
75 if (!pFormFillEnv)
76 return FALSE;
77
78 int nFind = m_pFormFillEnvList.Find(pFormFillEnv);
79 if (nFind != -1) {
80 m_pFormFillEnvList.RemoveAt(nFind);
81 return TRUE;
82 }
83
84 return FALSE;
85 } 29 }
86 30
87 void CPDFXFA_App::GetAppName(CFX_WideString& wsName) { 31 void CPDFXFA_App::GetAppName(CFX_WideString& wsName) {
88 CPDFSDK_FormFillEnvironment* pFormFillEnv = m_pFormFillEnvList.GetAt(0); 32 if (m_pFormFillEnv)
89 if (pFormFillEnv) 33 wsName = m_pFormFillEnv->FFI_GetAppName();
90 wsName = pFormFillEnv->FFI_GetAppName();
91 } 34 }
92 35
93 void CPDFXFA_App::GetLanguage(CFX_WideString& wsLanguage) { 36 void CPDFXFA_App::GetLanguage(CFX_WideString& wsLanguage) {
94 CPDFSDK_FormFillEnvironment* pFormFillEnv = m_pFormFillEnvList.GetAt(0); 37 if (m_pFormFillEnv)
95 if (pFormFillEnv) 38 wsLanguage = m_pFormFillEnv->GetLanguage();
96 wsLanguage = pFormFillEnv->GetLanguage();
97 } 39 }
98 40
99 void CPDFXFA_App::GetPlatform(CFX_WideString& wsPlatform) { 41 void CPDFXFA_App::GetPlatform(CFX_WideString& wsPlatform) {
100 CPDFSDK_FormFillEnvironment* pFormFillEnv = m_pFormFillEnvList.GetAt(0); 42 if (m_pFormFillEnv) {
101 if (pFormFillEnv) { 43 wsPlatform = m_pFormFillEnv->GetPlatform();
102 wsPlatform = pFormFillEnv->GetPlatform();
103 } 44 }
104 } 45 }
105 46
106 void CPDFXFA_App::Beep(uint32_t dwType) { 47 void CPDFXFA_App::Beep(uint32_t dwType) {
107 CPDFSDK_FormFillEnvironment* pFormFillEnv = m_pFormFillEnvList.GetAt(0); 48 if (m_pFormFillEnv)
108 if (pFormFillEnv) 49 m_pFormFillEnv->JS_appBeep(dwType);
109 pFormFillEnv->JS_appBeep(dwType);
110 } 50 }
111 51
112 int32_t CPDFXFA_App::MsgBox(const CFX_WideString& wsMessage, 52 int32_t CPDFXFA_App::MsgBox(const CFX_WideString& wsMessage,
113 const CFX_WideString& wsTitle, 53 const CFX_WideString& wsTitle,
114 uint32_t dwIconType, 54 uint32_t dwIconType,
115 uint32_t dwButtonType) { 55 uint32_t dwButtonType) {
116 CPDFSDK_FormFillEnvironment* pFormFillEnv = m_pFormFillEnvList.GetAt(0); 56 if (!m_pFormFillEnv)
117 if (!pFormFillEnv)
118 return -1; 57 return -1;
119 58
120 uint32_t iconType = 0; 59 uint32_t iconType = 0;
121 int iButtonType = 0; 60 int iButtonType = 0;
122 switch (dwIconType) { 61 switch (dwIconType) {
123 case XFA_MBICON_Error: 62 case XFA_MBICON_Error:
124 iconType |= 0; 63 iconType |= 0;
125 break; 64 break;
126 case XFA_MBICON_Warning: 65 case XFA_MBICON_Warning:
127 iconType |= 1; 66 iconType |= 1;
(...skipping 12 matching lines...) Expand all
140 case XFA_MB_OKCancel: 79 case XFA_MB_OKCancel:
141 iButtonType |= 1; 80 iButtonType |= 1;
142 break; 81 break;
143 case XFA_MB_YesNo: 82 case XFA_MB_YesNo:
144 iButtonType |= 2; 83 iButtonType |= 2;
145 break; 84 break;
146 case XFA_MB_YesNoCancel: 85 case XFA_MB_YesNoCancel:
147 iButtonType |= 3; 86 iButtonType |= 3;
148 break; 87 break;
149 } 88 }
150 int32_t iRet = pFormFillEnv->JS_appAlert(wsMessage.c_str(), wsTitle.c_str(), 89 int32_t iRet = m_pFormFillEnv->JS_appAlert(wsMessage.c_str(), wsTitle.c_str(),
151 iButtonType, iconType); 90 iButtonType, iconType);
152 switch (iRet) { 91 switch (iRet) {
153 case 1: 92 case 1:
154 return XFA_IDOK; 93 return XFA_IDOK;
155 case 2: 94 case 2:
156 return XFA_IDCancel; 95 return XFA_IDCancel;
157 case 3: 96 case 3:
158 return XFA_IDNo; 97 return XFA_IDNo;
159 case 4: 98 case 4:
160 return XFA_IDYes; 99 return XFA_IDYes;
161 } 100 }
162 return XFA_IDYes; 101 return XFA_IDYes;
163 } 102 }
164 103
165 CFX_WideString CPDFXFA_App::Response(const CFX_WideString& wsQuestion, 104 CFX_WideString CPDFXFA_App::Response(const CFX_WideString& wsQuestion,
166 const CFX_WideString& wsTitle, 105 const CFX_WideString& wsTitle,
167 const CFX_WideString& wsDefaultAnswer, 106 const CFX_WideString& wsDefaultAnswer,
168 FX_BOOL bMark) { 107 FX_BOOL bMark) {
169 CFX_WideString wsAnswer; 108 CFX_WideString wsAnswer;
170 CPDFSDK_FormFillEnvironment* pFormFillEnv = m_pFormFillEnvList.GetAt(0); 109 if (!m_pFormFillEnv)
171 if (pFormFillEnv) { 110 return wsAnswer;
172 int nLength = 2048; 111
173 char* pBuff = new char[nLength]; 112 int nLength = 2048;
174 nLength = pFormFillEnv->JS_appResponse(wsQuestion.c_str(), wsTitle.c_str(), 113 char* pBuff = new char[nLength];
114 nLength = m_pFormFillEnv->JS_appResponse(wsQuestion.c_str(), wsTitle.c_str(),
175 wsDefaultAnswer.c_str(), nullptr, 115 wsDefaultAnswer.c_str(), nullptr,
176 bMark, pBuff, nLength); 116 bMark, pBuff, nLength);
177 if (nLength > 0) { 117 if (nLength > 0) {
178 nLength = nLength > 2046 ? 2046 : nLength; 118 nLength = nLength > 2046 ? 2046 : nLength;
179 pBuff[nLength] = 0; 119 pBuff[nLength] = 0;
180 pBuff[nLength + 1] = 0; 120 pBuff[nLength + 1] = 0;
181 wsAnswer = CFX_WideString::FromUTF16LE( 121 wsAnswer = CFX_WideString::FromUTF16LE(
182 reinterpret_cast<const unsigned short*>(pBuff), 122 reinterpret_cast<const unsigned short*>(pBuff),
183 nLength / sizeof(unsigned short)); 123 nLength / sizeof(unsigned short));
184 }
185 delete[] pBuff;
186 } 124 }
125 delete[] pBuff;
187 return wsAnswer; 126 return wsAnswer;
188 } 127 }
189 128
190 IFX_FileRead* CPDFXFA_App::DownloadURL(const CFX_WideString& wsURL) { 129 IFX_FileRead* CPDFXFA_App::DownloadURL(const CFX_WideString& wsURL) {
191 CPDFSDK_FormFillEnvironment* pFormFillEnv = m_pFormFillEnvList.GetAt(0); 130 return m_pFormFillEnv ? m_pFormFillEnv->DownloadFromURL(wsURL.c_str())
192 return pFormFillEnv ? pFormFillEnv->DownloadFromURL(wsURL.c_str()) : nullptr; 131 : nullptr;
193 } 132 }
194 133
195 FX_BOOL CPDFXFA_App::PostRequestURL(const CFX_WideString& wsURL, 134 FX_BOOL CPDFXFA_App::PostRequestURL(const CFX_WideString& wsURL,
196 const CFX_WideString& wsData, 135 const CFX_WideString& wsData,
197 const CFX_WideString& wsContentType, 136 const CFX_WideString& wsContentType,
198 const CFX_WideString& wsEncode, 137 const CFX_WideString& wsEncode,
199 const CFX_WideString& wsHeader, 138 const CFX_WideString& wsHeader,
200 CFX_WideString& wsResponse) { 139 CFX_WideString& wsResponse) {
201 CPDFSDK_FormFillEnvironment* pFormFillEnv = m_pFormFillEnvList.GetAt(0); 140 if (!m_pFormFillEnv)
202 if (!pFormFillEnv)
203 return FALSE; 141 return FALSE;
204 142
205 wsResponse = pFormFillEnv->PostRequestURL(wsURL.c_str(), wsData.c_str(), 143 wsResponse = m_pFormFillEnv->PostRequestURL(
206 wsContentType.c_str(), 144 wsURL.c_str(), wsData.c_str(), wsContentType.c_str(), wsEncode.c_str(),
207 wsEncode.c_str(), wsHeader.c_str()); 145 wsHeader.c_str());
208 return TRUE; 146 return TRUE;
209 } 147 }
210 148
211 FX_BOOL CPDFXFA_App::PutRequestURL(const CFX_WideString& wsURL, 149 FX_BOOL CPDFXFA_App::PutRequestURL(const CFX_WideString& wsURL,
212 const CFX_WideString& wsData, 150 const CFX_WideString& wsData,
213 const CFX_WideString& wsEncode) { 151 const CFX_WideString& wsEncode) {
214 CPDFSDK_FormFillEnvironment* pFormFillEnv = m_pFormFillEnvList.GetAt(0); 152 return m_pFormFillEnv &&
215 return pFormFillEnv && 153 m_pFormFillEnv->PutRequestURL(wsURL.c_str(), wsData.c_str(),
216 pFormFillEnv->PutRequestURL(wsURL.c_str(), wsData.c_str(), 154 wsEncode.c_str());
217 wsEncode.c_str());
218 } 155 }
219 156
220 void CPDFXFA_App::LoadString(int32_t iStringID, CFX_WideString& wsString) { 157 void CPDFXFA_App::LoadString(int32_t iStringID, CFX_WideString& wsString) {
221 switch (iStringID) { 158 switch (iStringID) {
222 case XFA_IDS_ValidateFailed: 159 case XFA_IDS_ValidateFailed:
223 wsString = L"%s validation failed"; 160 wsString = L"%s validation failed";
224 return; 161 return;
225 case XFA_IDS_CalcOverride: 162 case XFA_IDS_CalcOverride:
226 wsString = L"Calculate Override"; 163 wsString = L"Calculate Override";
227 return; 164 return;
(...skipping 81 matching lines...) Expand 10 before | Expand all | Expand 10 after
309 L"%s, click Ignore."; 246 L"%s, click Ignore.";
310 return; 247 return;
311 case XFA_IDS_ValidateError: 248 case XFA_IDS_ValidateError:
312 wsString = L"The value you entered for %s is invalid."; 249 wsString = L"The value you entered for %s is invalid.";
313 return; 250 return;
314 } 251 }
315 } 252 }
316 253
317 IFWL_AdapterTimerMgr* CPDFXFA_App::GetTimerMgr() { 254 IFWL_AdapterTimerMgr* CPDFXFA_App::GetTimerMgr() {
318 CXFA_FWLAdapterTimerMgr* pAdapter = nullptr; 255 CXFA_FWLAdapterTimerMgr* pAdapter = nullptr;
319 CPDFSDK_FormFillEnvironment* pFormFillEnv = m_pFormFillEnvList.GetAt(0); 256 if (m_pFormFillEnv)
320 if (pFormFillEnv) 257 pAdapter = new CXFA_FWLAdapterTimerMgr(m_pFormFillEnv);
321 pAdapter = new CXFA_FWLAdapterTimerMgr(pFormFillEnv);
322 return pAdapter; 258 return pAdapter;
323 } 259 }
OLDNEW
« no previous file with comments | « fpdfsdk/fpdfxfa/cpdfxfa_app.h ('k') | fpdfsdk/fpdfxfa/cpdfxfa_document.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698