Chromium Code Reviews| Index: xfa/fgas/font/cfgas_gefont.cpp |
| diff --git a/xfa/fgas/font/fgas_gefont.cpp b/xfa/fgas/font/cfgas_gefont.cpp |
| similarity index 82% |
| rename from xfa/fgas/font/fgas_gefont.cpp |
| rename to xfa/fgas/font/cfgas_gefont.cpp |
| index 7fa352c23c1a7838f6adb1e38bcc50e1b94b0f39..e8ca1929095e392820e7553bbb95cfb480c7069c 100644 |
| --- a/xfa/fgas/font/fgas_gefont.cpp |
| +++ b/xfa/fgas/font/cfgas_gefont.cpp |
| @@ -4,7 +4,7 @@ |
| // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com |
| -#include "xfa/fgas/font/fgas_gefont.h" |
| +#include "xfa/fgas/font/cfgas_gefont.h" |
| #include <memory> |
| #include <utility> |
| @@ -12,6 +12,7 @@ |
| #include "core/fxge/cfx_substfont.h" |
| #include "core/fxge/cfx_unicodeencoding.h" |
| #include "core/fxge/cfx_unicodeencodingex.h" |
| +#include "third_party/base/ptr_util.h" |
| #include "xfa/fgas/crt/fgas_codepage.h" |
| #include "xfa/fgas/font/fgas_fontutils.h" |
| #include "xfa/fxfa/xfa_fontmgr.h" |
| @@ -120,9 +121,8 @@ CFGAS_GEFont::CFGAS_GEFont(CFGAS_GEFont* src, uint32_t dwFontStyles) |
| } |
| pSubst->m_Weight = |
| (dwFontStyles & FX_FONTSTYLE_Bold) ? FXFONT_FW_BOLD : FXFONT_FW_NORMAL; |
| - if (dwFontStyles & FX_FONTSTYLE_Italic) { |
| + if (dwFontStyles & FX_FONTSTYLE_Italic) |
| pSubst->m_SubstFlags |= FXFONT_SUBST_ITALIC; |
| - } |
| InitFont(); |
| } |
| @@ -144,9 +144,8 @@ CFGAS_GEFont::~CFGAS_GEFont() { |
| void CFGAS_GEFont::Release() { |
| if (--m_iRefCount < 1) { |
| - if (m_pFontMgr) { |
| + if (m_pFontMgr) |
| m_pFontMgr->RemoveFont(this); |
| - } |
| delete this; |
| } |
| } |
| @@ -159,45 +158,35 @@ CFGAS_GEFont* CFGAS_GEFont::Retain() { |
| bool CFGAS_GEFont::LoadFontInternal(const FX_WCHAR* pszFontFamily, |
| uint32_t dwFontStyles, |
| uint16_t wCodePage) { |
| - if (m_pFont) { |
| + if (m_pFont) |
| return false; |
| - } |
| CFX_ByteString csFontFamily; |
| - if (pszFontFamily) { |
| + if (pszFontFamily) |
| csFontFamily = CFX_ByteString::FromUnicode(pszFontFamily); |
| - } |
| uint32_t dwFlags = 0; |
| - if (dwFontStyles & FX_FONTSTYLE_FixedPitch) { |
| + if (dwFontStyles & FX_FONTSTYLE_FixedPitch) |
| dwFlags |= FXFONT_FIXED_PITCH; |
| - } |
| - if (dwFontStyles & FX_FONTSTYLE_Serif) { |
| + if (dwFontStyles & FX_FONTSTYLE_Serif) |
| dwFlags |= FXFONT_SERIF; |
| - } |
| - if (dwFontStyles & FX_FONTSTYLE_Symbolic) { |
| + if (dwFontStyles & FX_FONTSTYLE_Symbolic) |
| dwFlags |= FXFONT_SYMBOLIC; |
| - } |
| - if (dwFontStyles & FX_FONTSTYLE_Script) { |
| + if (dwFontStyles & FX_FONTSTYLE_Script) |
| dwFlags |= FXFONT_SCRIPT; |
| - } |
| - if (dwFontStyles & FX_FONTSTYLE_Italic) { |
| + if (dwFontStyles & FX_FONTSTYLE_Italic) |
| dwFlags |= FXFONT_ITALIC; |
| - } |
| - if (dwFontStyles & FX_FONTSTYLE_Bold) { |
| + if (dwFontStyles & FX_FONTSTYLE_Bold) |
| dwFlags |= FXFONT_BOLD; |
| - } |
| - if (dwFontStyles & FX_FONTSTYLE_ExactMatch) { |
| + if (dwFontStyles & FX_FONTSTYLE_ExactMatch) |
| dwFlags |= FXFONT_EXACTMATCH; |
| - } |
| int32_t iWeight = |
| (dwFontStyles & FX_FONTSTYLE_Bold) ? FXFONT_FW_BOLD : FXFONT_FW_NORMAL; |
| m_pFont = new CFX_Font; |
| - if ((dwFlags & FXFONT_ITALIC) && (dwFlags & FXFONT_BOLD)) { |
| + if ((dwFlags & FXFONT_ITALIC) && (dwFlags & FXFONT_BOLD)) |
| csFontFamily += ",BoldItalic"; |
| - } else if (dwFlags & FXFONT_BOLD) { |
| + else if (dwFlags & FXFONT_BOLD) |
| csFontFamily += ",Bold"; |
| - } else if (dwFlags & FXFONT_ITALIC) { |
| + else if (dwFlags & FXFONT_ITALIC) |
| csFontFamily += ",Italic"; |
| - } |
| m_pFont->LoadSubst(csFontFamily, true, dwFlags, iWeight, 0, wCodePage, false); |
| if (!m_pFont->GetFace()) |
| return false; |
| @@ -255,12 +244,14 @@ bool CFGAS_GEFont::InitFont() { |
| if (!m_pFontEncoding) |
| return false; |
| } |
| - if (!m_pCharWidthMap) |
| - m_pCharWidthMap.reset(new CFX_DiscreteArrayTemplate<uint16_t>(1024)); |
| + if (!m_pCharWidthMap) { |
| + m_pCharWidthMap = |
| + pdfium::MakeUnique<CFX_DiscreteArrayTemplate<uint16_t>>(1024); |
| + } |
| if (!m_pRectArray) |
| - m_pRectArray.reset(new CFX_MassArrayTemplate<CFX_Rect>(16)); |
| + m_pRectArray = pdfium::MakeUnique<CFX_MassArrayTemplate<CFX_Rect>>(16); |
| if (!m_pBBoxMap) |
| - m_pBBoxMap.reset(new CFX_MapPtrToPtr(16)); |
| + m_pBBoxMap = pdfium::MakeUnique<CFX_MapPtrToPtr>(16); |
| return true; |
| } |
| @@ -271,7 +262,8 @@ CFGAS_GEFont* CFGAS_GEFont::Derive(uint32_t dwFontStyles, uint16_t wCodePage) { |
| return new CFGAS_GEFont(this, dwFontStyles); |
| } |
| -void CFGAS_GEFont::GetFamilyName(CFX_WideString& wsFamily) const { |
| +CFX_WideString CFGAS_GEFont::GetFamilyName() const { |
| + CFX_WideString wsFamily; |
| if (!m_pFont->GetSubstFont() || |
| m_pFont->GetSubstFont()->m_Family.GetLength() == 0) { |
| wsFamily = CFX_WideString::FromLocal(m_pFont->GetFamilyName().AsStringC()); |
|
Tom Sepez
2016/11/21 21:17:51
nit: local not needed, just return CFX_WideString:
npm
2016/11/21 21:29:38
Done.
|
| @@ -279,6 +271,7 @@ void CFGAS_GEFont::GetFamilyName(CFX_WideString& wsFamily) const { |
| wsFamily = CFX_WideString::FromLocal( |
| m_pFont->GetSubstFont()->m_Family.AsStringC()); |
| } |
| + return wsFamily; |
| } |
| uint32_t CFGAS_GEFont::GetFontStyles() const { |
| @@ -329,9 +322,8 @@ bool CFGAS_GEFont::GetCharWidthInternal(FX_WCHAR wUnicode, |
| if (iGlyph != 0xFFFF && pFont) { |
| if (pFont == this) { |
| iWidth = m_pFont->GetGlyphWidth(iGlyph); |
| - if (iWidth < 0) { |
| + if (iWidth < 0) |
| iWidth = -1; |
| - } |
| } else if (pFont->GetCharWidthInternal(wUnicode, iWidth, false, |
| bCharCode)) { |
| return true; |
| @@ -381,26 +373,22 @@ bool CFGAS_GEFont::GetCharBBoxInternal(FX_WCHAR wUnicode, |
| bbox = *static_cast<const CFX_Rect*>(pRect); |
| return true; |
| } |
| + |
| bool CFGAS_GEFont::GetBBox(CFX_Rect& bbox) { |
| FX_RECT rt(0, 0, 0, 0); |
| - bool bRet = m_pFont->GetBBox(rt); |
| - if (bRet) { |
| - bbox.left = rt.left; |
| - bbox.width = rt.Width(); |
| - bbox.top = rt.bottom; |
| - bbox.height = -rt.Height(); |
| - } |
| - return bRet; |
| -} |
| -int32_t CFGAS_GEFont::GetItalicAngle() const { |
| - if (!m_pFont->GetSubstFont()) { |
| - return 0; |
| - } |
| - return m_pFont->GetSubstFont()->m_ItalicAngle; |
| + if (!m_pFont->GetBBox(rt)) |
| + return false; |
| + bbox.left = rt.left; |
| + bbox.width = rt.Width(); |
| + bbox.top = rt.bottom; |
| + bbox.height = -rt.Height(); |
| + return true; |
| } |
| + |
| int32_t CFGAS_GEFont::GetGlyphIndex(FX_WCHAR wUnicode, bool bCharCode) { |
| return GetGlyphIndex(wUnicode, true, nullptr, bCharCode); |
| } |
| + |
| int32_t CFGAS_GEFont::GetGlyphIndex(FX_WCHAR wUnicode, |
| bool bRecursive, |
| CFGAS_GEFont** ppFont, |
| @@ -408,19 +396,18 @@ int32_t CFGAS_GEFont::GetGlyphIndex(FX_WCHAR wUnicode, |
| ASSERT(m_pFontEncoding); |
| int32_t iGlyphIndex = m_pFontEncoding->GlyphFromCharCode(wUnicode); |
| if (iGlyphIndex > 0) { |
| - if (ppFont) { |
| + if (ppFont) |
| *ppFont = this; |
| - } |
| return iGlyphIndex; |
| } |
| const FGAS_FONTUSB* pFontUSB = FGAS_GetUnicodeBitField(wUnicode); |
| - if (!pFontUSB) { |
| + if (!pFontUSB) |
| return 0xFFFF; |
| - } |
| + |
| uint16_t wBitField = pFontUSB->wBitField; |
| - if (wBitField >= 128) { |
| + if (wBitField >= 128) |
| return 0xFFFF; |
| - } |
| + |
| auto it = m_FontMapper.find(wUnicode); |
| CFGAS_GEFont* pFont = it != m_FontMapper.end() ? it->second : nullptr; |
| if (pFont && pFont != this) { |
| @@ -435,55 +422,43 @@ int32_t CFGAS_GEFont::GetGlyphIndex(FX_WCHAR wUnicode, |
| } |
| } |
| } |
| - if (m_pFontMgr && bRecursive) { |
| - CFX_WideString wsFamily; |
| - GetFamilyName(wsFamily); |
| - CFGAS_GEFont* pFont = m_pFontMgr->GetFontByUnicode( |
| - wUnicode, GetFontStyles(), wsFamily.c_str()); |
| + if (!m_pFontMgr || !bRecursive) |
| + return 0xFFFF; |
| + CFX_WideString wsFamily = GetFamilyName(); |
| + pFont = |
| + m_pFontMgr->GetFontByUnicode(wUnicode, GetFontStyles(), wsFamily.c_str()); |
| #if _FXM_PLATFORM_ != _FXM_PLATFORM_WINDOWS_ |
| - if (!pFont) |
| - pFont = m_pFontMgr->GetFontByUnicode(wUnicode, GetFontStyles(), nullptr); |
| + if (!pFont) |
| + pFont = m_pFontMgr->GetFontByUnicode(wUnicode, GetFontStyles(), nullptr); |
| #endif |
| - if (pFont) { |
| - if (pFont == this) { |
| - pFont->Release(); |
| - return 0xFFFF; |
| - } |
| - m_FontMapper[wUnicode] = pFont; |
| - int32_t i = m_SubstFonts.GetSize(); |
| - m_SubstFonts.Add(pFont); |
| - iGlyphIndex = pFont->GetGlyphIndex(wUnicode, false, nullptr, bCharCode); |
| - if (iGlyphIndex != 0xFFFF) { |
| - iGlyphIndex |= ((i + 1) << 24); |
| - if (ppFont) |
| - *ppFont = pFont; |
| - return iGlyphIndex; |
| - } |
| - } |
| + if (!pFont) |
| + return 0xFFFF; |
| + if (pFont == this) { |
| + pFont->Release(); |
| + return 0xFFFF; |
| } |
| - return 0xFFFF; |
| + m_FontMapper[wUnicode] = pFont; |
| + int32_t i = m_SubstFonts.GetSize(); |
| + m_SubstFonts.Add(pFont); |
| + iGlyphIndex = pFont->GetGlyphIndex(wUnicode, false, nullptr, bCharCode); |
| + if (iGlyphIndex == 0xFFFF) |
| + return 0xFFFF; |
| + iGlyphIndex |= ((i + 1) << 24); |
| + if (ppFont) |
| + *ppFont = pFont; |
| + return iGlyphIndex; |
| } |
| + |
| int32_t CFGAS_GEFont::GetAscent() const { |
| return m_pFont->GetAscent(); |
| } |
| + |
| int32_t CFGAS_GEFont::GetDescent() const { |
| return m_pFont->GetDescent(); |
| } |
| -void CFGAS_GEFont::Reset() { |
| - for (int32_t i = 0; i < m_SubstFonts.GetSize(); i++) |
| - m_SubstFonts[i]->Reset(); |
| - if (m_pCharWidthMap) { |
| - m_pCharWidthMap->RemoveAll(); |
| - } |
| - if (m_pBBoxMap) { |
| - m_pBBoxMap->RemoveAll(); |
| - } |
| - if (m_pRectArray) { |
| - m_pRectArray->RemoveAll(false); |
| - } |
| -} |
| + |
| CFGAS_GEFont* CFGAS_GEFont::GetSubstFont(int32_t iGlyphIndex) const { |
| - iGlyphIndex = ((uint32_t)iGlyphIndex) >> 24; |
| + iGlyphIndex = static_cast<uint32_t>(iGlyphIndex) >> 24; |
| return iGlyphIndex == 0 ? const_cast<CFGAS_GEFont*>(this) |
| : m_SubstFonts[iGlyphIndex - 1]; |
| } |