summaryrefslogtreecommitdiff
path: root/Source/JavaScriptCore/runtime/NumericStrings.h
diff options
context:
space:
mode:
authorOswald Buddenhagen <oswald.buddenhagen@qt.io>2017-05-30 12:48:17 +0200
committerOswald Buddenhagen <oswald.buddenhagen@qt.io>2017-05-30 12:48:17 +0200
commit881da28418d380042aa95a97f0cbd42560a64f7c (patch)
treea794dff3274695e99c651902dde93d934ea7a5af /Source/JavaScriptCore/runtime/NumericStrings.h
parent7e104c57a70fdf551bb3d22a5d637cdcbc69dbea (diff)
parent0fcedcd17cc00d3dd44c718b3cb36c1033319671 (diff)
downloadqtwebkit-881da28418d380042aa95a97f0cbd42560a64f7c.tar.gz
Merge 'wip/next' into dev
Change-Id: Iff9ee5e23bb326c4371ec8ed81d56f2f05d680e9
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