diff options
author | Konstantin Tokarev <annulen@yandex.ru> | 2016-08-25 19:20:41 +0300 |
---|---|---|
committer | Konstantin Tokarev <annulen@yandex.ru> | 2017-02-02 12:30:55 +0000 |
commit | 6882a04fb36642862b11efe514251d32070c3d65 (patch) | |
tree | b7959826000b061fd5ccc7512035c7478742f7b0 /Source/JavaScriptCore/runtime/RegExpCachedResult.cpp | |
parent | ab6df191029eeeb0b0f16f127d553265659f739e (diff) | |
download | qtwebkit-6882a04fb36642862b11efe514251d32070c3d65.tar.gz |
Imported QtWebKit TP3 (git b57bc6801f1876c3220d5a4bfea33d620d477443)
Change-Id: I3b1d8a2808782c9f34d50240000e20cb38d3680f
Reviewed-by: Konstantin Tokarev <annulen@yandex.ru>
Diffstat (limited to 'Source/JavaScriptCore/runtime/RegExpCachedResult.cpp')
-rw-r--r-- | Source/JavaScriptCore/runtime/RegExpCachedResult.cpp | 34 |
1 files changed, 28 insertions, 6 deletions
diff --git a/Source/JavaScriptCore/runtime/RegExpCachedResult.cpp b/Source/JavaScriptCore/runtime/RegExpCachedResult.cpp index c54b4783d..e93061886 100644 --- a/Source/JavaScriptCore/runtime/RegExpCachedResult.cpp +++ b/Source/JavaScriptCore/runtime/RegExpCachedResult.cpp @@ -26,7 +26,7 @@ #include "config.h" #include "RegExpCachedResult.h" -#include "Operations.h" +#include "JSCInlines.h" #include "RegExpMatchesArray.h" namespace JSC { @@ -37,23 +37,45 @@ void RegExpCachedResult::visitChildren(SlotVisitor& visitor) visitor.append(&m_lastRegExp); visitor.append(&m_reifiedInput); visitor.append(&m_reifiedResult); + visitor.append(&m_reifiedLeftContext); + visitor.append(&m_reifiedRightContext); } -RegExpMatchesArray* RegExpCachedResult::lastResult(ExecState* exec, JSObject* owner) +JSArray* RegExpCachedResult::lastResult(ExecState* exec, JSObject* owner) { - if (m_result) { + if (!m_reified) { m_reifiedInput.set(exec->vm(), owner, m_lastInput.get()); - m_reifiedResult.set(exec->vm(), owner, RegExpMatchesArray::create(exec, m_lastInput.get(), m_lastRegExp.get(), m_result)); - m_result = MatchResult::failed(); + m_reifiedResult.set(exec->vm(), owner, createRegExpMatchesArray(exec, m_lastInput.get(), m_lastRegExp.get(), m_result)); + m_reified = true; } return m_reifiedResult.get(); } +JSString* RegExpCachedResult::leftContext(ExecState* exec, JSObject* owner) +{ + // Make sure we're reified. + lastResult(exec, owner); + if (!m_reifiedLeftContext) + m_reifiedLeftContext.set(exec->vm(), owner, m_result.start ? jsSubstring(exec, m_reifiedInput.get(), 0, m_result.start) : jsEmptyString(exec)); + return m_reifiedLeftContext.get(); +} + +JSString* RegExpCachedResult::rightContext(ExecState* exec, JSObject* owner) +{ + // Make sure we're reified. + lastResult(exec, owner); + if (!m_reifiedRightContext) { + unsigned length = m_reifiedInput->length(); + m_reifiedRightContext.set(exec->vm(), owner, m_result.end != length ? jsSubstring(exec, m_reifiedInput.get(), m_result.end, length - m_result.end) : jsEmptyString(exec)); + } + return m_reifiedRightContext.get(); +} + void RegExpCachedResult::setInput(ExecState* exec, JSObject* owner, JSString* input) { // Make sure we're reified, otherwise m_reifiedInput will be ignored. lastResult(exec, owner); - ASSERT(!m_result); + ASSERT(m_reified); m_reifiedInput.set(exec->vm(), owner, input); } |