OLD | NEW |
1 // Copyright 2014 PDFium Authors. All rights reserved. | 1 // Copyright 2014 PDFium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com | 5 // Original code copyright 2014 Foxit Software Inc. http://www.foxitsoftware.com |
6 | 6 |
7 #include "fpdfsdk/pdfwindow/PWL_FontMap.h" | 7 #include "fpdfsdk/pdfwindow/PWL_FontMap.h" |
8 | 8 |
9 #include "core/fpdfapi/cpdf_modulemgr.h" | 9 #include "core/fpdfapi/cpdf_modulemgr.h" |
10 #include "core/fpdfapi/font/cpdf_font.h" | 10 #include "core/fpdfapi/font/cpdf_font.h" |
(...skipping 58 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
69 CFX_ByteString CPWL_FontMap::GetPDFFontAlias(int32_t nFontIndex) { | 69 CFX_ByteString CPWL_FontMap::GetPDFFontAlias(int32_t nFontIndex) { |
70 if (nFontIndex >= 0 && nFontIndex < m_aData.GetSize()) { | 70 if (nFontIndex >= 0 && nFontIndex < m_aData.GetSize()) { |
71 if (CPWL_FontMap_Data* pData = m_aData.GetAt(nFontIndex)) { | 71 if (CPWL_FontMap_Data* pData = m_aData.GetAt(nFontIndex)) { |
72 return pData->sFontName; | 72 return pData->sFontName; |
73 } | 73 } |
74 } | 74 } |
75 | 75 |
76 return ""; | 76 return ""; |
77 } | 77 } |
78 | 78 |
79 FX_BOOL CPWL_FontMap::KnowWord(int32_t nFontIndex, uint16_t word) { | 79 bool CPWL_FontMap::KnowWord(int32_t nFontIndex, uint16_t word) { |
80 if (nFontIndex >= 0 && nFontIndex < m_aData.GetSize()) { | 80 if (nFontIndex >= 0 && nFontIndex < m_aData.GetSize()) { |
81 if (m_aData.GetAt(nFontIndex)) { | 81 if (m_aData.GetAt(nFontIndex)) { |
82 return CharCodeFromUnicode(nFontIndex, word) >= 0; | 82 return CharCodeFromUnicode(nFontIndex, word) >= 0; |
83 } | 83 } |
84 } | 84 } |
85 | 85 |
86 return FALSE; | 86 return false; |
87 } | 87 } |
88 | 88 |
89 int32_t CPWL_FontMap::GetWordFontIndex(uint16_t word, | 89 int32_t CPWL_FontMap::GetWordFontIndex(uint16_t word, |
90 int32_t nCharset, | 90 int32_t nCharset, |
91 int32_t nFontIndex) { | 91 int32_t nFontIndex) { |
92 if (nFontIndex > 0) { | 92 if (nFontIndex > 0) { |
93 if (KnowWord(nFontIndex, word)) | 93 if (KnowWord(nFontIndex, word)) |
94 return nFontIndex; | 94 return nFontIndex; |
95 } else { | 95 } else { |
96 if (const CPWL_FontMap_Data* pData = GetFontMapData(0)) { | 96 if (const CPWL_FontMap_Data* pData = GetFontMapData(0)) { |
97 if (nCharset == FXFONT_DEFAULT_CHARSET || | 97 if (nCharset == FXFONT_DEFAULT_CHARSET || |
98 pData->nCharset == FXFONT_SYMBOL_CHARSET || | 98 pData->nCharset == FXFONT_SYMBOL_CHARSET || |
99 nCharset == pData->nCharset) { | 99 nCharset == pData->nCharset) { |
100 if (KnowWord(0, word)) | 100 if (KnowWord(0, word)) |
101 return 0; | 101 return 0; |
102 } | 102 } |
103 } | 103 } |
104 } | 104 } |
105 | 105 |
106 int32_t nNewFontIndex = | 106 int32_t nNewFontIndex = |
107 GetFontIndex(GetNativeFontName(nCharset), nCharset, TRUE); | 107 GetFontIndex(GetNativeFontName(nCharset), nCharset, true); |
108 if (nNewFontIndex >= 0) { | 108 if (nNewFontIndex >= 0) { |
109 if (KnowWord(nNewFontIndex, word)) | 109 if (KnowWord(nNewFontIndex, word)) |
110 return nNewFontIndex; | 110 return nNewFontIndex; |
111 } | 111 } |
112 nNewFontIndex = | 112 nNewFontIndex = |
113 GetFontIndex("Arial Unicode MS", FXFONT_DEFAULT_CHARSET, FALSE); | 113 GetFontIndex("Arial Unicode MS", FXFONT_DEFAULT_CHARSET, false); |
114 if (nNewFontIndex >= 0) { | 114 if (nNewFontIndex >= 0) { |
115 if (KnowWord(nNewFontIndex, word)) | 115 if (KnowWord(nNewFontIndex, word)) |
116 return nNewFontIndex; | 116 return nNewFontIndex; |
117 } | 117 } |
118 return -1; | 118 return -1; |
119 } | 119 } |
120 | 120 |
121 int32_t CPWL_FontMap::CharCodeFromUnicode(int32_t nFontIndex, uint16_t word) { | 121 int32_t CPWL_FontMap::CharCodeFromUnicode(int32_t nFontIndex, uint16_t word) { |
122 CPWL_FontMap_Data* pData = m_aData.GetAt(nFontIndex); | 122 CPWL_FontMap_Data* pData = m_aData.GetAt(nFontIndex); |
123 if (!pData) | 123 if (!pData) |
(...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
163 } | 163 } |
164 { | 164 { |
165 for (int32_t i = 0, sz = m_aNativeFont.GetSize(); i < sz; i++) | 165 for (int32_t i = 0, sz = m_aNativeFont.GetSize(); i < sz; i++) |
166 delete m_aNativeFont.GetAt(i); | 166 delete m_aNativeFont.GetAt(i); |
167 | 167 |
168 m_aNativeFont.RemoveAll(); | 168 m_aNativeFont.RemoveAll(); |
169 } | 169 } |
170 } | 170 } |
171 | 171 |
172 void CPWL_FontMap::Initialize() { | 172 void CPWL_FontMap::Initialize() { |
173 GetFontIndex(kDefaultFontName, FXFONT_ANSI_CHARSET, FALSE); | 173 GetFontIndex(kDefaultFontName, FXFONT_ANSI_CHARSET, false); |
174 } | 174 } |
175 | 175 |
176 FX_BOOL CPWL_FontMap::IsStandardFont(const CFX_ByteString& sFontName) { | 176 bool CPWL_FontMap::IsStandardFont(const CFX_ByteString& sFontName) { |
177 for (size_t i = 0; i < FX_ArraySize(g_sDEStandardFontName); ++i) { | 177 for (size_t i = 0; i < FX_ArraySize(g_sDEStandardFontName); ++i) { |
178 if (sFontName == g_sDEStandardFontName[i]) | 178 if (sFontName == g_sDEStandardFontName[i]) |
179 return TRUE; | 179 return true; |
180 } | 180 } |
181 | 181 |
182 return FALSE; | 182 return false; |
183 } | 183 } |
184 | 184 |
185 int32_t CPWL_FontMap::FindFont(const CFX_ByteString& sFontName, | 185 int32_t CPWL_FontMap::FindFont(const CFX_ByteString& sFontName, |
186 int32_t nCharset) { | 186 int32_t nCharset) { |
187 for (int32_t i = 0, sz = m_aData.GetSize(); i < sz; i++) { | 187 for (int32_t i = 0, sz = m_aData.GetSize(); i < sz; i++) { |
188 if (CPWL_FontMap_Data* pData = m_aData.GetAt(i)) { | 188 if (CPWL_FontMap_Data* pData = m_aData.GetAt(i)) { |
189 if (nCharset == FXFONT_DEFAULT_CHARSET || nCharset == pData->nCharset) { | 189 if (nCharset == FXFONT_DEFAULT_CHARSET || nCharset == pData->nCharset) { |
190 if (sFontName.IsEmpty() || pData->sFontName == sFontName) | 190 if (sFontName.IsEmpty() || pData->sFontName == sFontName) |
191 return i; | 191 return i; |
192 } | 192 } |
193 } | 193 } |
194 } | 194 } |
195 | 195 |
196 return -1; | 196 return -1; |
197 } | 197 } |
198 | 198 |
199 int32_t CPWL_FontMap::GetFontIndex(const CFX_ByteString& sFontName, | 199 int32_t CPWL_FontMap::GetFontIndex(const CFX_ByteString& sFontName, |
200 int32_t nCharset, | 200 int32_t nCharset, |
201 FX_BOOL bFind) { | 201 bool bFind) { |
202 int32_t nFontIndex = FindFont(EncodeFontAlias(sFontName, nCharset), nCharset); | 202 int32_t nFontIndex = FindFont(EncodeFontAlias(sFontName, nCharset), nCharset); |
203 if (nFontIndex >= 0) | 203 if (nFontIndex >= 0) |
204 return nFontIndex; | 204 return nFontIndex; |
205 | 205 |
206 CFX_ByteString sAlias; | 206 CFX_ByteString sAlias; |
207 CPDF_Font* pFont = nullptr; | 207 CPDF_Font* pFont = nullptr; |
208 if (bFind) | 208 if (bFind) |
209 pFont = FindFontSameCharset(sAlias, nCharset); | 209 pFont = FindFontSameCharset(sAlias, nCharset); |
210 | 210 |
211 if (!pFont) { | 211 if (!pFont) { |
(...skipping 227 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
439 return FXFONT_RUSSIAN_CHARSET; | 439 return FXFONT_RUSSIAN_CHARSET; |
440 | 440 |
441 if (word >= 0x0100 && word <= 0x024F) | 441 if (word >= 0x0100 && word <= 0x024F) |
442 return FXFONT_EASTEUROPE_CHARSET; | 442 return FXFONT_EASTEUROPE_CHARSET; |
443 | 443 |
444 if (word >= 0x1E00 && word <= 0x1EFF) | 444 if (word >= 0x1E00 && word <= 0x1EFF) |
445 return FXFONT_VIETNAMESE_CHARSET; | 445 return FXFONT_VIETNAMESE_CHARSET; |
446 | 446 |
447 return FXFONT_ANSI_CHARSET; | 447 return FXFONT_ANSI_CHARSET; |
448 } | 448 } |
OLD | NEW |