diff options
author | Lorry Tar Creator <lorry-tar-importer@lorry> | 2017-06-27 06:07:23 +0000 |
---|---|---|
committer | Lorry Tar Creator <lorry-tar-importer@lorry> | 2017-06-27 06:07:23 +0000 |
commit | 1bf1084f2b10c3b47fd1a588d85d21ed0eb41d0c (patch) | |
tree | 46dcd36c86e7fbc6e5df36deb463b33e9967a6f7 /Source/JavaScriptCore/runtime/RegExpCachedResult.cpp | |
parent | 32761a6cee1d0dee366b885b7b9c777e67885688 (diff) | |
download | WebKitGtk-tarball-master.tar.gz |
webkitgtk-2.16.5HEADwebkitgtk-2.16.5master
Diffstat (limited to 'Source/JavaScriptCore/runtime/RegExpCachedResult.cpp')
-rw-r--r-- | Source/JavaScriptCore/runtime/RegExpCachedResult.cpp | 52 |
1 files changed, 41 insertions, 11 deletions
diff --git a/Source/JavaScriptCore/runtime/RegExpCachedResult.cpp b/Source/JavaScriptCore/runtime/RegExpCachedResult.cpp index c54b4783d..7dbaf05c8 100644 --- a/Source/JavaScriptCore/runtime/RegExpCachedResult.cpp +++ b/Source/JavaScriptCore/runtime/RegExpCachedResult.cpp @@ -1,5 +1,5 @@ /* - * Copyright (C) 2012 Apple Inc. All rights reserved. + * Copyright (C) 2012, 2016 Apple Inc. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions @@ -26,34 +26,64 @@ #include "config.h" #include "RegExpCachedResult.h" -#include "Operations.h" +#include "JSCInlines.h" #include "RegExpMatchesArray.h" namespace JSC { void RegExpCachedResult::visitChildren(SlotVisitor& visitor) { - visitor.append(&m_lastInput); - visitor.append(&m_lastRegExp); - visitor.append(&m_reifiedInput); - visitor.append(&m_reifiedResult); + 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); + } } -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(); + 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) +{ + // 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); } |