/*
* Copyright (C) 1999-2001 Harri Porten (porten@kde.org)
* Copyright (C) 2003, 2004, 2005, 2006, 2008, 2009 Apple Inc. All rights reserved.
* Copyright (C) 2007 Samuel Weinig <sam@webkit.org>
* Copyright (C) 2009 Google, Inc. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
*/
#ifndef DOMObjectHashTableMap_h
#define DOMObjectHashTableMap_h
#include <runtime/Lookup.h>
#include <wtf/HashMap.h>
namespace JSC {
class JSGlobalData;
}
namespace WebCore {
// Map from static HashTable instances to per-GlobalData ones.
class DOMObjectHashTableMap {
public:
static DOMObjectHashTableMap& mapFor(JSC::JSGlobalData&);
~DOMObjectHashTableMap()
{
HashMap<const JSC::HashTable*, JSC::HashTable>::iterator mapEnd = m_map.end();
for (HashMap<const JSC::HashTable*, JSC::HashTable>::iterator iter = m_map.begin(); iter != m_map.end(); ++iter)
iter->second.deleteTable();
}
const JSC::HashTable* get(const JSC::HashTable* staticTable)
{
HashMap<const JSC::HashTable*, JSC::HashTable>::iterator iter = m_map.find(staticTable);
if (iter != m_map.end())
return &iter->second;
return &m_map.set(staticTable, JSC::HashTable(*staticTable)).first->second;
}
private:
HashMap<const JSC::HashTable*, JSC::HashTable> m_map;
};
} // namespace WebCore
#endif // DOMObjectHashTableMap_h