summaryrefslogtreecommitdiff
path: root/Source/JavaScriptCore/parser/SourceProviderCacheItem.h
diff options
context:
space:
mode:
authorLorry Tar Creator <lorry-tar-importer@lorry>2016-04-10 09:28:39 +0000
committerLorry Tar Creator <lorry-tar-importer@lorry>2016-04-10 09:28:39 +0000
commit32761a6cee1d0dee366b885b7b9c777e67885688 (patch)
treed6bec92bebfb216f4126356e55518842c2f476a1 /Source/JavaScriptCore/parser/SourceProviderCacheItem.h
parenta4e969f4965059196ca948db781e52f7cfebf19e (diff)
downloadWebKitGtk-tarball-32761a6cee1d0dee366b885b7b9c777e67885688.tar.gz
webkitgtk-2.4.11webkitgtk-2.4.11
Diffstat (limited to 'Source/JavaScriptCore/parser/SourceProviderCacheItem.h')
-rw-r--r--Source/JavaScriptCore/parser/SourceProviderCacheItem.h62
1 files changed, 23 insertions, 39 deletions
diff --git a/Source/JavaScriptCore/parser/SourceProviderCacheItem.h b/Source/JavaScriptCore/parser/SourceProviderCacheItem.h
index 81d221b39..396211861 100644
--- a/Source/JavaScriptCore/parser/SourceProviderCacheItem.h
+++ b/Source/JavaScriptCore/parser/SourceProviderCacheItem.h
@@ -27,27 +27,22 @@
#define SourceProviderCacheItem_h
#include "ParserTokens.h"
+#include <wtf/PassOwnPtr.h>
#include <wtf/Vector.h>
-#include <wtf/text/UniquedStringImpl.h>
#include <wtf/text/WTFString.h>
namespace JSC {
struct SourceProviderCacheItemCreationParameters {
unsigned functionNameStart;
- unsigned lastTockenLine;
- unsigned lastTockenStartOffset;
- unsigned lastTockenEndOffset;
- unsigned lastTockenLineStartOffset;
- unsigned endFunctionOffset;
- unsigned parameterCount;
+ unsigned closeBraceLine;
+ unsigned closeBraceOffset;
+ unsigned closeBraceLineStartOffset;
bool needsFullActivation;
bool usesEval;
bool strictMode;
- Vector<RefPtr<UniquedStringImpl>> usedVariables;
- Vector<RefPtr<UniquedStringImpl>> writtenVariables;
- bool isBodyArrowExpression { false };
- JSTokenType tokenType { CLOSEBRACE };
+ Vector<RefPtr<StringImpl>> usedVariables;
+ Vector<RefPtr<StringImpl>> writtenVariables;
};
#if COMPILER(MSVC)
@@ -61,15 +56,15 @@ public:
static std::unique_ptr<SourceProviderCacheItem> create(const SourceProviderCacheItemCreationParameters&);
~SourceProviderCacheItem();
- JSToken endFunctionToken() const
+ JSToken closeBraceToken() const
{
JSToken token;
- token.m_type = isBodyArrowExpression ? tokenType : CLOSEBRACE;
- token.m_data.offset = lastTockenStartOffset;
- token.m_location.startOffset = lastTockenStartOffset;
- token.m_location.endOffset = lastTockenEndOffset;
- token.m_location.line = lastTockenLine;
- token.m_location.lineStartOffset = lastTockenLineStartOffset;
+ token.m_type = CLOSEBRACE;
+ token.m_data.offset = closeBraceOffset;
+ token.m_location.startOffset = closeBraceOffset;
+ token.m_location.endOffset = closeBraceOffset + 1;
+ token.m_location.line = closeBraceLine;
+ token.m_location.lineStartOffset = closeBraceLineStartOffset;
// token.m_location.sourceOffset is initialized once by the client. So,
// we do not need to set it here.
return token;
@@ -77,30 +72,24 @@ public:
unsigned functionNameStart : 31;
bool needsFullActivation : 1;
-
- unsigned endFunctionOffset : 31;
- unsigned lastTockenLine : 31;
- unsigned lastTockenStartOffset : 31;
- unsigned lastTockenEndOffset: 31;
- unsigned parameterCount;
+ unsigned closeBraceLine : 31;
bool usesEval : 1;
+ unsigned closeBraceOffset : 31;
bool strictMode : 1;
- unsigned lastTockenLineStartOffset;
+ unsigned closeBraceLineStartOffset;
unsigned usedVariablesCount;
unsigned writtenVariablesCount;
- UniquedStringImpl** usedVariables() const { return const_cast<UniquedStringImpl**>(m_variables); }
- UniquedStringImpl** writtenVariables() const { return const_cast<UniquedStringImpl**>(&m_variables[usedVariablesCount]); }
- bool isBodyArrowExpression;
- JSTokenType tokenType;
+ StringImpl** usedVariables() const { return const_cast<StringImpl**>(m_variables); }
+ StringImpl** writtenVariables() const { return const_cast<StringImpl**>(&m_variables[usedVariablesCount]); }
private:
SourceProviderCacheItem(const SourceProviderCacheItemCreationParameters&);
- UniquedStringImpl* m_variables[0];
+ StringImpl* m_variables[0];
};
inline SourceProviderCacheItem::~SourceProviderCacheItem()
@@ -112,7 +101,7 @@ inline SourceProviderCacheItem::~SourceProviderCacheItem()
inline std::unique_ptr<SourceProviderCacheItem> SourceProviderCacheItem::create(const SourceProviderCacheItemCreationParameters& parameters)
{
size_t variableCount = parameters.writtenVariables.size() + parameters.usedVariables.size();
- size_t objectSize = sizeof(SourceProviderCacheItem) + sizeof(UniquedStringImpl*) * variableCount;
+ size_t objectSize = sizeof(SourceProviderCacheItem) + sizeof(StringImpl*) * variableCount;
void* slot = fastMalloc(objectSize);
return std::unique_ptr<SourceProviderCacheItem>(new (slot) SourceProviderCacheItem(parameters));
}
@@ -120,18 +109,13 @@ inline std::unique_ptr<SourceProviderCacheItem> SourceProviderCacheItem::create(
inline SourceProviderCacheItem::SourceProviderCacheItem(const SourceProviderCacheItemCreationParameters& parameters)
: functionNameStart(parameters.functionNameStart)
, needsFullActivation(parameters.needsFullActivation)
- , endFunctionOffset(parameters.endFunctionOffset)
- , lastTockenLine(parameters.lastTockenLine)
- , lastTockenStartOffset(parameters.lastTockenStartOffset)
- , lastTockenEndOffset(parameters.lastTockenEndOffset)
- , parameterCount(parameters.parameterCount)
+ , closeBraceLine(parameters.closeBraceLine)
, usesEval(parameters.usesEval)
+ , closeBraceOffset(parameters.closeBraceOffset)
, strictMode(parameters.strictMode)
- , lastTockenLineStartOffset(parameters.lastTockenLineStartOffset)
+ , closeBraceLineStartOffset(parameters.closeBraceLineStartOffset)
, usedVariablesCount(parameters.usedVariables.size())
, writtenVariablesCount(parameters.writtenVariables.size())
- , isBodyArrowExpression(parameters.isBodyArrowExpression)
- , tokenType(parameters.tokenType)
{
unsigned j = 0;
for (unsigned i = 0; i < usedVariablesCount; ++i, ++j) {