OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2007 Nicholas Shanks <contact@nickshanks.com> | 2 * Copyright (C) 2007 Nicholas Shanks <contact@nickshanks.com> |
3 * Copyright (C) 2008 Apple Inc. All rights reserved. | 3 * Copyright (C) 2008 Apple Inc. All rights reserved. |
4 * | 4 * |
5 * Redistribution and use in source and binary forms, with or without | 5 * Redistribution and use in source and binary forms, with or without |
6 * modification, are permitted provided that the following conditions | 6 * modification, are permitted provided that the following conditions |
7 * are met: | 7 * are met: |
8 * | 8 * |
9 * 1. Redistributions of source code must retain the above copyright | 9 * 1. Redistributions of source code must retain the above copyright |
10 * notice, this list of conditions and the following disclaimer. | 10 * notice, this list of conditions and the following disclaimer. |
(...skipping 22 matching lines...) Expand all Loading... |
33 #include "platform/RuntimeEnabledFeatures.h" | 33 #include "platform/RuntimeEnabledFeatures.h" |
34 #include "wtf/text/AtomicStringHash.h" | 34 #include "wtf/text/AtomicStringHash.h" |
35 #include "wtf/text/StringHash.h" | 35 #include "wtf/text/StringHash.h" |
36 | 36 |
37 namespace blink { | 37 namespace blink { |
38 | 38 |
39 struct SameSizeAsFontDescription { | 39 struct SameSizeAsFontDescription { |
40 FontFamily familyList; | 40 FontFamily familyList; |
41 RefPtr<FontFeatureSettings> m_featureSettings; | 41 RefPtr<FontFeatureSettings> m_featureSettings; |
42 AtomicString locale; | 42 AtomicString locale; |
43 float sizes[4]; | 43 float sizes[5]; |
44 // FXIME: Make them fit into one word. | 44 // FXIME: Make them fit into one word. |
45 uint32_t bitfields; | 45 uint32_t bitfields; |
46 uint32_t bitfields2 : 7; | 46 uint32_t bitfields2 : 7; |
47 }; | 47 }; |
48 | 48 |
49 static_assert(sizeof(FontDescription) == sizeof(SameSizeAsFontDescription), "Fon
tDescription should stay small"); | 49 static_assert(sizeof(FontDescription) == sizeof(SameSizeAsFontDescription), "Fon
tDescription should stay small"); |
50 | 50 |
51 TypesettingFeatures FontDescription::s_defaultTypesettingFeatures = 0; | 51 TypesettingFeatures FontDescription::s_defaultTypesettingFeatures = 0; |
52 | 52 |
53 bool FontDescription::s_useSubpixelTextPositioning = false; | 53 bool FontDescription::s_useSubpixelTextPositioning = false; |
(...skipping 99 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
153 m_historicalLigaturesState = ligatures.historical; | 153 m_historicalLigaturesState = ligatures.historical; |
154 m_contextualLigaturesState = ligatures.contextual; | 154 m_contextualLigaturesState = ligatures.contextual; |
155 | 155 |
156 updateTypesettingFeatures(); | 156 updateTypesettingFeatures(); |
157 } | 157 } |
158 | 158 |
159 float FontDescription::effectiveFontSize() const | 159 float FontDescription::effectiveFontSize() const |
160 { | 160 { |
161 // Ensure that the effective precision matches the font-cache precision. | 161 // Ensure that the effective precision matches the font-cache precision. |
162 // This guarantees that the same precision is used regardless of cache statu
s. | 162 // This guarantees that the same precision is used regardless of cache statu
s. |
163 return floorf(computedSize() * FontCacheKey::precisionMultiplier()) / FontCa
cheKey::precisionMultiplier(); | 163 float computedOrAdjustedSize = adjustedSize() ? adjustedSize() : computedSiz
e(); |
| 164 return floorf(computedOrAdjustedSize * FontCacheKey::precisionMultiplier())
/ FontCacheKey::precisionMultiplier(); |
164 } | 165 } |
165 | 166 |
166 FontCacheKey FontDescription::cacheKey(const FontFaceCreationParams& creationPar
ams, FontTraits desiredTraits) const | 167 FontCacheKey FontDescription::cacheKey(const FontFaceCreationParams& creationPar
ams, FontTraits desiredTraits) const |
167 { | 168 { |
168 FontTraits fontTraits = desiredTraits.bitfield() ? desiredTraits : traits(); | 169 FontTraits fontTraits = desiredTraits.bitfield() ? desiredTraits : traits(); |
169 | 170 |
170 unsigned options = | 171 unsigned options = |
171 static_cast<unsigned>(m_syntheticItalic) << 5 | // bit 6 | 172 static_cast<unsigned>(m_syntheticItalic) << 5 | // bit 6 |
172 static_cast<unsigned>(m_syntheticBold) << 4 | // bit 5 | 173 static_cast<unsigned>(m_syntheticBold) << 4 | // bit 5 |
173 static_cast<unsigned>(m_textRendering) << 2 | // bits 3-4 | 174 static_cast<unsigned>(m_textRendering) << 2 | // bits 3-4 |
(...skipping 59 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
233 | 234 |
234 if (discretionaryLigaturesState() == FontDescription::EnabledLigaturesSt
ate | 235 if (discretionaryLigaturesState() == FontDescription::EnabledLigaturesSt
ate |
235 || historicalLigaturesState() == FontDescription::EnabledLigaturesSt
ate | 236 || historicalLigaturesState() == FontDescription::EnabledLigaturesSt
ate |
236 || contextualLigaturesState() == FontDescription::EnabledLigaturesSt
ate) { | 237 || contextualLigaturesState() == FontDescription::EnabledLigaturesSt
ate) { |
237 m_typesettingFeatures |= blink::Ligatures; | 238 m_typesettingFeatures |= blink::Ligatures; |
238 } | 239 } |
239 } | 240 } |
240 } | 241 } |
241 | 242 |
242 } // namespace blink | 243 } // namespace blink |
OLD | NEW |