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

Side by Side Diff: fpdfsdk/formfiller/cffl_combobox.cpp

Issue 2266943002: Destroy window before cleaning up combobox (Closed) Base URL: https://pdfium.googlesource.com/pdfium.git@master
Patch Set: Update textfield Created 4 years, 4 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 | « no previous file | fpdfsdk/formfiller/cffl_formfiller.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/formfiller/cffl_combobox.h" 7 #include "fpdfsdk/formfiller/cffl_combobox.h"
8 8
9 #include "fpdfsdk/formfiller/cba_fontmap.h" 9 #include "fpdfsdk/formfiller/cba_fontmap.h"
10 #include "fpdfsdk/formfiller/cffl_formfiller.h" 10 #include "fpdfsdk/formfiller/cffl_formfiller.h"
11 #include "fpdfsdk/formfiller/cffl_iformfiller.h" 11 #include "fpdfsdk/formfiller/cffl_iformfiller.h"
12 #include "fpdfsdk/include/cpdfsdk_widget.h" 12 #include "fpdfsdk/include/cpdfsdk_widget.h"
13 #include "fpdfsdk/include/fsdk_common.h" 13 #include "fpdfsdk/include/fsdk_common.h"
14 #include "fpdfsdk/include/fsdk_mgr.h" 14 #include "fpdfsdk/include/fsdk_mgr.h"
15 #include "fpdfsdk/pdfwindow/PWL_ComboBox.h" 15 #include "fpdfsdk/pdfwindow/PWL_ComboBox.h"
16 16
17 CFFL_ComboBox::CFFL_ComboBox(CPDFDoc_Environment* pApp, CPDFSDK_Annot* pAnnot) 17 CFFL_ComboBox::CFFL_ComboBox(CPDFDoc_Environment* pApp, CPDFSDK_Annot* pAnnot)
18 : CFFL_FormFiller(pApp, pAnnot), m_pFontMap(nullptr) { 18 : CFFL_FormFiller(pApp, pAnnot), m_pFontMap(nullptr) {
19 m_State.nIndex = 0; 19 m_State.nIndex = 0;
20 m_State.nStart = 0; 20 m_State.nStart = 0;
21 m_State.nEnd = 0; 21 m_State.nEnd = 0;
22 } 22 }
23 23
24 CFFL_ComboBox::~CFFL_ComboBox() { 24 CFFL_ComboBox::~CFFL_ComboBox() {
25 for (const auto& it : m_Maps) 25 for (const auto& it : m_Maps)
26 it.second->InvalidateFocusHandler(this); 26 it.second->InvalidateFocusHandler(this);
27
28 // See comment in cffl_formfiller.h.
29 // The font map should be stored somewhere more appropriate so it will live
30 // until the PWL_Edit is done with it. pdfium:566
31 DestroyWindows();
27 delete m_pFontMap; 32 delete m_pFontMap;
28 } 33 }
29 34
30 PWL_CREATEPARAM CFFL_ComboBox::GetCreateParam() { 35 PWL_CREATEPARAM CFFL_ComboBox::GetCreateParam() {
31 PWL_CREATEPARAM cp = CFFL_FormFiller::GetCreateParam(); 36 PWL_CREATEPARAM cp = CFFL_FormFiller::GetCreateParam();
32 37
33 int nFlags = m_pWidget->GetFieldFlags(); 38 int nFlags = m_pWidget->GetFieldFlags();
34 if (nFlags & FIELDFLAG_EDIT) { 39 if (nFlags & FIELDFLAG_EDIT) {
35 cp.dwFlags |= PCBS_ALLOWCUSTOMTEXT; 40 cp.dwFlags |= PCBS_ALLOWCUSTOMTEXT;
36 } 41 }
(...skipping 247 matching lines...) Expand 10 before | Expand all | Expand 10 after
284 if (nExport >= 0) { 289 if (nExport >= 0) {
285 if (CPDF_FormField* pFormField = m_pWidget->GetFormField()) { 290 if (CPDF_FormField* pFormField = m_pWidget->GetFormField()) {
286 swRet = pFormField->GetOptionValue(nExport); 291 swRet = pFormField->GetOptionValue(nExport);
287 if (swRet.IsEmpty()) 292 if (swRet.IsEmpty())
288 swRet = pFormField->GetOptionLabel(nExport); 293 swRet = pFormField->GetOptionLabel(nExport);
289 } 294 }
290 } 295 }
291 296
292 return swRet; 297 return swRet;
293 } 298 }
OLDNEW
« no previous file with comments | « no previous file | fpdfsdk/formfiller/cffl_formfiller.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698