diff options
author | Simon Hausmann <simon.hausmann@nokia.com> | 2012-01-06 14:44:00 +0100 |
---|---|---|
committer | Simon Hausmann <simon.hausmann@nokia.com> | 2012-01-06 14:44:00 +0100 |
commit | 40736c5763bf61337c8c14e16d8587db021a87d4 (patch) | |
tree | b17a9c00042ad89cb1308e2484491799aa14e9f8 /Source/JavaScriptCore/runtime/RegExpCache.cpp | |
download | qtwebkit-40736c5763bf61337c8c14e16d8587db021a87d4.tar.gz |
Imported WebKit commit 2ea9d364d0f6efa8fa64acf19f451504c59be0e4 (http://svn.webkit.org/repository/webkit/trunk@104285)
Diffstat (limited to 'Source/JavaScriptCore/runtime/RegExpCache.cpp')
-rw-r--r-- | Source/JavaScriptCore/runtime/RegExpCache.cpp | 87 |
1 files changed, 87 insertions, 0 deletions
diff --git a/Source/JavaScriptCore/runtime/RegExpCache.cpp b/Source/JavaScriptCore/runtime/RegExpCache.cpp new file mode 100644 index 000000000..cd96301db --- /dev/null +++ b/Source/JavaScriptCore/runtime/RegExpCache.cpp @@ -0,0 +1,87 @@ +/* + * Copyright (C) 2010 University of Szeged + * Copyright (C) 2010 Renata Hodovan (hodovan@inf.u-szeged.hu) + * 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 "RegExpObject.h" +#include "StrongInlines.h" + +namespace JSC { + +RegExp* RegExpCache::lookupOrCreate(const UString& patternString, RegExpFlags flags) +{ + RegExpKey key(flags, patternString); + RegExpCacheMap::iterator result = m_weakCache.find(key); + if (result != m_weakCache.end()) + return result->second.get(); + RegExp* regExp = RegExp::createWithoutCaching(*m_globalData, patternString, flags); +#if ENABLE(REGEXP_TRACING) + m_globalData->addRegExpToTrace(regExp); +#endif + // We need to do a second lookup to add the RegExp as + // allocating it may have caused a gc cycle, which in + // turn may have removed items from the cache. + m_weakCache.add(key, Weak<RegExp>(*m_globalData, regExp, this)); + return regExp; +} + +RegExpCache::RegExpCache(JSGlobalData* globalData) + : m_nextEntryInStrongCache(0) + , m_globalData(globalData) +{ +} + +void RegExpCache::finalize(Handle<Unknown> handle, void*) +{ + RegExp* regExp = static_cast<RegExp*>(handle.get().asCell()); + m_weakCache.remove(regExp->key()); + regExp->invalidateCode(); +} + +void RegExpCache::addToStrongCache(RegExp* regExp) +{ + UString pattern = regExp->pattern(); + if (pattern.length() > maxStrongCacheablePatternLength) + return; + m_strongCache[m_nextEntryInStrongCache].set(*m_globalData, regExp); + m_nextEntryInStrongCache++; + if (m_nextEntryInStrongCache == maxStrongCacheableEntries) + m_nextEntryInStrongCache = 0; +} + +void RegExpCache::invalidateCode() +{ + for (int i = 0; i < maxStrongCacheableEntries; i++) + m_strongCache[i].clear(); + m_nextEntryInStrongCache = 0; + RegExpCacheMap::iterator end = m_weakCache.end(); + for (RegExpCacheMap::iterator ptr = m_weakCache.begin(); ptr != end; ++ptr) + ptr->second->invalidateCode(); +} + +} |