RegExpCachedResult.cpp [plain text]
#include "config.h"
#include "RegExpCachedResult.h"
#include "JSCInlines.h"
#include "RegExpMatchesArray.h"
namespace JSC {
void RegExpCachedResult::visitChildren(SlotVisitor& visitor)
{
visitor.append(m_lastInput);
visitor.append(m_lastRegExp);
if (m_reified) {
visitor.append(m_reifiedInput);
visitor.append(m_reifiedResult);
visitor.append(m_reifiedLeftContext);
visitor.append(m_reifiedRightContext);
}
}
JSArray* RegExpCachedResult::lastResult(ExecState* exec, JSObject* owner)
{
if (!m_reified) {
m_reifiedInput.set(exec->vm(), owner, m_lastInput.get());
if (m_result)
m_reifiedResult.setWithoutWriteBarrier(createRegExpMatchesArray(exec, exec->lexicalGlobalObject(), m_lastInput.get(), m_lastRegExp.get(), m_result.start));
else
m_reifiedResult.setWithoutWriteBarrier(createEmptyRegExpMatchesArray(exec->lexicalGlobalObject(), m_lastInput.get(), m_lastRegExp.get()));
m_reifiedLeftContext.clear();
m_reifiedRightContext.clear();
m_reified = true;
exec->vm().heap.writeBarrier(owner);
}
return m_reifiedResult.get();
}
JSString* RegExpCachedResult::leftContext(ExecState* exec, JSObject* owner)
{
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)
{
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)
{
lastResult(exec, owner);
leftContext(exec, owner);
rightContext(exec, owner);
ASSERT(m_reified);
m_reifiedInput.set(exec->vm(), owner, input);
}
}