| Index: fpdfsdk/include/cpdfsdk_environment.h
|
| diff --git a/fpdfsdk/include/cpdfsdk_environment.h b/fpdfsdk/include/cpdfsdk_environment.h
|
| index 7fd146a043bace5162ae5a1eb46c7986e57e8a2b..fe63ecad1389e991fa6f93256902bdf1be25b7fe 100644
|
| --- a/fpdfsdk/include/cpdfsdk_environment.h
|
| +++ b/fpdfsdk/include/cpdfsdk_environment.h
|
| @@ -30,41 +30,41 @@ class CPDFSDK_Environment final {
|
| CPDFSDK_Environment(UnderlyingDocumentType* pDoc, FPDF_FORMFILLINFO* pFFinfo);
|
| ~CPDFSDK_Environment();
|
|
|
| - void FFI_Invalidate(FPDF_PAGE page,
|
| - double left,
|
| - double top,
|
| - double right,
|
| - double bottom) {
|
| + void Invalidate(FPDF_PAGE page,
|
| + double left,
|
| + double top,
|
| + double right,
|
| + double bottom) {
|
| if (m_pInfo && m_pInfo->FFI_Invalidate)
|
| m_pInfo->FFI_Invalidate(m_pInfo, page, left, top, right, bottom);
|
| }
|
|
|
| - void FFI_OutputSelectedRect(FPDF_PAGE page,
|
| - double left,
|
| - double top,
|
| - double right,
|
| - double bottom) {
|
| + void OutputSelectedRect(FPDF_PAGE page,
|
| + double left,
|
| + double top,
|
| + double right,
|
| + double bottom) {
|
| if (m_pInfo && m_pInfo->FFI_OutputSelectedRect)
|
| m_pInfo->FFI_OutputSelectedRect(m_pInfo, page, left, top, right, bottom);
|
| }
|
|
|
| - void FFI_SetCursor(int nCursorType) {
|
| + void SetCursor(int nCursorType) {
|
| if (m_pInfo && m_pInfo->FFI_SetCursor)
|
| m_pInfo->FFI_SetCursor(m_pInfo, nCursorType);
|
| }
|
|
|
| - int FFI_SetTimer(int uElapse, TimerCallback lpTimerFunc) {
|
| + int SetTimer(int uElapse, TimerCallback lpTimerFunc) {
|
| if (m_pInfo && m_pInfo->FFI_SetTimer)
|
| return m_pInfo->FFI_SetTimer(m_pInfo, uElapse, lpTimerFunc);
|
| return -1;
|
| }
|
|
|
| - void FFI_KillTimer(int nTimerID) {
|
| + void KillTimer(int nTimerID) {
|
| if (m_pInfo && m_pInfo->FFI_KillTimer)
|
| m_pInfo->FFI_KillTimer(m_pInfo, nTimerID);
|
| }
|
|
|
| - FX_SYSTEMTIME FFI_GetLocalTime() const {
|
| + FX_SYSTEMTIME GetLocalTime() const {
|
| FX_SYSTEMTIME fxtime;
|
| if (m_pInfo && m_pInfo->FFI_GetLocalTime) {
|
| FPDF_SYSTEMTIME systime = m_pInfo->FFI_GetLocalTime(m_pInfo);
|
| @@ -80,120 +80,114 @@ class CPDFSDK_Environment final {
|
| return fxtime;
|
| }
|
|
|
| - void FFI_OnChange() {
|
| + void OnChange() {
|
| if (m_pInfo && m_pInfo->FFI_OnChange)
|
| m_pInfo->FFI_OnChange(m_pInfo);
|
| }
|
|
|
| - FX_BOOL FFI_IsSHIFTKeyDown(uint32_t nFlag) const {
|
| + FX_BOOL IsSHIFTKeyDown(uint32_t nFlag) const {
|
| return (nFlag & FWL_EVENTFLAG_ShiftKey) != 0;
|
| }
|
|
|
| - FX_BOOL FFI_IsCTRLKeyDown(uint32_t nFlag) const {
|
| + FX_BOOL IsCTRLKeyDown(uint32_t nFlag) const {
|
| return (nFlag & FWL_EVENTFLAG_ControlKey) != 0;
|
| }
|
|
|
| - FX_BOOL FFI_IsALTKeyDown(uint32_t nFlag) const {
|
| + FX_BOOL IsALTKeyDown(uint32_t nFlag) const {
|
| return (nFlag & FWL_EVENTFLAG_AltKey) != 0;
|
| }
|
|
|
| - FPDF_PAGE FFI_GetPage(FPDF_DOCUMENT document, int nPageIndex) {
|
| + FPDF_PAGE GetPage(FPDF_DOCUMENT document, int nPageIndex) {
|
| if (m_pInfo && m_pInfo->FFI_GetPage)
|
| return m_pInfo->FFI_GetPage(m_pInfo, document, nPageIndex);
|
| return nullptr;
|
| }
|
|
|
| - FPDF_PAGE FFI_GetCurrentPage(FPDF_DOCUMENT document) {
|
| + FPDF_PAGE GetCurrentPage(FPDF_DOCUMENT document) {
|
| if (m_pInfo && m_pInfo->FFI_GetCurrentPage)
|
| return m_pInfo->FFI_GetCurrentPage(m_pInfo, document);
|
| return nullptr;
|
| }
|
|
|
| - int FFI_GetRotation(FPDF_PAGE page) {
|
| - if (m_pInfo && m_pInfo->FFI_GetRotation)
|
| - return m_pInfo->FFI_GetRotation(m_pInfo, page);
|
| - return 0;
|
| - }
|
| -
|
| - void FFI_ExecuteNamedAction(const FX_CHAR* namedAction) {
|
| + void ExecuteNamedAction(const FX_CHAR* namedAction) {
|
| if (m_pInfo && m_pInfo->FFI_ExecuteNamedAction)
|
| m_pInfo->FFI_ExecuteNamedAction(m_pInfo, namedAction);
|
| }
|
|
|
| - void FFI_OnSetFieldInputFocus(void* field,
|
| - FPDF_WIDESTRING focusText,
|
| - FPDF_DWORD nTextLen,
|
| - FX_BOOL bFocus) {
|
| + void OnSetFieldInputFocus(void* field,
|
| + FPDF_WIDESTRING focusText,
|
| + FPDF_DWORD nTextLen,
|
| + FX_BOOL bFocus) {
|
| if (m_pInfo && m_pInfo->FFI_SetTextFieldFocus)
|
| m_pInfo->FFI_SetTextFieldFocus(m_pInfo, focusText, nTextLen, bFocus);
|
| }
|
|
|
| - void FFI_DoURIAction(const FX_CHAR* bsURI) {
|
| + void DoURIAction(const FX_CHAR* bsURI) {
|
| if (m_pInfo && m_pInfo->FFI_DoURIAction)
|
| m_pInfo->FFI_DoURIAction(m_pInfo, bsURI);
|
| }
|
|
|
| - void FFI_DoGoToAction(int nPageIndex,
|
| - int zoomMode,
|
| - float* fPosArray,
|
| - int sizeOfArray) {
|
| + void DoGoToAction(int nPageIndex,
|
| + int zoomMode,
|
| + float* fPosArray,
|
| + int sizeOfArray) {
|
| if (m_pInfo && m_pInfo->FFI_DoGoToAction)
|
| m_pInfo->FFI_DoGoToAction(m_pInfo, nPageIndex, zoomMode, fPosArray,
|
| sizeOfArray);
|
| }
|
|
|
| #ifdef PDF_ENABLE_XFA
|
| - void FFI_DisplayCaret(FPDF_PAGE page,
|
| - FPDF_BOOL bVisible,
|
| - double left,
|
| - double top,
|
| - double right,
|
| - double bottom) {
|
| + void DisplayCaret(FPDF_PAGE page,
|
| + FPDF_BOOL bVisible,
|
| + double left,
|
| + double top,
|
| + double right,
|
| + double bottom) {
|
| if (m_pInfo && m_pInfo->FFI_DisplayCaret)
|
| m_pInfo->FFI_DisplayCaret(m_pInfo, page, bVisible, left, top, right,
|
| bottom);
|
| }
|
|
|
| - int FFI_GetCurrentPageIndex(FPDF_DOCUMENT document) {
|
| - if (!m_pInfo || !m_pInfo->FFI_GetCurrentPageIndex) {
|
| + int GetCurrentPageIndex(FPDF_DOCUMENT document) {
|
| + if (!m_pInfo || !m_pInfo->FFI_GetCurrentPageIndex)
|
| return -1;
|
| - }
|
| return m_pInfo->FFI_GetCurrentPageIndex(m_pInfo, document);
|
| }
|
|
|
| - void FFI_SetCurrentPage(FPDF_DOCUMENT document, int iCurPage) {
|
| + void SetCurrentPage(FPDF_DOCUMENT document, int iCurPage) {
|
| if (m_pInfo && m_pInfo->FFI_SetCurrentPage)
|
| m_pInfo->FFI_SetCurrentPage(m_pInfo, document, iCurPage);
|
| }
|
|
|
| + // TODO(dsinclair): This should probably change to PDFium?
|
| CFX_WideString FFI_GetAppName() const { return CFX_WideString(L"Acrobat"); }
|
|
|
| - CFX_WideString FFI_GetPlatform() {
|
| - if (m_pInfo && m_pInfo->FFI_GetPlatform) {
|
| - int nRequiredLen = m_pInfo->FFI_GetPlatform(m_pInfo, nullptr, 0);
|
| - if (nRequiredLen <= 0)
|
| - return L"";
|
| -
|
| - char* pbuff = new char[nRequiredLen];
|
| - memset(pbuff, 0, nRequiredLen);
|
| - int nActualLen = m_pInfo->FFI_GetPlatform(m_pInfo, pbuff, nRequiredLen);
|
| - if (nActualLen <= 0 || nActualLen > nRequiredLen) {
|
| - delete[] pbuff;
|
| - return L"";
|
| - }
|
| - CFX_ByteString bsRet = CFX_ByteString(pbuff, nActualLen);
|
| - CFX_WideString wsRet = CFX_WideString::FromUTF16LE(
|
| - (unsigned short*)bsRet.GetBuffer(bsRet.GetLength()),
|
| - bsRet.GetLength() / sizeof(unsigned short));
|
| + CFX_WideString GetPlatform() {
|
| + if (!m_pInfo || !m_pInfo->FFI_GetPlatform)
|
| + return L"";
|
| +
|
| + int nRequiredLen = m_pInfo->FFI_GetPlatform(m_pInfo, nullptr, 0);
|
| + if (nRequiredLen <= 0)
|
| + return L"";
|
| +
|
| + char* pbuff = new char[nRequiredLen];
|
| + memset(pbuff, 0, nRequiredLen);
|
| + int nActualLen = m_pInfo->FFI_GetPlatform(m_pInfo, pbuff, nRequiredLen);
|
| + if (nActualLen <= 0 || nActualLen > nRequiredLen) {
|
| delete[] pbuff;
|
| - return wsRet;
|
| + return L"";
|
| }
|
| - return L"";
|
| + CFX_ByteString bsRet = CFX_ByteString(pbuff, nActualLen);
|
| + CFX_WideString wsRet = CFX_WideString::FromUTF16LE(
|
| + (unsigned short*)bsRet.GetBuffer(bsRet.GetLength()),
|
| + bsRet.GetLength() / sizeof(unsigned short));
|
| + delete[] pbuff;
|
| + return wsRet;
|
| }
|
|
|
| - void FFI_GotoURL(FPDF_DOCUMENT document,
|
| - const CFX_WideStringC& wsURL,
|
| - FX_BOOL bAppend) {
|
| + void GotoURL(FPDF_DOCUMENT document,
|
| + const CFX_WideStringC& wsURL,
|
| + FX_BOOL bAppend) {
|
| if (m_pInfo && m_pInfo->FFI_GotoURL) {
|
| CFX_ByteString bsTo = CFX_WideString(wsURL).UTF16LE_Encode();
|
| FPDF_WIDESTRING pTo = (FPDF_WIDESTRING)bsTo.GetBuffer(wsURL.GetLength());
|
| @@ -202,7 +196,7 @@ class CPDFSDK_Environment final {
|
| }
|
| }
|
|
|
| - void FFI_GetPageViewRect(FPDF_PAGE page, FS_RECTF& dstRect) {
|
| + void GetPageViewRect(FPDF_PAGE page, FS_RECTF& dstRect) {
|
| if (m_pInfo && m_pInfo->FFI_GetPageViewRect) {
|
| double left;
|
| double top;
|
| @@ -217,157 +211,147 @@ class CPDFSDK_Environment final {
|
| }
|
| }
|
|
|
| - FX_BOOL FFI_PopupMenu(FPDF_PAGE page,
|
| - FPDF_WIDGET hWidget,
|
| - int menuFlag,
|
| - CFX_PointF ptPopup,
|
| - const CFX_PointF* pRectExclude) {
|
| + FX_BOOL PopupMenu(FPDF_PAGE page,
|
| + FPDF_WIDGET hWidget,
|
| + int menuFlag,
|
| + CFX_PointF ptPopup,
|
| + const CFX_PointF* pRectExclude) {
|
| if (m_pInfo && m_pInfo->FFI_PopupMenu)
|
| return m_pInfo->FFI_PopupMenu(m_pInfo, page, hWidget, menuFlag, ptPopup.x,
|
| ptPopup.y);
|
| return FALSE;
|
| }
|
|
|
| - void FFI_Alert(FPDF_WIDESTRING Msg,
|
| - FPDF_WIDESTRING Title,
|
| - int Type,
|
| - int Icon) {
|
| + void Alert(FPDF_WIDESTRING Msg, FPDF_WIDESTRING Title, int Type, int Icon) {
|
| if (m_pInfo && m_pInfo->m_pJsPlatform && m_pInfo->m_pJsPlatform->app_alert)
|
| m_pInfo->m_pJsPlatform->app_alert(m_pInfo->m_pJsPlatform, Msg, Title,
|
| Type, Icon);
|
| }
|
|
|
| - void FFI_EmailTo(FPDF_FILEHANDLER* fileHandler,
|
| - FPDF_WIDESTRING pTo,
|
| - FPDF_WIDESTRING pSubject,
|
| - FPDF_WIDESTRING pCC,
|
| - FPDF_WIDESTRING pBcc,
|
| - FPDF_WIDESTRING pMsg) {
|
| + void EmailTo(FPDF_FILEHANDLER* fileHandler,
|
| + FPDF_WIDESTRING pTo,
|
| + FPDF_WIDESTRING pSubject,
|
| + FPDF_WIDESTRING pCC,
|
| + FPDF_WIDESTRING pBcc,
|
| + FPDF_WIDESTRING pMsg) {
|
| if (m_pInfo && m_pInfo->FFI_EmailTo)
|
| m_pInfo->FFI_EmailTo(m_pInfo, fileHandler, pTo, pSubject, pCC, pBcc,
|
| pMsg);
|
| }
|
|
|
| - void FFI_UploadTo(FPDF_FILEHANDLER* fileHandler,
|
| - int fileFlag,
|
| - FPDF_WIDESTRING uploadTo) {
|
| + void UploadTo(FPDF_FILEHANDLER* fileHandler,
|
| + int fileFlag,
|
| + FPDF_WIDESTRING uploadTo) {
|
| if (m_pInfo && m_pInfo->FFI_UploadTo)
|
| m_pInfo->FFI_UploadTo(m_pInfo, fileHandler, fileFlag, uploadTo);
|
| }
|
|
|
| - FPDF_FILEHANDLER* FFI_OpenFile(int fileType,
|
| - FPDF_WIDESTRING wsURL,
|
| - const char* mode) {
|
| + FPDF_FILEHANDLER* OpenFile(int fileType,
|
| + FPDF_WIDESTRING wsURL,
|
| + const char* mode) {
|
| if (m_pInfo && m_pInfo->FFI_OpenFile)
|
| return m_pInfo->FFI_OpenFile(m_pInfo, fileType, wsURL, mode);
|
| return nullptr;
|
| }
|
|
|
| - CFX_WideString FFI_GetFilePath(FPDF_FILEHANDLER* pFileHandler) const {
|
| - return L"";
|
| - }
|
| -
|
| - int FFI_GetDocumentCount() const { return 0; }
|
| - int FFI_GetCurDocument() const { return 0; }
|
| + IFX_FileRead* DownloadFromURL(const FX_WCHAR* url) {
|
| + if (!m_pInfo || !m_pInfo->FFI_DownloadFromURL)
|
| + return nullptr;
|
|
|
| - IFX_FileRead* FFI_DownloadFromURL(const FX_WCHAR* url) {
|
| - if (m_pInfo && m_pInfo->FFI_DownloadFromURL) {
|
| - CFX_ByteString bstrURL = CFX_WideString(url).UTF16LE_Encode();
|
| - FPDF_WIDESTRING wsURL =
|
| - (FPDF_WIDESTRING)bstrURL.GetBuffer(bstrURL.GetLength());
|
| + CFX_ByteString bstrURL = CFX_WideString(url).UTF16LE_Encode();
|
| + FPDF_WIDESTRING wsURL =
|
| + (FPDF_WIDESTRING)bstrURL.GetBuffer(bstrURL.GetLength());
|
|
|
| - FPDF_LPFILEHANDLER fileHandler =
|
| - m_pInfo->FFI_DownloadFromURL(m_pInfo, wsURL);
|
| + FPDF_LPFILEHANDLER fileHandler =
|
| + m_pInfo->FFI_DownloadFromURL(m_pInfo, wsURL);
|
|
|
| - return new CFPDF_FileStream(fileHandler);
|
| - }
|
| - return nullptr;
|
| + return new CFPDF_FileStream(fileHandler);
|
| }
|
|
|
| - CFX_WideString FFI_PostRequestURL(const FX_WCHAR* wsURL,
|
| - const FX_WCHAR* wsData,
|
| - const FX_WCHAR* wsContentType,
|
| - const FX_WCHAR* wsEncode,
|
| - const FX_WCHAR* wsHeader) {
|
| - if (m_pInfo && m_pInfo->FFI_PostRequestURL) {
|
| - CFX_ByteString bsURL = CFX_WideString(wsURL).UTF16LE_Encode();
|
| - FPDF_WIDESTRING URL = (FPDF_WIDESTRING)bsURL.GetBuffer(bsURL.GetLength());
|
| + CFX_WideString PostRequestURL(const FX_WCHAR* wsURL,
|
| + const FX_WCHAR* wsData,
|
| + const FX_WCHAR* wsContentType,
|
| + const FX_WCHAR* wsEncode,
|
| + const FX_WCHAR* wsHeader) {
|
| + if (!m_pInfo || !m_pInfo->FFI_PostRequestURL)
|
| + return L"";
|
|
|
| - CFX_ByteString bsData = CFX_WideString(wsData).UTF16LE_Encode();
|
| - FPDF_WIDESTRING data =
|
| - (FPDF_WIDESTRING)bsData.GetBuffer(bsData.GetLength());
|
| + CFX_ByteString bsURL = CFX_WideString(wsURL).UTF16LE_Encode();
|
| + FPDF_WIDESTRING URL = (FPDF_WIDESTRING)bsURL.GetBuffer(bsURL.GetLength());
|
|
|
| - CFX_ByteString bsContentType =
|
| - CFX_WideString(wsContentType).UTF16LE_Encode();
|
| - FPDF_WIDESTRING contentType =
|
| - (FPDF_WIDESTRING)bsContentType.GetBuffer(bsContentType.GetLength());
|
| + CFX_ByteString bsData = CFX_WideString(wsData).UTF16LE_Encode();
|
| + FPDF_WIDESTRING data =
|
| + (FPDF_WIDESTRING)bsData.GetBuffer(bsData.GetLength());
|
|
|
| - CFX_ByteString bsEncode = CFX_WideString(wsEncode).UTF16LE_Encode();
|
| - FPDF_WIDESTRING encode =
|
| - (FPDF_WIDESTRING)bsEncode.GetBuffer(bsEncode.GetLength());
|
| + CFX_ByteString bsContentType =
|
| + CFX_WideString(wsContentType).UTF16LE_Encode();
|
| + FPDF_WIDESTRING contentType =
|
| + (FPDF_WIDESTRING)bsContentType.GetBuffer(bsContentType.GetLength());
|
|
|
| - CFX_ByteString bsHeader = CFX_WideString(wsHeader).UTF16LE_Encode();
|
| - FPDF_WIDESTRING header =
|
| - (FPDF_WIDESTRING)bsHeader.GetBuffer(bsHeader.GetLength());
|
| + CFX_ByteString bsEncode = CFX_WideString(wsEncode).UTF16LE_Encode();
|
| + FPDF_WIDESTRING encode =
|
| + (FPDF_WIDESTRING)bsEncode.GetBuffer(bsEncode.GetLength());
|
|
|
| - FPDF_BSTR response;
|
| - FPDF_BStr_Init(&response);
|
| - m_pInfo->FFI_PostRequestURL(m_pInfo, URL, data, contentType, encode,
|
| - header, &response);
|
| + CFX_ByteString bsHeader = CFX_WideString(wsHeader).UTF16LE_Encode();
|
| + FPDF_WIDESTRING header =
|
| + (FPDF_WIDESTRING)bsHeader.GetBuffer(bsHeader.GetLength());
|
|
|
| - CFX_WideString wsRet = CFX_WideString::FromUTF16LE(
|
| - (unsigned short*)response.str, response.len / sizeof(unsigned short));
|
| - FPDF_BStr_Clear(&response);
|
| + FPDF_BSTR response;
|
| + FPDF_BStr_Init(&response);
|
| + m_pInfo->FFI_PostRequestURL(m_pInfo, URL, data, contentType, encode, header,
|
| + &response);
|
|
|
| - return wsRet;
|
| - }
|
| - return L"";
|
| + CFX_WideString wsRet = CFX_WideString::FromUTF16LE(
|
| + (unsigned short*)response.str, response.len / sizeof(unsigned short));
|
| + FPDF_BStr_Clear(&response);
|
| +
|
| + return wsRet;
|
| }
|
|
|
| - FPDF_BOOL FFI_PutRequestURL(const FX_WCHAR* wsURL,
|
| - const FX_WCHAR* wsData,
|
| - const FX_WCHAR* wsEncode) {
|
| - if (m_pInfo && m_pInfo->FFI_PutRequestURL) {
|
| - CFX_ByteString bsURL = CFX_WideString(wsURL).UTF16LE_Encode();
|
| - FPDF_WIDESTRING URL = (FPDF_WIDESTRING)bsURL.GetBuffer(bsURL.GetLength());
|
| + FPDF_BOOL PutRequestURL(const FX_WCHAR* wsURL,
|
| + const FX_WCHAR* wsData,
|
| + const FX_WCHAR* wsEncode) {
|
| + if (!m_pInfo || !m_pInfo->FFI_PutRequestURL)
|
| + return FALSE;
|
|
|
| - CFX_ByteString bsData = CFX_WideString(wsData).UTF16LE_Encode();
|
| - FPDF_WIDESTRING data =
|
| - (FPDF_WIDESTRING)bsData.GetBuffer(bsData.GetLength());
|
| + CFX_ByteString bsURL = CFX_WideString(wsURL).UTF16LE_Encode();
|
| + FPDF_WIDESTRING URL = (FPDF_WIDESTRING)bsURL.GetBuffer(bsURL.GetLength());
|
|
|
| - CFX_ByteString bsEncode = CFX_WideString(wsEncode).UTF16LE_Encode();
|
| - FPDF_WIDESTRING encode =
|
| - (FPDF_WIDESTRING)bsEncode.GetBuffer(bsEncode.GetLength());
|
| + CFX_ByteString bsData = CFX_WideString(wsData).UTF16LE_Encode();
|
| + FPDF_WIDESTRING data =
|
| + (FPDF_WIDESTRING)bsData.GetBuffer(bsData.GetLength());
|
|
|
| - return m_pInfo->FFI_PutRequestURL(m_pInfo, URL, data, encode);
|
| - }
|
| - return FALSE;
|
| + CFX_ByteString bsEncode = CFX_WideString(wsEncode).UTF16LE_Encode();
|
| + FPDF_WIDESTRING encode =
|
| + (FPDF_WIDESTRING)bsEncode.GetBuffer(bsEncode.GetLength());
|
| +
|
| + return m_pInfo->FFI_PutRequestURL(m_pInfo, URL, data, encode);
|
| }
|
|
|
| - CFX_WideString FFI_GetLanguage() {
|
| - if (m_pInfo && m_pInfo->FFI_GetLanguage) {
|
| - int nRequiredLen = m_pInfo->FFI_GetLanguage(m_pInfo, nullptr, 0);
|
| - if (nRequiredLen <= 0)
|
| - return L"";
|
| -
|
| - char* pbuff = new char[nRequiredLen];
|
| - memset(pbuff, 0, nRequiredLen);
|
| - int nActualLen = m_pInfo->FFI_GetLanguage(m_pInfo, pbuff, nRequiredLen);
|
| - if (nActualLen <= 0 || nActualLen > nRequiredLen) {
|
| - delete[] pbuff;
|
| - return L"";
|
| - }
|
| - CFX_ByteString bsRet = CFX_ByteString(pbuff, nActualLen);
|
| - CFX_WideString wsRet = CFX_WideString::FromUTF16LE(
|
| - (unsigned short*)bsRet.GetBuffer(bsRet.GetLength()),
|
| - bsRet.GetLength() / sizeof(unsigned short));
|
| + CFX_WideString GetLanguage() {
|
| + if (!m_pInfo || !m_pInfo->FFI_GetLanguage)
|
| + return L"";
|
| +
|
| + int nRequiredLen = m_pInfo->FFI_GetLanguage(m_pInfo, nullptr, 0);
|
| + if (nRequiredLen <= 0)
|
| + return L"";
|
| +
|
| + char* pbuff = new char[nRequiredLen];
|
| + memset(pbuff, 0, nRequiredLen);
|
| + int nActualLen = m_pInfo->FFI_GetLanguage(m_pInfo, pbuff, nRequiredLen);
|
| + if (nActualLen <= 0 || nActualLen > nRequiredLen) {
|
| delete[] pbuff;
|
| - return wsRet;
|
| + return L"";
|
| }
|
| - return L"";
|
| + CFX_ByteString bsRet = CFX_ByteString(pbuff, nActualLen);
|
| + CFX_WideString wsRet = CFX_WideString::FromUTF16LE(
|
| + (unsigned short*)bsRet.GetBuffer(bsRet.GetLength()),
|
| + bsRet.GetLength() / sizeof(unsigned short));
|
| + delete[] pbuff;
|
| + return wsRet;
|
| }
|
|
|
| - void FFI_PageEvent(int iPageCount, uint32_t dwEventType) const {
|
| + void PageEvent(int iPageCount, uint32_t dwEventType) const {
|
| if (m_pInfo && m_pInfo->FFI_PageEvent)
|
| m_pInfo->FFI_PageEvent(m_pInfo, iPageCount, dwEventType);
|
| }
|
|
|