blob: b8e751df331e0647c39fbde52e763a0a1f95e429 [file] [log] [blame]
/*
Copyright (C) 2000 Harri Porten (porten@kde.org)
Copyright (C) 2000 Daniel Molkentin (molkentin@kde.org)
Copyright (C) 2000 Stefan Schimanski (schimmi@kde.org)
Copyright (C) 2003, 2004, 2005, 2006, 2007 Apple Inc. All Rights Reserved.
Copyright (C) 2008 Nokia Corporation and/or its subsidiary(-ies)
This library is free software; you can redistribute it and/or
modify it under the terms of the GNU Library 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
Library General Public License for more details.
You should have received a copy of the GNU Library General Public License
along with this library; see the file COPYING.LIB. If not, write to
the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor,
Boston, MA 02110-1301, USA.
*/
#include "config.h"
#include "PluginData.h"
#if USE(PLATFORM_STRATEGIES)
#include "PlatformStrategies.h"
#include "PluginStrategy.h"
#endif
namespace WebCore {
PluginData::PluginData(const Page* page)
{
initPlugins(page);
for (unsigned i = 0; i < m_plugins.size(); ++i) {
const PluginInfo& plugin = m_plugins[i];
for (unsigned j = 0; j < plugin.mimes.size(); ++j) {
m_mimes.append(plugin.mimes[j]);
m_mimePluginIndices.append(i);
}
}
}
bool PluginData::supportsMimeType(const String& mimeType) const
{
for (unsigned i = 0; i < m_mimes.size(); ++i)
if (m_mimes[i].type == mimeType)
return true;
return false;
}
String PluginData::pluginNameForMimeType(const String& mimeType) const
{
for (unsigned i = 0; i < m_mimes.size(); ++i) {
const MimeClassInfo& info = m_mimes[i];
if (info.type == mimeType)
return m_plugins[m_mimePluginIndices[i]].name;
}
return String();
}
#if USE(PLATFORM_STRATEGIES)
void PluginData::refresh()
{
platformStrategies()->pluginStrategy()->refreshPlugins();
}
void PluginData::initPlugins(const Page* page)
{
ASSERT(m_plugins.isEmpty());
platformStrategies()->pluginStrategy()->getPluginInfo(page, m_plugins);
}
#endif
}