Index: xfa/fxfa/xfa_fontmgr.h |
diff --git a/xfa/fxfa/xfa_fontmgr.h b/xfa/fxfa/xfa_fontmgr.h |
index a6a5822e0df8addc2b5b069219b6b6553d4ea86a..f00b069ef03f0311197e4daa3034b206741b9f76 100644 |
--- a/xfa/fxfa/xfa_fontmgr.h |
+++ b/xfa/fxfa/xfa_fontmgr.h |
@@ -9,7 +9,9 @@ |
#include <map> |
#include <memory> |
+#include <vector> |
+#include "core/fxcrt/cfx_retain_ptr.h" |
#include "core/fxcrt/fx_ext.h" |
#include "core/fxcrt/fx_system.h" |
#include "xfa/fgas/font/cfgas_fontmgr.h" |
@@ -30,17 +32,18 @@ class CXFA_DefFontMgr { |
CXFA_DefFontMgr(); |
~CXFA_DefFontMgr(); |
- CFGAS_GEFont* GetFont(CXFA_FFDoc* hDoc, |
- const CFX_WideStringC& wsFontFamily, |
- uint32_t dwFontStyles, |
- uint16_t wCodePage = 0xFFFF); |
- CFGAS_GEFont* GetDefaultFont(CXFA_FFDoc* hDoc, |
- const CFX_WideStringC& wsFontFamily, |
- uint32_t dwFontStyles, |
- uint16_t wCodePage = 0xFFFF); |
+ CFX_RetainPtr<CFGAS_GEFont> GetFont(CXFA_FFDoc* hDoc, |
+ const CFX_WideStringC& wsFontFamily, |
+ uint32_t dwFontStyles, |
+ uint16_t wCodePage = 0xFFFF); |
+ CFX_RetainPtr<CFGAS_GEFont> GetDefaultFont( |
+ CXFA_FFDoc* hDoc, |
+ const CFX_WideStringC& wsFontFamily, |
+ uint32_t dwFontStyles, |
+ uint16_t wCodePage = 0xFFFF); |
protected: |
- CFX_ArrayTemplate<CFGAS_GEFont*> m_CacheFonts; |
+ std::vector<CFX_RetainPtr<CFGAS_GEFont>> m_CacheFonts; |
}; |
class CXFA_PDFFontMgr { |
@@ -48,22 +51,22 @@ class CXFA_PDFFontMgr { |
explicit CXFA_PDFFontMgr(CXFA_FFDoc* pDoc); |
~CXFA_PDFFontMgr(); |
- CFGAS_GEFont* GetFont(const CFX_WideStringC& wsFontFamily, |
- uint32_t dwFontStyles, |
- CPDF_Font** pPDFFont, |
- bool bStrictMatch); |
- bool GetCharWidth(const CFGAS_GEFont* pFont, |
+ CFX_RetainPtr<CFGAS_GEFont> GetFont(const CFX_WideStringC& wsFontFamily, |
+ uint32_t dwFontStyles, |
+ CPDF_Font** pPDFFont, |
+ bool bStrictMatch); |
+ bool GetCharWidth(const CFX_RetainPtr<CFGAS_GEFont>& pFont, |
FX_WCHAR wUnicode, |
bool bCharCode, |
int32_t* pWidth); |
- void SetFont(const CFGAS_GEFont* pFont, CPDF_Font* pPDFFont); |
+ void SetFont(const CFX_RetainPtr<CFGAS_GEFont>& pFont, CPDF_Font* pPDFFont); |
protected: |
- CFGAS_GEFont* FindFont(const CFX_ByteString& strFamilyName, |
- bool bBold, |
- bool bItalic, |
- CPDF_Font** pPDFFont, |
- bool bStrictMatch); |
+ CFX_RetainPtr<CFGAS_GEFont> FindFont(const CFX_ByteString& strFamilyName, |
+ bool bBold, |
+ bool bItalic, |
+ CPDF_Font** pPDFFont, |
+ bool bStrictMatch); |
CFX_ByteString PsNameToFontName(const CFX_ByteString& strPsName, |
bool bBold, |
bool bItalic); |
@@ -74,8 +77,8 @@ class CXFA_PDFFontMgr { |
bool bStrictMatch); |
CXFA_FFDoc* const m_pDoc; |
- std::map<const CFGAS_GEFont*, CPDF_Font*> m_FDE2PDFFont; |
- std::map<CFX_ByteString, CFGAS_GEFont*> m_FontMap; |
+ std::map<CFX_RetainPtr<CFGAS_GEFont>, CPDF_Font*> m_FDE2PDFFont; |
+ std::map<CFX_ByteString, CFX_RetainPtr<CFGAS_GEFont>> m_FontMap; |
}; |
class CXFA_FontMgr { |
@@ -83,10 +86,10 @@ class CXFA_FontMgr { |
CXFA_FontMgr(); |
~CXFA_FontMgr(); |
- CFGAS_GEFont* GetFont(CXFA_FFDoc* hDoc, |
- const CFX_WideStringC& wsFontFamily, |
- uint32_t dwFontStyles, |
- uint16_t wCodePage = 0xFFFF); |
+ CFX_RetainPtr<CFGAS_GEFont> GetFont(CXFA_FFDoc* hDoc, |
+ const CFX_WideStringC& wsFontFamily, |
+ uint32_t dwFontStyles, |
+ uint16_t wCodePage = 0xFFFF); |
void LoadDocFonts(CXFA_FFDoc* hDoc); |
void ReleaseDocFonts(CXFA_FFDoc* hDoc); |
void SetDefFontMgr(std::unique_ptr<CXFA_DefFontMgr> pFontMgr); |
@@ -94,7 +97,7 @@ class CXFA_FontMgr { |
protected: |
std::unique_ptr<CXFA_DefFontMgr> m_pDefFontMgr; |
std::map<CXFA_FFDoc*, std::unique_ptr<CXFA_PDFFontMgr>> m_PDFFontMgrMap; |
- std::map<CFX_ByteString, CFGAS_GEFont*> m_FontMap; |
+ std::map<CFX_ByteString, CFX_RetainPtr<CFGAS_GEFont>> m_FontMap; |
}; |
#endif // XFA_FXFA_XFA_FONTMGR_H_ |