Index: fpdfsdk/src/formfiller/FFL_TextField.cpp |
diff --git a/fpdfsdk/src/formfiller/FFL_TextField.cpp b/fpdfsdk/src/formfiller/FFL_TextField.cpp |
index a4b87263ed6521edd40b01d326c368a5e2b3c17c..2acf6b8fda9b4a37f5d0ff86932b9605f861b5ca 100644 |
--- a/fpdfsdk/src/formfiller/FFL_TextField.cpp |
+++ b/fpdfsdk/src/formfiller/FFL_TextField.cpp |
@@ -7,353 +7,302 @@ |
#include "../../include/formfiller/FFL_TextField.h" |
#include "../../include/formfiller/FFL_CBA_Fontmap.h" |
-/* ------------------------------- CFFL_TextField ------------------------------- */ |
+/* ------------------------------- CFFL_TextField |
+ * ------------------------------- */ |
-CFFL_TextField::CFFL_TextField(CPDFDoc_Environment* pApp, CPDFSDK_Annot* pAnnot) : |
- CFFL_FormFiller(pApp, pAnnot), |
- m_pFontMap(NULL)//, |
- //m_pSpellCheck(NULL) |
+CFFL_TextField::CFFL_TextField(CPDFDoc_Environment* pApp, CPDFSDK_Annot* pAnnot) |
+ : CFFL_FormFiller(pApp, pAnnot), |
+ m_pFontMap(NULL) //, |
+// m_pSpellCheck(NULL) |
{ |
- m_State.nStart = m_State.nEnd = 0; |
+ m_State.nStart = m_State.nEnd = 0; |
} |
-CFFL_TextField::~CFFL_TextField() |
-{ |
- delete m_pFontMap; |
+CFFL_TextField::~CFFL_TextField() { |
+ delete m_pFontMap; |
} |
-PWL_CREATEPARAM CFFL_TextField::GetCreateParam() |
-{ |
- PWL_CREATEPARAM cp = CFFL_FormFiller::GetCreateParam(); |
+PWL_CREATEPARAM CFFL_TextField::GetCreateParam() { |
+ PWL_CREATEPARAM cp = CFFL_FormFiller::GetCreateParam(); |
- ASSERT(m_pWidget != NULL); |
- int nFlags = m_pWidget->GetFieldFlags(); |
+ ASSERT(m_pWidget != NULL); |
+ int nFlags = m_pWidget->GetFieldFlags(); |
+ if (nFlags & FIELDFLAG_PASSWORD) { |
+ cp.dwFlags |= PES_PASSWORD; |
+ } |
- if (nFlags & FIELDFLAG_PASSWORD) |
- { |
- cp.dwFlags |= PES_PASSWORD; |
- } |
+ if (!(nFlags & FIELDFLAG_DONOTSPELLCHECK)) { |
+ } |
- if (!(nFlags & FIELDFLAG_DONOTSPELLCHECK)) |
- { |
- } |
+ if (nFlags & FIELDFLAG_MULTILINE) { |
+ cp.dwFlags |= PES_MULTILINE | PES_AUTORETURN | PES_TOP; |
- if (nFlags & FIELDFLAG_MULTILINE) |
- { |
- cp.dwFlags |= PES_MULTILINE | PES_AUTORETURN | PES_TOP; |
- |
- if (!(nFlags & FIELDFLAG_DONOTSCROLL)) |
- { |
- cp.dwFlags |= PWS_VSCROLL | PES_AUTOSCROLL; |
- } |
+ if (!(nFlags & FIELDFLAG_DONOTSCROLL)) { |
+ cp.dwFlags |= PWS_VSCROLL | PES_AUTOSCROLL; |
} |
- else |
- { |
- cp.dwFlags |= PES_CENTER; |
+ } else { |
+ cp.dwFlags |= PES_CENTER; |
- if (!(nFlags & FIELDFLAG_DONOTSCROLL)) |
- { |
- cp.dwFlags |= PES_AUTOSCROLL; |
- } |
+ if (!(nFlags & FIELDFLAG_DONOTSCROLL)) { |
+ cp.dwFlags |= PES_AUTOSCROLL; |
} |
+ } |
- if (nFlags & FIELDFLAG_COMB) |
- { |
- cp.dwFlags |= PES_CHARARRAY; |
- } |
+ if (nFlags & FIELDFLAG_COMB) { |
+ cp.dwFlags |= PES_CHARARRAY; |
+ } |
- if (nFlags & FIELDFLAG_RICHTEXT) |
- { |
- cp.dwFlags |= PES_RICH; |
- } |
+ if (nFlags & FIELDFLAG_RICHTEXT) { |
+ cp.dwFlags |= PES_RICH; |
+ } |
- cp.dwFlags |= PES_UNDO; |
+ cp.dwFlags |= PES_UNDO; |
- switch (m_pWidget->GetAlignment()) |
- { |
+ switch (m_pWidget->GetAlignment()) { |
default: |
case BF_ALIGN_LEFT: |
- cp.dwFlags |= PES_LEFT; |
- break; |
+ cp.dwFlags |= PES_LEFT; |
+ break; |
case BF_ALIGN_MIDDLE: |
- cp.dwFlags |= PES_MIDDLE; |
- break; |
+ cp.dwFlags |= PES_MIDDLE; |
+ break; |
case BF_ALIGN_RIGHT: |
- cp.dwFlags |= PES_RIGHT; |
- break; |
- } |
- |
- if (!m_pFontMap) |
- { |
- m_pFontMap = new CBA_FontMap(m_pWidget, m_pApp->GetSysHandler()); |
- m_pFontMap->Initial(); |
- } |
- cp.pFontMap = m_pFontMap; |
- cp.pFocusHandler = this; |
- |
- return cp; |
+ cp.dwFlags |= PES_RIGHT; |
+ break; |
+ } |
+ |
+ if (!m_pFontMap) { |
+ m_pFontMap = new CBA_FontMap(m_pWidget, m_pApp->GetSysHandler()); |
+ m_pFontMap->Initial(); |
+ } |
+ cp.pFontMap = m_pFontMap; |
+ cp.pFocusHandler = this; |
+ |
+ return cp; |
} |
-CPWL_Wnd* CFFL_TextField::NewPDFWindow(const PWL_CREATEPARAM& cp, CPDFSDK_PageView* pPageView) |
-{ |
- CPWL_Edit * pWnd = new CPWL_Edit(); |
- pWnd->AttachFFLData(this); |
- pWnd->Create(cp); |
- |
- |
- |
- ASSERT(m_pApp != NULL); |
- CFFL_IFormFiller* pIFormFiller = m_pApp->GetIFormFiller(); |
- pWnd->SetFillerNotify(pIFormFiller); |
- |
- ASSERT(m_pWidget != NULL); |
- int32_t nMaxLen = m_pWidget->GetMaxLen(); |
- CFX_WideString swValue = m_pWidget->GetValue(); |
- |
- if (nMaxLen > 0) |
- { |
- if (pWnd->HasFlag(PES_CHARARRAY)) |
- { |
- pWnd->SetCharArray(nMaxLen); |
- pWnd->SetAlignFormatV(PEAV_CENTER); |
- } |
- else |
- { |
- pWnd->SetLimitChar(nMaxLen); |
- } |
+CPWL_Wnd* CFFL_TextField::NewPDFWindow(const PWL_CREATEPARAM& cp, |
+ CPDFSDK_PageView* pPageView) { |
+ CPWL_Edit* pWnd = new CPWL_Edit(); |
+ pWnd->AttachFFLData(this); |
+ pWnd->Create(cp); |
+ |
+ ASSERT(m_pApp != NULL); |
+ CFFL_IFormFiller* pIFormFiller = m_pApp->GetIFormFiller(); |
+ pWnd->SetFillerNotify(pIFormFiller); |
+ |
+ ASSERT(m_pWidget != NULL); |
+ int32_t nMaxLen = m_pWidget->GetMaxLen(); |
+ CFX_WideString swValue = m_pWidget->GetValue(); |
+ |
+ if (nMaxLen > 0) { |
+ if (pWnd->HasFlag(PES_CHARARRAY)) { |
+ pWnd->SetCharArray(nMaxLen); |
+ pWnd->SetAlignFormatV(PEAV_CENTER); |
+ } else { |
+ pWnd->SetLimitChar(nMaxLen); |
} |
+ } |
- pWnd->SetText(swValue.c_str()); |
- return pWnd; |
+ pWnd->SetText(swValue.c_str()); |
+ return pWnd; |
} |
- |
-FX_BOOL CFFL_TextField::OnChar(CPDFSDK_Annot* pAnnot, FX_UINT nChar, FX_UINT nFlags) |
-{ |
- switch (nChar) |
- { |
+FX_BOOL CFFL_TextField::OnChar(CPDFSDK_Annot* pAnnot, |
+ FX_UINT nChar, |
+ FX_UINT nFlags) { |
+ switch (nChar) { |
case FWL_VKEY_Return: |
- if (!(m_pWidget->GetFieldFlags() & FIELDFLAG_MULTILINE)) |
- { |
- CPDFSDK_PageView* pPageView = GetCurPageView(); |
- ASSERT(pPageView != NULL); |
- m_bValid = !m_bValid; |
- CPDF_Rect rcAnnot = pAnnot->GetRect(); |
- m_pApp->FFI_Invalidate(pAnnot->GetPDFPage(), rcAnnot.left, rcAnnot.top, rcAnnot.right, rcAnnot.bottom); |
- |
- if (m_bValid) |
- { |
- if (CPWL_Wnd* pWnd = GetPDFWindow(pPageView, TRUE)) |
- pWnd->SetFocus(); |
- } |
- else |
- { |
- if (CommitData(pPageView, nFlags)) |
- { |
- DestroyPDFWindow(pPageView); |
- return TRUE; |
- } |
- return FALSE; |
- } |
- } |
- break; |
- case FWL_VKEY_Escape: |
- { |
- CPDFSDK_PageView* pPageView = GetCurPageView(); |
- ASSERT(pPageView != NULL); |
- EscapeFiller(pPageView,TRUE); |
+ if (!(m_pWidget->GetFieldFlags() & FIELDFLAG_MULTILINE)) { |
+ CPDFSDK_PageView* pPageView = GetCurPageView(); |
+ ASSERT(pPageView != NULL); |
+ m_bValid = !m_bValid; |
+ CPDF_Rect rcAnnot = pAnnot->GetRect(); |
+ m_pApp->FFI_Invalidate(pAnnot->GetPDFPage(), rcAnnot.left, rcAnnot.top, |
+ rcAnnot.right, rcAnnot.bottom); |
+ |
+ if (m_bValid) { |
+ if (CPWL_Wnd* pWnd = GetPDFWindow(pPageView, TRUE)) |
+ pWnd->SetFocus(); |
+ } else { |
+ if (CommitData(pPageView, nFlags)) { |
+ DestroyPDFWindow(pPageView); |
return TRUE; |
+ } |
+ return FALSE; |
} |
+ } |
+ break; |
+ case FWL_VKEY_Escape: { |
+ CPDFSDK_PageView* pPageView = GetCurPageView(); |
+ ASSERT(pPageView != NULL); |
+ EscapeFiller(pPageView, TRUE); |
+ return TRUE; |
} |
+ } |
- return CFFL_FormFiller::OnChar(pAnnot, nChar, nFlags); |
+ return CFFL_FormFiller::OnChar(pAnnot, nChar, nFlags); |
} |
-FX_BOOL CFFL_TextField::IsDataChanged(CPDFSDK_PageView* pPageView) |
-{ |
- ASSERT(m_pWidget != NULL); |
+FX_BOOL CFFL_TextField::IsDataChanged(CPDFSDK_PageView* pPageView) { |
+ ASSERT(m_pWidget != NULL); |
- if (CPWL_Edit * pEdit = (CPWL_Edit*)GetPDFWindow(pPageView, FALSE)) |
- return pEdit->GetText() != m_pWidget->GetValue(); |
+ if (CPWL_Edit* pEdit = (CPWL_Edit*)GetPDFWindow(pPageView, FALSE)) |
+ return pEdit->GetText() != m_pWidget->GetValue(); |
- return FALSE; |
+ return FALSE; |
} |
-void CFFL_TextField::SaveData(CPDFSDK_PageView* pPageView) |
-{ |
- ASSERT(m_pWidget != NULL); |
+void CFFL_TextField::SaveData(CPDFSDK_PageView* pPageView) { |
+ ASSERT(m_pWidget != NULL); |
- if (CPWL_Edit* pWnd = (CPWL_Edit*)GetPDFWindow(pPageView, FALSE)) |
- { |
- CFX_WideString sOldValue = m_pWidget->GetValue(); |
- CFX_WideString sNewValue = pWnd->GetText(); |
+ if (CPWL_Edit* pWnd = (CPWL_Edit*)GetPDFWindow(pPageView, FALSE)) { |
+ CFX_WideString sOldValue = m_pWidget->GetValue(); |
+ CFX_WideString sNewValue = pWnd->GetText(); |
- m_pWidget->SetValue(sNewValue, FALSE); |
- m_pWidget->ResetFieldAppearance(TRUE); |
- m_pWidget->UpdateField(); |
- SetChangeMark(); |
- } |
+ m_pWidget->SetValue(sNewValue, FALSE); |
+ m_pWidget->ResetFieldAppearance(TRUE); |
+ m_pWidget->UpdateField(); |
+ SetChangeMark(); |
+ } |
} |
-void CFFL_TextField::GetActionData(CPDFSDK_PageView* pPageView, CPDF_AAction::AActionType type, |
- PDFSDK_FieldAction& fa) |
-{ |
- switch (type) |
- { |
+void CFFL_TextField::GetActionData(CPDFSDK_PageView* pPageView, |
+ CPDF_AAction::AActionType type, |
+ PDFSDK_FieldAction& fa) { |
+ switch (type) { |
case CPDF_AAction::KeyStroke: |
- if (CPWL_Edit* pWnd = (CPWL_Edit*)GetPDFWindow(pPageView, FALSE)) |
- { |
- fa.bFieldFull = pWnd->IsTextFull(); |
+ if (CPWL_Edit* pWnd = (CPWL_Edit*)GetPDFWindow(pPageView, FALSE)) { |
+ fa.bFieldFull = pWnd->IsTextFull(); |
- fa.sValue = pWnd->GetText(); |
+ fa.sValue = pWnd->GetText(); |
- if (fa.bFieldFull) |
- { |
- fa.sChange = L""; |
- fa.sChangeEx = L""; |
- } |
+ if (fa.bFieldFull) { |
+ fa.sChange = L""; |
+ fa.sChangeEx = L""; |
} |
- break; |
+ } |
+ break; |
case CPDF_AAction::Validate: |
- if (CPWL_Edit* pWnd = (CPWL_Edit*)GetPDFWindow(pPageView, FALSE)) |
- { |
- fa.sValue = pWnd->GetText(); |
- } |
- break; |
+ if (CPWL_Edit* pWnd = (CPWL_Edit*)GetPDFWindow(pPageView, FALSE)) { |
+ fa.sValue = pWnd->GetText(); |
+ } |
+ break; |
case CPDF_AAction::LoseFocus: |
case CPDF_AAction::GetFocus: |
- ASSERT(m_pWidget != NULL); |
- fa.sValue = m_pWidget->GetValue(); |
- break; |
+ ASSERT(m_pWidget != NULL); |
+ fa.sValue = m_pWidget->GetValue(); |
+ break; |
default: |
- break; |
- } |
+ break; |
+ } |
} |
-void CFFL_TextField::SetActionData(CPDFSDK_PageView* pPageView, CPDF_AAction::AActionType type, |
- const PDFSDK_FieldAction& fa) |
-{ |
- switch (type) |
- { |
+void CFFL_TextField::SetActionData(CPDFSDK_PageView* pPageView, |
+ CPDF_AAction::AActionType type, |
+ const PDFSDK_FieldAction& fa) { |
+ switch (type) { |
case CPDF_AAction::KeyStroke: |
- if (CPWL_Edit * pEdit = (CPWL_Edit*)GetPDFWindow(pPageView, FALSE)) |
- { |
- pEdit->SetFocus(); |
- pEdit->SetSel(fa.nSelStart, fa.nSelEnd); |
- pEdit->ReplaceSel(fa.sChange.c_str()); |
- } |
- break; |
+ if (CPWL_Edit* pEdit = (CPWL_Edit*)GetPDFWindow(pPageView, FALSE)) { |
+ pEdit->SetFocus(); |
+ pEdit->SetSel(fa.nSelStart, fa.nSelEnd); |
+ pEdit->ReplaceSel(fa.sChange.c_str()); |
+ } |
+ break; |
default: |
- break; |
- } |
+ break; |
+ } |
} |
- |
-FX_BOOL CFFL_TextField::IsActionDataChanged(CPDF_AAction::AActionType type, const PDFSDK_FieldAction& faOld, |
- const PDFSDK_FieldAction& faNew) |
-{ |
- switch (type) |
- { |
+FX_BOOL CFFL_TextField::IsActionDataChanged(CPDF_AAction::AActionType type, |
+ const PDFSDK_FieldAction& faOld, |
+ const PDFSDK_FieldAction& faNew) { |
+ switch (type) { |
case CPDF_AAction::KeyStroke: |
- return (!faOld.bFieldFull && faOld.nSelEnd != faNew.nSelEnd) || faOld.nSelStart != faNew.nSelStart || |
- faOld.sChange != faNew.sChange; |
+ return (!faOld.bFieldFull && faOld.nSelEnd != faNew.nSelEnd) || |
+ faOld.nSelStart != faNew.nSelStart || |
+ faOld.sChange != faNew.sChange; |
default: |
- break; |
- } |
+ break; |
+ } |
- return FALSE; |
+ return FALSE; |
} |
-void CFFL_TextField::SaveState(CPDFSDK_PageView* pPageView) |
-{ |
- ASSERT(pPageView != NULL); |
+void CFFL_TextField::SaveState(CPDFSDK_PageView* pPageView) { |
+ ASSERT(pPageView != NULL); |
- if (CPWL_Edit* pWnd = (CPWL_Edit*)GetPDFWindow(pPageView, FALSE)) |
- { |
- pWnd->GetSel(m_State.nStart, m_State.nEnd); |
- m_State.sValue = pWnd->GetText(); |
- } |
+ if (CPWL_Edit* pWnd = (CPWL_Edit*)GetPDFWindow(pPageView, FALSE)) { |
+ pWnd->GetSel(m_State.nStart, m_State.nEnd); |
+ m_State.sValue = pWnd->GetText(); |
+ } |
} |
-void CFFL_TextField::RestoreState(CPDFSDK_PageView* pPageView) |
-{ |
- ASSERT(pPageView != NULL); |
+void CFFL_TextField::RestoreState(CPDFSDK_PageView* pPageView) { |
+ ASSERT(pPageView != NULL); |
- if (CPWL_Edit* pWnd = (CPWL_Edit*)GetPDFWindow(pPageView, TRUE)) |
- { |
- pWnd->SetText(m_State.sValue.c_str()); |
- pWnd->SetSel(m_State.nStart, m_State.nEnd); |
- } |
+ if (CPWL_Edit* pWnd = (CPWL_Edit*)GetPDFWindow(pPageView, TRUE)) { |
+ pWnd->SetText(m_State.sValue.c_str()); |
+ pWnd->SetSel(m_State.nStart, m_State.nEnd); |
+ } |
} |
-CPWL_Wnd* CFFL_TextField::ResetPDFWindow(CPDFSDK_PageView* pPageView, FX_BOOL bRestoreValue) |
-{ |
- if (bRestoreValue) |
- SaveState(pPageView); |
+CPWL_Wnd* CFFL_TextField::ResetPDFWindow(CPDFSDK_PageView* pPageView, |
+ FX_BOOL bRestoreValue) { |
+ if (bRestoreValue) |
+ SaveState(pPageView); |
- DestroyPDFWindow(pPageView); |
+ DestroyPDFWindow(pPageView); |
- CPWL_Wnd* pRet = NULL; |
+ CPWL_Wnd* pRet = NULL; |
- if (bRestoreValue) |
- { |
- RestoreState(pPageView); |
- pRet = GetPDFWindow(pPageView, FALSE); |
- } |
- else |
- pRet = GetPDFWindow(pPageView, TRUE); |
+ if (bRestoreValue) { |
+ RestoreState(pPageView); |
+ pRet = GetPDFWindow(pPageView, FALSE); |
+ } else |
+ pRet = GetPDFWindow(pPageView, TRUE); |
- m_pWidget->UpdateField(); |
+ m_pWidget->UpdateField(); |
- return pRet; |
+ return pRet; |
} |
-void CFFL_TextField::OnSetFocus(CPWL_Wnd* pWnd) |
-{ |
- ASSERT(m_pApp != NULL); |
+void CFFL_TextField::OnSetFocus(CPWL_Wnd* pWnd) { |
+ ASSERT(m_pApp != NULL); |
- ASSERT(pWnd != NULL); |
+ ASSERT(pWnd != NULL); |
- if (pWnd->GetClassName() == PWL_CLASSNAME_EDIT) |
- { |
- CPWL_Edit* pEdit = (CPWL_Edit*)pWnd; |
- pEdit->SetCharSet(134); |
- pEdit->SetCodePage(936); |
+ if (pWnd->GetClassName() == PWL_CLASSNAME_EDIT) { |
+ CPWL_Edit* pEdit = (CPWL_Edit*)pWnd; |
+ pEdit->SetCharSet(134); |
+ pEdit->SetCodePage(936); |
- pEdit->SetReadyToInput(); |
- CFX_WideString wsText = pEdit->GetText(); |
- int nCharacters = wsText.GetLength(); |
- CFX_ByteString bsUTFText = wsText.UTF16LE_Encode(); |
- unsigned short* pBuffer = (unsigned short*)bsUTFText.c_str(); |
- m_pApp->FFI_OnSetFieldInputFocus(m_pWidget->GetFormField(), pBuffer, nCharacters, TRUE); |
+ pEdit->SetReadyToInput(); |
+ CFX_WideString wsText = pEdit->GetText(); |
+ int nCharacters = wsText.GetLength(); |
+ CFX_ByteString bsUTFText = wsText.UTF16LE_Encode(); |
+ unsigned short* pBuffer = (unsigned short*)bsUTFText.c_str(); |
+ m_pApp->FFI_OnSetFieldInputFocus(m_pWidget->GetFormField(), pBuffer, |
+ nCharacters, TRUE); |
- pEdit->SetEditNotify(this); |
- //pUndo->BeginEdit(pDocument); |
- } |
+ pEdit->SetEditNotify(this); |
+ // pUndo->BeginEdit(pDocument); |
+ } |
} |
-void CFFL_TextField::OnKillFocus(CPWL_Wnd* pWnd) |
-{ |
+void CFFL_TextField::OnKillFocus(CPWL_Wnd* pWnd) {} |
+FX_BOOL CFFL_TextField::CanCopy(CPDFSDK_Document* pDocument) { |
+ return FALSE; |
} |
-FX_BOOL CFFL_TextField::CanCopy(CPDFSDK_Document* pDocument) |
-{ |
- return FALSE; |
+FX_BOOL CFFL_TextField::CanCut(CPDFSDK_Document* pDocument) { |
+ return FALSE; |
} |
-FX_BOOL CFFL_TextField::CanCut(CPDFSDK_Document* pDocument) |
-{ |
- return FALSE; |
-} |
- |
-FX_BOOL CFFL_TextField::CanPaste(CPDFSDK_Document* pDocument) |
-{ |
- return FALSE; |
-} |
- |
-void CFFL_TextField::OnAddUndo(CPWL_Edit* pEdit) |
-{ |
+FX_BOOL CFFL_TextField::CanPaste(CPDFSDK_Document* pDocument) { |
+ return FALSE; |
} |
+void CFFL_TextField::OnAddUndo(CPWL_Edit* pEdit) {} |