OLD | NEW |
1 /* | 1 /* |
2 * Copyright (C) 2008 Apple Inc. All rights reserved. | 2 * Copyright (C) 2008 Apple Inc. All rights reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
6 * are met: | 6 * are met: |
7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
(...skipping 88 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
99 return; | 99 return; |
100 | 100 |
101 if (it == m_firstNonCssConnectedFace) | 101 if (it == m_firstNonCssConnectedFace) |
102 ++m_firstNonCssConnectedFace; | 102 ++m_firstNonCssConnectedFace; |
103 m_fontFaces.remove(it); | 103 m_fontFaces.remove(it); |
104 | 104 |
105 pruneTable(); | 105 pruneTable(); |
106 fontFace->cssFontFace()->clearSegmentedFontFace(); | 106 fontFace->cssFontFace()->clearSegmentedFontFace(); |
107 } | 107 } |
108 | 108 |
| 109 static void appendFontData(SegmentedFontData* newFontData, PassRefPtr<SimpleFont
Data> prpFaceFontData, const UnicodeRangeSet& ranges) |
| 110 { |
| 111 RefPtr<SimpleFontData> faceFontData = prpFaceFontData; |
| 112 unsigned numRanges = ranges.size(); |
| 113 if (!numRanges) { |
| 114 newFontData->appendRange(FontDataRange(0, 0x7FFFFFFF, faceFontData)); |
| 115 return; |
| 116 } |
| 117 |
| 118 for (unsigned j = 0; j < numRanges; ++j) |
| 119 newFontData->appendRange(FontDataRange(ranges.rangeAt(j).from(), ranges.
rangeAt(j).to(), faceFontData)); |
| 120 } |
| 121 |
109 PassRefPtr<FontData> CSSSegmentedFontFace::getFontData(const FontDescription& fo
ntDescription) | 122 PassRefPtr<FontData> CSSSegmentedFontFace::getFontData(const FontDescription& fo
ntDescription) |
110 { | 123 { |
111 if (!isValid()) | 124 if (!isValid()) |
112 return nullptr; | 125 return nullptr; |
113 | 126 |
114 FontTraits desiredTraits = fontDescription.traits(); | 127 FontTraits desiredTraits = fontDescription.traits(); |
115 FontCacheKey key = fontDescription.cacheKey(FontFaceCreationParams(), desire
dTraits); | 128 FontCacheKey key = fontDescription.cacheKey(FontFaceCreationParams(), desire
dTraits); |
116 | 129 |
117 RefPtr<SegmentedFontData>& fontData = m_fontDataTable.add(key.hash(), nullpt
r).storedValue->value; | 130 RefPtr<SegmentedFontData>& fontData = m_fontDataTable.add(key.hash(), nullpt
r).storedValue->value; |
118 if (fontData && fontData->numFaces()) | 131 if (fontData && fontData->numRanges()) |
119 return fontData; // No release, we have a reference to an object in the
cache which should retain the ref count it has. | 132 return fontData; // No release, we have a reference to an object in the
cache which should retain the ref count it has. |
120 | 133 |
121 if (!fontData) | 134 if (!fontData) |
122 fontData = SegmentedFontData::create(); | 135 fontData = SegmentedFontData::create(); |
123 | 136 |
124 FontDescription requestedFontDescription(fontDescription); | 137 FontDescription requestedFontDescription(fontDescription); |
125 requestedFontDescription.setTraits(m_traits); | 138 requestedFontDescription.setTraits(m_traits); |
126 requestedFontDescription.setSyntheticBold(m_traits.weight() < FontWeight600
&& desiredTraits.weight() >= FontWeight600); | 139 requestedFontDescription.setSyntheticBold(m_traits.weight() < FontWeight600
&& desiredTraits.weight() >= FontWeight600); |
127 requestedFontDescription.setSyntheticItalic(m_traits.style() == FontStyleNor
mal && desiredTraits.style() == FontStyleItalic); | 140 requestedFontDescription.setSyntheticItalic(m_traits.style() == FontStyleNor
mal && desiredTraits.style() == FontStyleItalic); |
128 | 141 |
129 for (FontFaceList::reverse_iterator it = m_fontFaces.rbegin(); it != m_fontF
aces.rend(); ++it) { | 142 for (FontFaceList::reverse_iterator it = m_fontFaces.rbegin(); it != m_fontF
aces.rend(); ++it) { |
130 if (!(*it)->cssFontFace()->isValid()) | 143 if (!(*it)->cssFontFace()->isValid()) |
131 continue; | 144 continue; |
132 if (RefPtr<SimpleFontData> faceFontData = (*it)->cssFontFace()->getFontD
ata(requestedFontDescription)) { | 145 if (RefPtr<SimpleFontData> faceFontData = (*it)->cssFontFace()->getFontD
ata(requestedFontDescription)) { |
133 ASSERT(!faceFontData->isSegmented()); | 146 ASSERT(!faceFontData->isSegmented()); |
134 fontData->appendFace(FontDataForRangeSet(faceFontData.release(), (*i
t)->cssFontFace()->ranges())); | 147 appendFontData(fontData.get(), faceFontData.release(), (*it)->cssFon
tFace()->ranges()); |
135 } | 148 } |
136 } | 149 } |
137 if (fontData->numFaces()) | 150 if (fontData->numRanges()) |
138 return fontData; // No release, we have a reference to an object in the
cache which should retain the ref count it has. | 151 return fontData; // No release, we have a reference to an object in the
cache which should retain the ref count it has. |
139 | 152 |
140 return nullptr; | 153 return nullptr; |
141 } | 154 } |
142 | 155 |
143 void CSSSegmentedFontFace::willUseFontData(const FontDescription& fontDescriptio
n, UChar32 character) | 156 void CSSSegmentedFontFace::willUseFontData(const FontDescription& fontDescriptio
n, UChar32 character) |
144 { | 157 { |
145 for (FontFaceList::reverse_iterator it = m_fontFaces.rbegin(); it != m_fontF
aces.rend(); ++it) { | 158 for (FontFaceList::reverse_iterator it = m_fontFaces.rbegin(); it != m_fontF
aces.rend(); ++it) { |
146 if ((*it)->loadStatus() != FontFace::Unloaded) | 159 if ((*it)->loadStatus() != FontFace::Unloaded) |
147 break; | 160 break; |
148 if ((*it)->cssFontFace()->maybeScheduleFontLoad(fontDescription, charact
er)) | 161 if ((*it)->cssFontFace()->maybeScheduleFontLoad(fontDescription, charact
er)) |
149 break; | 162 break; |
150 } | 163 } |
151 } | 164 } |
152 | 165 |
153 void CSSSegmentedFontFace::willUseRange(const blink::FontDescription& fontDescri
ption, const blink::FontDataForRangeSet& rangeSet) | 166 void CSSSegmentedFontFace::willUseRange(const blink::FontDescription& fontDescri
ption, const blink::FontDataRange& range) |
154 { | 167 { |
155 // Iterating backwards since later defined unicode-range faces override | 168 // Iterating backwards since later defined unicode-range faces override |
156 // previously defined ones, according to the CSS3 fonts module. | 169 // previously defined ones, according to the CSS3 fonts module. |
157 // https://drafts.csswg.org/css-fonts/#composite-fonts | 170 // https://drafts.csswg.org/css-fonts/#composite-fonts |
158 for (FontFaceList::reverse_iterator it = m_fontFaces.rbegin(); it != m_fontF
aces.rend(); ++it) { | 171 for (FontFaceList::reverse_iterator it = m_fontFaces.rbegin(); it != m_fontF
aces.rend(); ++it) { |
159 CSSFontFace* cssFontFace = (*it)->cssFontFace(); | 172 CSSFontFace* cssFontFace = (*it)->cssFontFace(); |
160 if (cssFontFace->maybeScheduleFontLoad(fontDescription, rangeSet)) | 173 if (cssFontFace->maybeScheduleFontLoad(fontDescription, range)) |
161 break; | 174 break; |
162 } | 175 } |
163 } | 176 } |
164 | 177 |
165 bool CSSSegmentedFontFace::checkFont(const String& text) const | 178 bool CSSSegmentedFontFace::checkFont(const String& text) const |
166 { | 179 { |
167 for (const auto& fontFace : m_fontFaces) { | 180 for (const auto& fontFace : m_fontFaces) { |
168 if (fontFace->loadStatus() != FontFace::Loaded && fontFace->cssFontFace(
)->ranges()->intersectsWith(text)) | 181 if (fontFace->loadStatus() != FontFace::Loaded && fontFace->cssFontFace(
)->ranges().intersectsWith(text)) |
169 return false; | 182 return false; |
170 } | 183 } |
171 return true; | 184 return true; |
172 } | 185 } |
173 | 186 |
174 void CSSSegmentedFontFace::match(const String& text, WillBeHeapVector<RefPtrWill
BeMember<FontFace>>& faces) const | 187 void CSSSegmentedFontFace::match(const String& text, WillBeHeapVector<RefPtrWill
BeMember<FontFace>>& faces) const |
175 { | 188 { |
176 for (const auto& fontFace : m_fontFaces) { | 189 for (const auto& fontFace : m_fontFaces) { |
177 if (fontFace->cssFontFace()->ranges()->intersectsWith(text)) | 190 if (fontFace->cssFontFace()->ranges().intersectsWith(text)) |
178 faces.append(fontFace); | 191 faces.append(fontFace); |
179 } | 192 } |
180 } | 193 } |
181 | 194 |
182 DEFINE_TRACE(CSSSegmentedFontFace) | 195 DEFINE_TRACE(CSSSegmentedFontFace) |
183 { | 196 { |
184 #if ENABLE(OILPAN) | 197 #if ENABLE(OILPAN) |
185 visitor->trace(m_fontSelector); | 198 visitor->trace(m_fontSelector); |
186 visitor->trace(m_fontFaces); | 199 visitor->trace(m_fontFaces); |
187 #endif | 200 #endif |
188 } | 201 } |
189 | 202 |
190 } // namespace blink | 203 } // namespace blink |
OLD | NEW |