summaryrefslogtreecommitdiff
path: root/Source/JavaScriptCore/runtime/NumericStrings.h
diff options
context:
space:
mode:
authorKonstantin Tokarev <annulen@yandex.ru>2016-08-25 19:20:41 +0300
committerKonstantin Tokarev <annulen@yandex.ru>2017-02-02 12:30:55 +0000
commit6882a04fb36642862b11efe514251d32070c3d65 (patch)
treeb7959826000b061fd5ccc7512035c7478742f7b0 /Source/JavaScriptCore/runtime/NumericStrings.h
parentab6df191029eeeb0b0f16f127d553265659f739e (diff)
downloadqtwebkit-6882a04fb36642862b11efe514251d32070c3d65.tar.gz
Imported QtWebKit TP3 (git b57bc6801f1876c3220d5a4bfea33d620d477443)
Change-Id: I3b1d8a2808782c9f34d50240000e20cb38d3680f Reviewed-by: Konstantin Tokarev <annulen@yandex.ru>
Diffstat (limited to 'Source/JavaScriptCore/runtime/NumericStrings.h')
-rw-r--r--Source/JavaScriptCore/runtime/NumericStrings.h106
1 files changed, 53 insertions, 53 deletions
diff --git a/Source/JavaScriptCore/runtime/NumericStrings.h b/Source/JavaScriptCore/runtime/NumericStrings.h
index 68bfbd06a..ac8d41603 100644
--- a/Source/JavaScriptCore/runtime/NumericStrings.h
+++ b/Source/JavaScriptCore/runtime/NumericStrings.h
@@ -26,72 +26,72 @@
#ifndef NumericStrings_h
#define NumericStrings_h
-#include <wtf/FixedArray.h>
+#include <array>
#include <wtf/HashFunctions.h>
#include <wtf/text/WTFString.h>
namespace JSC {
- class NumericStrings {
- public:
- ALWAYS_INLINE String add(double d)
- {
- CacheEntry<double>& entry = lookup(d);
- if (!entry.value.isNull() && d == entry.key)
- return entry.value;
- entry.key = d;
- entry.value = String::numberToStringECMAScript(d);
+class NumericStrings {
+public:
+ ALWAYS_INLINE String add(double d)
+ {
+ CacheEntry<double>& entry = lookup(d);
+ if (d == entry.key && !entry.value.isNull())
return entry.value;
- }
+ entry.key = d;
+ entry.value = String::numberToStringECMAScript(d);
+ return entry.value;
+ }
- ALWAYS_INLINE String add(int i)
- {
- if (static_cast<unsigned>(i) < cacheSize)
- return lookupSmallString(static_cast<unsigned>(i));
- CacheEntry<int>& entry = lookup(i);
- if (!entry.value.isNull() && i == entry.key)
- return entry.value;
- entry.key = i;
- entry.value = String::number(i);
+ ALWAYS_INLINE String add(int i)
+ {
+ if (static_cast<unsigned>(i) < cacheSize)
+ return lookupSmallString(static_cast<unsigned>(i));
+ CacheEntry<int>& entry = lookup(i);
+ if (i == entry.key && !entry.value.isNull())
return entry.value;
- }
+ entry.key = i;
+ entry.value = String::number(i);
+ return entry.value;
+ }
- ALWAYS_INLINE String add(unsigned i)
- {
- if (i < cacheSize)
- return lookupSmallString(static_cast<unsigned>(i));
- CacheEntry<unsigned>& entry = lookup(i);
- if (!entry.value.isNull() && i == entry.key)
- return entry.value;
- entry.key = i;
- entry.value = String::number(i);
+ ALWAYS_INLINE String add(unsigned i)
+ {
+ if (i < cacheSize)
+ return lookupSmallString(static_cast<unsigned>(i));
+ CacheEntry<unsigned>& entry = lookup(i);
+ if (i == entry.key && !entry.value.isNull())
return entry.value;
- }
- private:
- static const size_t cacheSize = 64;
+ entry.key = i;
+ entry.value = String::number(i);
+ return entry.value;
+ }
+private:
+ static const size_t cacheSize = 64;
- template<typename T>
- struct CacheEntry {
- T key;
- String value;
- };
+ template<typename T>
+ struct CacheEntry {
+ T key;
+ String value;
+ };
- CacheEntry<double>& lookup(double d) { return doubleCache[WTF::FloatHash<double>::hash(d) & (cacheSize - 1)]; }
- CacheEntry<int>& lookup(int i) { return intCache[WTF::IntHash<int>::hash(i) & (cacheSize - 1)]; }
- CacheEntry<unsigned>& lookup(unsigned i) { return unsignedCache[WTF::IntHash<unsigned>::hash(i) & (cacheSize - 1)]; }
- ALWAYS_INLINE const String& lookupSmallString(unsigned i)
- {
- ASSERT(i < cacheSize);
- if (smallIntCache[i].isNull())
- smallIntCache[i] = String::number(i);
- return smallIntCache[i];
- }
+ CacheEntry<double>& lookup(double d) { return doubleCache[WTF::FloatHash<double>::hash(d) & (cacheSize - 1)]; }
+ CacheEntry<int>& lookup(int i) { return intCache[WTF::IntHash<int>::hash(i) & (cacheSize - 1)]; }
+ CacheEntry<unsigned>& lookup(unsigned i) { return unsignedCache[WTF::IntHash<unsigned>::hash(i) & (cacheSize - 1)]; }
+ ALWAYS_INLINE const String& lookupSmallString(unsigned i)
+ {
+ ASSERT(i < cacheSize);
+ if (smallIntCache[i].isNull())
+ smallIntCache[i] = String::number(i);
+ return smallIntCache[i];
+ }
- FixedArray<CacheEntry<double>, cacheSize> doubleCache;
- FixedArray<CacheEntry<int>, cacheSize> intCache;
- FixedArray<CacheEntry<unsigned>, cacheSize> unsignedCache;
- FixedArray<String, cacheSize> smallIntCache;
- };
+ std::array<CacheEntry<double>, cacheSize> doubleCache;
+ std::array<CacheEntry<int>, cacheSize> intCache;
+ std::array<CacheEntry<unsigned>, cacheSize> unsignedCache;
+ std::array<String, cacheSize> smallIntCache;
+};
} // namespace JSC