Index: fpdfsdk/src/fpdf_sysfontinfo.cpp |
diff --git a/fpdfsdk/src/fpdf_sysfontinfo.cpp b/fpdfsdk/src/fpdf_sysfontinfo.cpp |
index cc75e635b3abbd5ccc4e9b219240e9603cfe1cc4..a1b05dc83f1166caa3dad02ac9b51da927098188 100644 |
--- a/fpdfsdk/src/fpdf_sysfontinfo.cpp |
+++ b/fpdfsdk/src/fpdf_sysfontinfo.cpp |
@@ -1,163 +1,177 @@ |
// Copyright 2014 PDFium Authors. All rights reserved. |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
- |
+ |
// Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com |
#include "../include/fsdk_define.h" |
#include "../include/fpdf_sysfontinfo.h" |
-class CSysFontInfo_Ext FX_FINAL : public IFX_SystemFontInfo |
-{ |
-public: |
- FPDF_SYSFONTINFO* m_pInfo; |
- |
- virtual void Release() |
- { |
- if (m_pInfo->Release) |
- m_pInfo->Release(m_pInfo); |
- delete this; |
- } |
- |
- virtual FX_BOOL EnumFontList(CFX_FontMapper* pMapper) |
- { |
- if (m_pInfo->EnumFonts) { |
- m_pInfo->EnumFonts(m_pInfo, pMapper); |
- return TRUE; |
- } |
- return FALSE; |
- } |
- |
- virtual void* MapFont(int weight, FX_BOOL bItalic, int charset, int pitch_family, FX_LPCSTR family, FX_BOOL& bExact) |
- { |
- if (m_pInfo->MapFont) |
- return m_pInfo->MapFont(m_pInfo, weight, bItalic, charset, pitch_family, family, &bExact); |
- return NULL; |
- } |
- |
- virtual void* GetFont(FX_LPCSTR family) |
- { |
- if (m_pInfo->GetFont) |
- return m_pInfo->GetFont(m_pInfo, family); |
- return NULL; |
- } |
- |
- virtual FX_DWORD GetFontData(void* hFont, FX_DWORD table, FX_LPBYTE buffer, FX_DWORD size) |
- { |
- if (m_pInfo->GetFontData) |
- return m_pInfo->GetFontData(m_pInfo, hFont, table, buffer, size); |
- return 0; |
- } |
- |
- virtual FX_BOOL GetFaceName(void* hFont, CFX_ByteString& name) |
- { |
- if (m_pInfo->GetFaceName == NULL) return FALSE; |
- FX_DWORD size = m_pInfo->GetFaceName(m_pInfo, hFont, NULL, 0); |
- if (size == 0) return FALSE; |
- char* buffer = FX_Alloc(char, size); |
- size = m_pInfo->GetFaceName(m_pInfo, hFont, buffer, size); |
- name = CFX_ByteString(buffer, size); |
- FX_Free(buffer); |
- return TRUE; |
- } |
- |
- virtual FX_BOOL GetFontCharset(void* hFont, int& charset) |
- { |
- if (m_pInfo->GetFontCharset) { |
- charset = m_pInfo->GetFontCharset(m_pInfo, hFont); |
- return TRUE; |
- } |
- return FALSE; |
- } |
- |
- virtual void DeleteFont(void* hFont) |
- { |
- if (m_pInfo->DeleteFont) |
- m_pInfo->DeleteFont(m_pInfo, hFont); |
- } |
+class CSysFontInfo_Ext FX_FINAL : public IFX_SystemFontInfo { |
+ public: |
+ FPDF_SYSFONTINFO* m_pInfo; |
+ |
+ virtual void Release() { |
+ if (m_pInfo->Release) |
+ m_pInfo->Release(m_pInfo); |
+ delete this; |
+ } |
+ |
+ virtual FX_BOOL EnumFontList(CFX_FontMapper* pMapper) { |
+ if (m_pInfo->EnumFonts) { |
+ m_pInfo->EnumFonts(m_pInfo, pMapper); |
+ return TRUE; |
+ } |
+ return FALSE; |
+ } |
+ |
+ virtual void* MapFont(int weight, |
+ FX_BOOL bItalic, |
+ int charset, |
+ int pitch_family, |
+ FX_LPCSTR family, |
+ FX_BOOL& bExact) { |
+ if (m_pInfo->MapFont) |
+ return m_pInfo->MapFont( |
+ m_pInfo, weight, bItalic, charset, pitch_family, family, &bExact); |
+ return NULL; |
+ } |
+ |
+ virtual void* GetFont(FX_LPCSTR family) { |
+ if (m_pInfo->GetFont) |
+ return m_pInfo->GetFont(m_pInfo, family); |
+ return NULL; |
+ } |
+ |
+ virtual FX_DWORD GetFontData(void* hFont, |
+ FX_DWORD table, |
+ FX_LPBYTE buffer, |
+ FX_DWORD size) { |
+ if (m_pInfo->GetFontData) |
+ return m_pInfo->GetFontData(m_pInfo, hFont, table, buffer, size); |
+ return 0; |
+ } |
+ |
+ virtual FX_BOOL GetFaceName(void* hFont, CFX_ByteString& name) { |
+ if (m_pInfo->GetFaceName == NULL) |
+ return FALSE; |
+ FX_DWORD size = m_pInfo->GetFaceName(m_pInfo, hFont, NULL, 0); |
+ if (size == 0) |
+ return FALSE; |
+ char* buffer = FX_Alloc(char, size); |
+ size = m_pInfo->GetFaceName(m_pInfo, hFont, buffer, size); |
+ name = CFX_ByteString(buffer, size); |
+ FX_Free(buffer); |
+ return TRUE; |
+ } |
+ |
+ virtual FX_BOOL GetFontCharset(void* hFont, int& charset) { |
+ if (m_pInfo->GetFontCharset) { |
+ charset = m_pInfo->GetFontCharset(m_pInfo, hFont); |
+ return TRUE; |
+ } |
+ return FALSE; |
+ } |
+ |
+ virtual void DeleteFont(void* hFont) { |
+ if (m_pInfo->DeleteFont) |
+ m_pInfo->DeleteFont(m_pInfo, hFont); |
+ } |
}; |
-DLLEXPORT void STDCALL FPDF_AddInstalledFont(void* mapper, const char* name, int charset) |
-{ |
- ((CFX_FontMapper*)mapper)->AddInstalledFont(name, charset); |
+DLLEXPORT void STDCALL |
+ FPDF_AddInstalledFont(void* mapper, const char* name, int charset) { |
+ ((CFX_FontMapper*)mapper)->AddInstalledFont(name, charset); |
} |
-DLLEXPORT void STDCALL FPDF_SetSystemFontInfo(FPDF_SYSFONTINFO* pFontInfoExt) |
-{ |
- if (pFontInfoExt->version != 1) return; |
+DLLEXPORT void STDCALL FPDF_SetSystemFontInfo(FPDF_SYSFONTINFO* pFontInfoExt) { |
+ if (pFontInfoExt->version != 1) |
+ return; |
- CSysFontInfo_Ext* pFontInfo = FX_NEW CSysFontInfo_Ext; |
- pFontInfo->m_pInfo = pFontInfoExt; |
- CFX_GEModule::Get()->GetFontMgr()->SetSystemFontInfo(pFontInfo); |
+ CSysFontInfo_Ext* pFontInfo = FX_NEW CSysFontInfo_Ext; |
+ pFontInfo->m_pInfo = pFontInfoExt; |
+ CFX_GEModule::Get()->GetFontMgr()->SetSystemFontInfo(pFontInfo); |
} |
-struct FPDF_SYSFONTINFO_DEFAULT : public FPDF_SYSFONTINFO |
-{ |
- IFX_SystemFontInfo* m_pFontInfo; |
+struct FPDF_SYSFONTINFO_DEFAULT : public FPDF_SYSFONTINFO { |
+ IFX_SystemFontInfo* m_pFontInfo; |
}; |
-static void DefaultRelease(struct _FPDF_SYSFONTINFO* pThis) |
-{ |
- ((FPDF_SYSFONTINFO_DEFAULT*)pThis)->m_pFontInfo->Release(); |
+static void DefaultRelease(struct _FPDF_SYSFONTINFO* pThis) { |
+ ((FPDF_SYSFONTINFO_DEFAULT*)pThis)->m_pFontInfo->Release(); |
} |
-static void DefaultEnumFonts(struct _FPDF_SYSFONTINFO* pThis, void* pMapper) |
-{ |
- ((FPDF_SYSFONTINFO_DEFAULT*)pThis)->m_pFontInfo->EnumFontList((CFX_FontMapper*)pMapper); |
+static void DefaultEnumFonts(struct _FPDF_SYSFONTINFO* pThis, void* pMapper) { |
+ ((FPDF_SYSFONTINFO_DEFAULT*)pThis) |
+ ->m_pFontInfo->EnumFontList((CFX_FontMapper*)pMapper); |
} |
-static void* DefaultMapFont(struct _FPDF_SYSFONTINFO* pThis, int weight, int bItalic, int charset, int pitch_family, const char* family, int* bExact) |
-{ |
- return ((FPDF_SYSFONTINFO_DEFAULT*)pThis)->m_pFontInfo->MapFont(weight, bItalic, charset, pitch_family, family, *bExact); |
+static void* DefaultMapFont(struct _FPDF_SYSFONTINFO* pThis, |
+ int weight, |
+ int bItalic, |
+ int charset, |
+ int pitch_family, |
+ const char* family, |
+ int* bExact) { |
+ return ((FPDF_SYSFONTINFO_DEFAULT*)pThis)->m_pFontInfo->MapFont( |
+ weight, bItalic, charset, pitch_family, family, *bExact); |
} |
-void* DefaultGetFont(struct _FPDF_SYSFONTINFO* pThis, const char* family) |
-{ |
- return ((FPDF_SYSFONTINFO_DEFAULT*)pThis)->m_pFontInfo->GetFont(family); |
+void* DefaultGetFont(struct _FPDF_SYSFONTINFO* pThis, const char* family) { |
+ return ((FPDF_SYSFONTINFO_DEFAULT*)pThis)->m_pFontInfo->GetFont(family); |
} |
-static unsigned long DefaultGetFontData(struct _FPDF_SYSFONTINFO* pThis, void* hFont, |
- unsigned int table, unsigned char* buffer, unsigned long buf_size) |
-{ |
- return ((FPDF_SYSFONTINFO_DEFAULT*)pThis)->m_pFontInfo->GetFontData(hFont, table, buffer, buf_size); |
+static unsigned long DefaultGetFontData(struct _FPDF_SYSFONTINFO* pThis, |
+ void* hFont, |
+ unsigned int table, |
+ unsigned char* buffer, |
+ unsigned long buf_size) { |
+ return ((FPDF_SYSFONTINFO_DEFAULT*)pThis) |
+ ->m_pFontInfo->GetFontData(hFont, table, buffer, buf_size); |
} |
-static unsigned long DefaultGetFaceName(struct _FPDF_SYSFONTINFO* pThis, void* hFont, char* buffer, unsigned long buf_size) |
-{ |
- CFX_ByteString name; |
- if (!((FPDF_SYSFONTINFO_DEFAULT*)pThis)->m_pFontInfo->GetFaceName(hFont, name)) return 0; |
- if (name.GetLength() >= (long)buf_size) return name.GetLength() + 1; |
- FXSYS_strcpy(buffer, name); |
- return name.GetLength() + 1; |
+static unsigned long DefaultGetFaceName(struct _FPDF_SYSFONTINFO* pThis, |
+ void* hFont, |
+ char* buffer, |
+ unsigned long buf_size) { |
+ CFX_ByteString name; |
+ if (!((FPDF_SYSFONTINFO_DEFAULT*)pThis) |
+ ->m_pFontInfo->GetFaceName(hFont, name)) |
+ return 0; |
+ if (name.GetLength() >= (long)buf_size) |
+ return name.GetLength() + 1; |
+ FXSYS_strcpy(buffer, name); |
+ return name.GetLength() + 1; |
} |
-static int DefaultGetFontCharset(struct _FPDF_SYSFONTINFO* pThis, void* hFont) |
-{ |
- int charset; |
- if (!((FPDF_SYSFONTINFO_DEFAULT*)pThis)->m_pFontInfo->GetFontCharset(hFont, charset)) return 0; |
- return charset; |
+static int DefaultGetFontCharset(struct _FPDF_SYSFONTINFO* pThis, void* hFont) { |
+ int charset; |
+ if (!((FPDF_SYSFONTINFO_DEFAULT*)pThis) |
+ ->m_pFontInfo->GetFontCharset(hFont, charset)) |
+ return 0; |
+ return charset; |
} |
-static void DefaultDeleteFont(struct _FPDF_SYSFONTINFO* pThis, void* hFont) |
-{ |
- ((FPDF_SYSFONTINFO_DEFAULT*)pThis)->m_pFontInfo->DeleteFont(hFont); |
+static void DefaultDeleteFont(struct _FPDF_SYSFONTINFO* pThis, void* hFont) { |
+ ((FPDF_SYSFONTINFO_DEFAULT*)pThis)->m_pFontInfo->DeleteFont(hFont); |
} |
-DLLEXPORT FPDF_SYSFONTINFO* STDCALL FPDF_GetDefaultSystemFontInfo() |
-{ |
- IFX_SystemFontInfo* pFontInfo = IFX_SystemFontInfo::CreateDefault(); |
- if (pFontInfo == NULL) return NULL; |
- |
- FPDF_SYSFONTINFO_DEFAULT* pFontInfoExt = FX_Alloc(FPDF_SYSFONTINFO_DEFAULT, 1); |
- pFontInfoExt->DeleteFont = DefaultDeleteFont; |
- pFontInfoExt->EnumFonts = DefaultEnumFonts; |
- pFontInfoExt->GetFaceName = DefaultGetFaceName; |
- pFontInfoExt->GetFont = DefaultGetFont; |
- pFontInfoExt->GetFontCharset = DefaultGetFontCharset; |
- pFontInfoExt->GetFontData = DefaultGetFontData; |
- pFontInfoExt->MapFont = DefaultMapFont; |
- pFontInfoExt->Release = DefaultRelease; |
- pFontInfoExt->version = 1; |
- pFontInfoExt->m_pFontInfo = pFontInfo; |
- return pFontInfoExt; |
+DLLEXPORT FPDF_SYSFONTINFO* STDCALL FPDF_GetDefaultSystemFontInfo() { |
+ IFX_SystemFontInfo* pFontInfo = IFX_SystemFontInfo::CreateDefault(); |
+ if (pFontInfo == NULL) |
+ return NULL; |
+ |
+ FPDF_SYSFONTINFO_DEFAULT* pFontInfoExt = |
+ FX_Alloc(FPDF_SYSFONTINFO_DEFAULT, 1); |
+ pFontInfoExt->DeleteFont = DefaultDeleteFont; |
+ pFontInfoExt->EnumFonts = DefaultEnumFonts; |
+ pFontInfoExt->GetFaceName = DefaultGetFaceName; |
+ pFontInfoExt->GetFont = DefaultGetFont; |
+ pFontInfoExt->GetFontCharset = DefaultGetFontCharset; |
+ pFontInfoExt->GetFontData = DefaultGetFontData; |
+ pFontInfoExt->MapFont = DefaultMapFont; |
+ pFontInfoExt->Release = DefaultRelease; |
+ pFontInfoExt->version = 1; |
+ pFontInfoExt->m_pFontInfo = pFontInfo; |
+ return pFontInfoExt; |
} |