X-Git-Url: https://git.saurik.com/apple/javascriptcore.git/blobdiff_plain/6fe7ccc865dc7d7541b93c5bcaf6368d2c98a174..ed1e77d3adeb83d26fd1dfb16dd84cabdcefd250:/runtime/RegExpCachedResult.cpp diff --git a/runtime/RegExpCachedResult.cpp b/runtime/RegExpCachedResult.cpp index 0788145..e930618 100644 --- a/runtime/RegExpCachedResult.cpp +++ b/runtime/RegExpCachedResult.cpp @@ -26,37 +26,57 @@ #include "config.h" #include "RegExpCachedResult.h" +#include "JSCInlines.h" #include "RegExpMatchesArray.h" namespace JSC { void RegExpCachedResult::visitChildren(SlotVisitor& visitor) { - if (m_result) { - visitor.append(&m_lastInput); - visitor.append(&m_lastRegExp); - } else { - visitor.append(&m_reifiedInput); - visitor.append(&m_reifiedResult); - } + visitor.append(&m_lastInput); + 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) { - m_reifiedInput.set(exec->globalData(), owner, m_lastInput.get()); - m_reifiedResult.set(exec->globalData(), owner, RegExpMatchesArray::create(exec, m_lastInput.get(), m_lastRegExp.get(), m_result)); - m_result = MatchResult::failed(); + if (!m_reified) { + m_reifiedInput.set(exec->vm(), owner, m_lastInput.get()); + 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); - m_reifiedInput.set(exec->globalData(), owner, input); + ASSERT(m_reified); + m_reifiedInput.set(exec->vm(), owner, input); } } // namespace JSC