blob: 1dd623d24cddf32634fd04177432559e1901b4df [file] [log] [blame]
epoger@google.comec3ed6a2011-07-28 14:26:00 +00001
reed@google.comac10a2d2010-12-22 21:39:39 +00002/*
epoger@google.comec3ed6a2011-07-28 14:26:00 +00003 * Copyright 2010 Google Inc.
4 *
5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file.
reed@google.comac10a2d2010-12-22 21:39:39 +00007 */
8
9
epoger@google.comec3ed6a2011-07-28 14:26:00 +000010
reed@google.comac10a2d2010-12-22 21:39:39 +000011#ifndef GrTextStrike_impl_DEFINED
12#define GrTextStrike_impl_DEFINED
13
14class GrFontCache::Key {
15public:
jvanverth733f5f52014-07-11 19:45:16 -070016 explicit Key(const GrFontDescKey* fontScalarKey) {
commit-bot@chromium.orgb2e9fa52013-10-27 20:50:23 +000017 fFontScalerKey = fontScalarKey;
reed@google.comac10a2d2010-12-22 21:39:39 +000018 }
rmistry@google.comd6176b02012-08-23 18:14:13 +000019
robertphillips@google.com8b169312013-10-15 17:47:36 +000020 intptr_t getHash() const { return fFontScalerKey->getHash(); }
rmistry@google.comd6176b02012-08-23 18:14:13 +000021
rmistry@google.comd6bab022013-12-02 13:50:38 +000022 static bool LessThan(const GrTextStrike& strike, const Key& key) {
reed@google.comac10a2d2010-12-22 21:39:39 +000023 return *strike.getFontScalerKey() < *key.fFontScalerKey;
24 }
rmistry@google.comd6bab022013-12-02 13:50:38 +000025 static bool Equals(const GrTextStrike& strike, const Key& key) {
reed@google.comac10a2d2010-12-22 21:39:39 +000026 return *strike.getFontScalerKey() == *key.fFontScalerKey;
27 }
rmistry@google.comd6176b02012-08-23 18:14:13 +000028
reed@google.comac10a2d2010-12-22 21:39:39 +000029private:
jvanverth733f5f52014-07-11 19:45:16 -070030 const GrFontDescKey* fFontScalerKey;
reed@google.comac10a2d2010-12-22 21:39:39 +000031};
32
33void GrFontCache::detachStrikeFromList(GrTextStrike* strike) {
34 if (strike->fPrev) {
tfarina@chromium.orgf6de4752013-08-17 00:02:59 +000035 SkASSERT(fHead != strike);
reed@google.comac10a2d2010-12-22 21:39:39 +000036 strike->fPrev->fNext = strike->fNext;
37 } else {
tfarina@chromium.orgf6de4752013-08-17 00:02:59 +000038 SkASSERT(fHead == strike);
reed@google.comac10a2d2010-12-22 21:39:39 +000039 fHead = strike->fNext;
40 }
41
42 if (strike->fNext) {
tfarina@chromium.orgf6de4752013-08-17 00:02:59 +000043 SkASSERT(fTail != strike);
reed@google.comac10a2d2010-12-22 21:39:39 +000044 strike->fNext->fPrev = strike->fPrev;
45 } else {
tfarina@chromium.orgf6de4752013-08-17 00:02:59 +000046 SkASSERT(fTail == strike);
reed@google.comac10a2d2010-12-22 21:39:39 +000047 fTail = strike->fPrev;
48 }
49}
50
jvanverth@google.comd830d132013-11-11 20:54:09 +000051GrTextStrike* GrFontCache::getStrike(GrFontScaler* scaler, bool useDistanceField) {
reed@google.comac10a2d2010-12-22 21:39:39 +000052 this->validate();
rmistry@google.comd6176b02012-08-23 18:14:13 +000053
commit-bot@chromium.orgb2e9fa52013-10-27 20:50:23 +000054 const Key key(scaler->getKey());
reed@google.comac10a2d2010-12-22 21:39:39 +000055 GrTextStrike* strike = fCache.find(key);
56 if (NULL == strike) {
57 strike = this->generateStrike(scaler, key);
58 } else if (strike->fPrev) {
59 // Need to put the strike at the head of its dllist, since that is how
commit-bot@chromium.org53e1e4d2014-04-01 16:25:11 +000060 // we age the strikes for purging (we purge from the back of the list)
reed@google.comac10a2d2010-12-22 21:39:39 +000061 this->detachStrikeFromList(strike);
62 // attach at the head
63 fHead->fPrev = strike;
64 strike->fNext = fHead;
65 strike->fPrev = NULL;
66 fHead = strike;
67 }
jvanverth@google.comd830d132013-11-11 20:54:09 +000068 strike->fUseDistanceField = useDistanceField;
reed@google.comac10a2d2010-12-22 21:39:39 +000069 this->validate();
70 return strike;
71}
72
73///////////////////////////////////////////////////////////////////////////////
74
75/**
76 * This Key just wraps a glyphID, and matches the protocol need for
77 * GrTHashTable
78 */
79class GrTextStrike::Key {
80public:
81 Key(GrGlyph::PackedID id) : fPackedID(id) {}
rmistry@google.comd6176b02012-08-23 18:14:13 +000082
reed@google.comac10a2d2010-12-22 21:39:39 +000083 uint32_t getHash() const { return fPackedID; }
rmistry@google.comd6176b02012-08-23 18:14:13 +000084
rmistry@google.comd6bab022013-12-02 13:50:38 +000085 static bool LessThan(const GrGlyph& glyph, const Key& key) {
reed@google.comac10a2d2010-12-22 21:39:39 +000086 return glyph.fPackedID < key.fPackedID;
87 }
rmistry@google.comd6bab022013-12-02 13:50:38 +000088 static bool Equals(const GrGlyph& glyph, const Key& key) {
reed@google.comac10a2d2010-12-22 21:39:39 +000089 return glyph.fPackedID == key.fPackedID;
90 }
rmistry@google.comd6176b02012-08-23 18:14:13 +000091
reed@google.comac10a2d2010-12-22 21:39:39 +000092private:
93 GrGlyph::PackedID fPackedID;
94};
95
96GrGlyph* GrTextStrike::getGlyph(GrGlyph::PackedID packed,
97 GrFontScaler* scaler) {
98 GrGlyph* glyph = fCache.find(packed);
99 if (NULL == glyph) {
100 glyph = this->generateGlyph(packed, scaler);
101 }
102 return glyph;
103}
104
105#endif