Files
DocumentServer-v-9.2.0/core/PdfFile/SrcReader/Adaptors.h
T
Yajbir Singh f1b860b25c
check / markdownlint (push) Has been cancelled
check / spellchecker (push) Has been cancelled
updated
2025-12-11 19:03:17 +05:30

236 lines
7.1 KiB
C++

/*
* (c) Copyright Ascensio System SIA 2010-2023
*
* This program is a free software product. You can redistribute it and/or
* modify it under the terms of the GNU Affero General Public License (AGPL)
* version 3 as published by the Free Software Foundation. In accordance with
* Section 7(a) of the GNU AGPL its Section 15 shall be amended to the effect
* that Ascensio System SIA expressly excludes the warranty of non-infringement
* of any third-party rights.
*
* This program is distributed WITHOUT ANY WARRANTY; without even the implied
* warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. For
* details, see the GNU AGPL at: http://www.gnu.org/licenses/agpl-3.0.html
*
* You can contact Ascensio System SIA at 20A-6 Ernesta Birznieka-Upish
* street, Riga, Latvia, EU, LV-1050.
*
* The interactive user interfaces in modified source and object code versions
* of the Program must display Appropriate Legal Notices, as required under
* Section 5 of the GNU AGPL version 3.
*
* Pursuant to Section 7(b) of the License you must retain the original Product
* logo when distributing the program. Pursuant to Section 7(e) we decline to
* grant you any rights under trademark law for use of our trademarks.
*
* All the Product's GUI elements, including illustrations and icon sets, as
* well as technical writing content are licensed under the terms of the
* Creative Commons Attribution-ShareAlike 4.0 International. See the License
* terms at http://creativecommons.org/licenses/by-sa/4.0/legalcode
*
*/
//
// Contains classes and functions which are necessary to xpdf to work with PDFReader
//
#ifndef CORE_ADAPTORS_H
#define CORE_ADAPTORS_H
#include "../lib/xpdf/GlobalParams.h"
#include "../lib/xpdf/Object.h"
#include "../lib/xpdf/XRef.h"
#include "../../DesktopEditor/graphics/pro/Fonts.h"
#include "../../DesktopEditor/common/StringExt.h"
#include "../../DesktopEditor/common/File.h"
#include "../../DesktopEditor/common/Directory.h"
#include <string>
#include <vector>
#include "../lib/goo/GList.h"
#include "../lib/goo/GHash.h"
#define GrClipEOFlag 0x01
class GlobalParamsAdaptor : public GlobalParams
{
private:
std::wstring m_wsTempFolder;
std::wstring m_wsCMapFolder;
BYTE* m_bCMapData;
DWORD m_nCMapDataLength;
bool m_bDrawFormField;
std::vector<double> m_arrRedactBox;
public:
GlobalParamsAdaptor(const char *filename) : GlobalParams(filename)
{
m_bCMapData = NULL;
m_nCMapDataLength = 0;
m_bDrawFormField = false;
}
virtual ~GlobalParamsAdaptor()
{
RELEASEARRAYOBJECTS(m_bCMapData);
}
void SetFontManager(NSFonts::IFontManager* pFontManager);
std::wstring GetTempFolder()
{
return m_wsTempFolder;
}
void SetTempFolder(const std::wstring &folder)
{
m_wsTempFolder = folder;
}
bool IsNeedCMap() { return !m_bCMapData; }
void SetCMapFolder(const std::wstring &wsFolder);
void SetCMapFile(const std::wstring &wsFile);
void SetCMapMemory(BYTE* pData, DWORD nSizeData);
bool GetCMap(const char* sName, char*& pData, unsigned int& nSize);
void setDrawFormField(bool bDrawFormField) { m_bDrawFormField = bDrawFormField; }
bool getDrawFormField() { return m_bDrawFormField; }
void AddRedact(const std::vector<double>& arrRedactBox);
bool InRedact(double dX, double dY);
void ClearRedact();
private:
void AddNameToUnicode(const char* sFile);
void AddAllCMap(GString* sFolder);
void AddCMapFolder(const char* sCollection, GString* sFolder);
};
#ifndef CORE_REF_OPERATORS
#define CORE_REF_OPERATORS
// Ref operators
bool operator==(const Ref &a, const Ref &b);
bool operator<(const Ref &a, const Ref &b);
bool operator<=(const Ref &a, const Ref &b);
bool operator>=(const Ref &a, const Ref &b);
bool operator>(const Ref &a, const Ref &b);
#endif
//String functions
static std::wstring* AStringToPWString(const char* sString)
{
return new std::wstring(NSStringExt::CConverter::GetUnicodeFromSingleByteString((unsigned char*)sString, (long)strlen(sString)));
}
static std::wstring AStringToWString(const char* sString)
{
return std::wstring(NSStringExt::CConverter::GetUnicodeFromSingleByteString((unsigned char*)sString, (long)strlen(sString)));
}
namespace NSStrings
{
GString* CreateString(const std::wstring& str);
GString* CreateString(const std::string& str);
std::wstring GetString(GString* str);
std::string GetStringA(GString* str);
std::wstring GetStringFromUTF32(GString* str);
std::string GetStringAFromUTF32(GString* str);
}
namespace PdfReader
{
static void SpitPathExt(std::wstring& wsFullPath, std::wstring* pwsFilePath, std::wstring* pwsExt)
{
// Ищем '.' начиная с конца пути, и разделяем путь на расширение и остальную часть
size_t nPos = wsFullPath.find_last_of(L".");
*pwsFilePath = wsFullPath.substr(0, nPos);
*pwsExt = wsFullPath.substr(nPos + 1);
}
static bool OpenTempFile(std::wstring* pwsName, FILE **ppFile, wchar_t *wsMode, wchar_t *wsExt, wchar_t *wsFolder, wchar_t *wsName = NULL)
{
return NSFile::CFileBinary::OpenTempFile(pwsName, ppFile, wsMode, wsExt, wsFolder, wsName);
}
static char*GetLine(char *sBuffer, int nSize, FILE *pFile)
{
int nChar, nCurIndex = 0;
while (nCurIndex < nSize - 1)
{
if ((nChar = fgetc(pFile)) == EOF)
break;
sBuffer[nCurIndex++] = (char)nChar;
if ('\x0a' == nChar)
{
break;
}
if ('\x0d' == nChar)
{
nChar = fgetc(pFile);
if ('\x0a' == nChar && nCurIndex < nSize - 1)
{
sBuffer[nCurIndex++] = (char)nChar;
}
else if (EOF != nChar)
{
ungetc(nChar, pFile);
}
break;
}
}
sBuffer[nCurIndex] = '\0';
if (0 == nCurIndex)
return NULL;
return sBuffer;
}
}
class XMLConverter
{
public:
XMLConverter(XRef* xref, bool isParseStreams = false);
const std::wstring& GetXml() const {return m_wsXml;};
static void XRefToXml(XRef* xref, std::wstring &wsXml, bool parse_streams);
static std::wstring DictToXml(const std::wstring& wsName, Object* obj, int nNum = 0, int nGen = 0, bool bBinary = false);
private:
void ParseDicts();
void PdfToXml();
void ObjectToXml(Object* pObject, bool isSkipCheck = false);
void StreamDictToXml(Dict* pStreamDict, bool isSkipCheck = false);
void DictToXml(Dict* pDict);
bool CheckDict(Dict* pDict);
void Append(const char* sString)
{
std::string s(sString);
std::wstring wsTmp(s.begin(), s.end());
m_wsXml += wsTmp;
}
void Append(GString* pString)
{
for (int nPos = 0, nLen = pString->getLength(); nPos < nLen; ++nPos)
{
m_wsXml.push_back(std::btowc(pString->getChar(nPos)));
}
}
private:
XRef* m_pXRef;
bool m_bParseStreams;
std::map<Dict*, int> m_mDict;
std::wstring m_wsXml;
int m_nNumMax;
};
#endif //CORE_ADAPTORS_H