diff options
author | Lorry Tar Creator <lorry-tar-importer@lorry> | 2015-10-15 09:45:50 +0000 |
---|---|---|
committer | Lorry Tar Creator <lorry-tar-importer@lorry> | 2015-10-15 09:45:50 +0000 |
commit | e15dd966d523731101f70ccf768bba12435a0208 (patch) | |
tree | ae9cb828a24ded2585a41af3f21411523b47897d /Source/JavaScriptCore/runtime/RegExpCache.cpp | |
download | WebKitGtk-tarball-e15dd966d523731101f70ccf768bba12435a0208.tar.gz |
webkitgtk-2.10.2webkitgtk-2.10.2
Diffstat (limited to 'Source/JavaScriptCore/runtime/RegExpCache.cpp')
-rw-r--r-- | Source/JavaScriptCore/runtime/RegExpCache.cpp | 91 |
1 files changed, 91 insertions, 0 deletions
diff --git a/Source/JavaScriptCore/runtime/RegExpCache.cpp b/Source/JavaScriptCore/runtime/RegExpCache.cpp new file mode 100644 index 000000000..8f4660a78 --- /dev/null +++ b/Source/JavaScriptCore/runtime/RegExpCache.cpp @@ -0,0 +1,91 @@ +/* + * Copyright (C) 2010 University of Szeged + * Copyright (C) 2010 Renata Hodovan (hodovan@inf.u-szeged.hu) + * Copyright (C) 2012 Apple Inc. All rights reserved. + * All rights reserved. + * + * Redistribution and use in source and binary forms, with or without + * modification, are permitted provided that the following conditions + * are met: + * 1. Redistributions of source code must retain the above copyright + * notice, this list of conditions and the following disclaimer. + * 2. Redistributions in binary form must reproduce the above copyright + * notice, this list of conditions and the following disclaimer in the + * documentation and/or other materials provided with the distribution. + * + * THIS SOFTWARE IS PROVIDED BY UNIVERSITY OF SZEGED ``AS IS'' AND ANY + * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE + * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR + * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL UNIVERSITY OF SZEGED OR + * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, + * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, + * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR + * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY + * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT + * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE + * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. + */ + +#include "config.h" +#include "RegExpCache.h" + +#include "JSCInlines.h" +#include "RegExpObject.h" +#include "StrongInlines.h" + +namespace JSC { + +RegExp* RegExpCache::lookupOrCreate(const String& patternString, RegExpFlags flags) +{ + RegExpKey key(flags, patternString); + if (RegExp* regExp = m_weakCache.get(key)) + return regExp; + + RegExp* regExp = RegExp::createWithoutCaching(*m_vm, patternString, flags); +#if ENABLE(REGEXP_TRACING) + m_vm->addRegExpToTrace(regExp); +#endif + + weakAdd(m_weakCache, key, Weak<RegExp>(regExp, this)); + return regExp; +} + +RegExpCache::RegExpCache(VM* vm) + : m_nextEntryInStrongCache(0) + , m_vm(vm) +{ +} + +void RegExpCache::finalize(Handle<Unknown> handle, void*) +{ + RegExp* regExp = static_cast<RegExp*>(handle.get().asCell()); + weakRemove(m_weakCache, regExp->key(), regExp); +} + +void RegExpCache::addToStrongCache(RegExp* regExp) +{ + String pattern = regExp->pattern(); + if (pattern.length() > maxStrongCacheablePatternLength) + return; + m_strongCache[m_nextEntryInStrongCache].set(*m_vm, regExp); + m_nextEntryInStrongCache++; + if (m_nextEntryInStrongCache == maxStrongCacheableEntries) + m_nextEntryInStrongCache = 0; +} + +void RegExpCache::deleteAllCode() +{ + for (int i = 0; i < maxStrongCacheableEntries; i++) + m_strongCache[i].clear(); + m_nextEntryInStrongCache = 0; + + RegExpCacheMap::iterator end = m_weakCache.end(); + for (RegExpCacheMap::iterator it = m_weakCache.begin(); it != end; ++it) { + RegExp* regExp = it->value.get(); + if (!regExp) // Skip zombies. + continue; + regExp->deleteCode(); + } +} + +} |