| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2012 Apple Inc. All rights reserved. | 2 * Copyright (C) 2012 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 |
| 11 * documentation and/or other materials provided with the distribution. | 11 * documentation and/or other materials provided with the distribution. |
| 12 * | 12 * |
| 13 * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY | 13 * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY |
| 14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | 14 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
| 15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR | 15 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR |
| 16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR | 16 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR |
| 17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, | 17 * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, |
| 18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, | 18 * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, |
| 19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR | 19 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR |
| 20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY | 20 * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY |
| 21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | 21 * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT |
| 22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 22 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
| 23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 23 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
| 24 */ | 24 */ |
| 25 | 25 |
| 26 #ifndef WidthCache_h | 26 #ifndef WidthCache_h |
| 27 #define WidthCache_h | 27 #define WidthCache_h |
| 28 | 28 |
| 29 #include "platform/geometry/IntRectOutsets.h" | 29 #include "platform/geometry/FloatRectOutsets.h" |
| 30 #include "platform/text/TextRun.h" | 30 #include "platform/text/TextRun.h" |
| 31 #include "wtf/Forward.h" | 31 #include "wtf/Forward.h" |
| 32 #include "wtf/HashFunctions.h" | 32 #include "wtf/HashFunctions.h" |
| 33 #include "wtf/HashSet.h" | 33 #include "wtf/HashSet.h" |
| 34 #include "wtf/HashTableDeletedValueType.h" | 34 #include "wtf/HashTableDeletedValueType.h" |
| 35 #include "wtf/StringHasher.h" | 35 #include "wtf/StringHasher.h" |
| 36 | 36 |
| 37 namespace blink { | 37 namespace blink { |
| 38 | 38 |
| 39 struct WidthCacheEntry { | 39 struct WidthCacheEntry { |
| 40 WidthCacheEntry() | 40 WidthCacheEntry() |
| 41 { | 41 { |
| 42 width = std::numeric_limits<float>::quiet_NaN(); | 42 width = std::numeric_limits<float>::quiet_NaN(); |
| 43 } | 43 } |
| 44 bool isValid() const { return !std::isnan(width); } | 44 bool isValid() const { return !std::isnan(width); } |
| 45 float width; | 45 float width; |
| 46 IntRectOutsets glyphBounds; | 46 FloatRectOutsets glyphBounds; |
| 47 }; | 47 }; |
| 48 | 48 |
| 49 class WidthCache { | 49 class WidthCache { |
| 50 private: | 50 private: |
| 51 // Used to optimize small strings as hash table keys. Avoids malloc'ing an o
ut-of-line StringImpl. | 51 // Used to optimize small strings as hash table keys. Avoids malloc'ing an o
ut-of-line StringImpl. |
| 52 class SmallStringKey { | 52 class SmallStringKey { |
| 53 public: | 53 public: |
| 54 static unsigned capacity() { return s_capacity; } | 54 static unsigned capacity() { return s_capacity; } |
| 55 | 55 |
| 56 SmallStringKey() | 56 SmallStringKey() |
| (...skipping 146 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 203 inline bool operator==(const WidthCache::SmallStringKey& a, const WidthCache::Sm
allStringKey& b) | 203 inline bool operator==(const WidthCache::SmallStringKey& a, const WidthCache::Sm
allStringKey& b) |
| 204 { | 204 { |
| 205 if (a.length() != b.length()) | 205 if (a.length() != b.length()) |
| 206 return false; | 206 return false; |
| 207 return WTF::equal(a.characters(), b.characters(), a.length()); | 207 return WTF::equal(a.characters(), b.characters(), a.length()); |
| 208 } | 208 } |
| 209 | 209 |
| 210 } // namespace blink | 210 } // namespace blink |
| 211 | 211 |
| 212 #endif // WidthCache_h | 212 #endif // WidthCache_h |
| OLD | NEW |