#include "config.h"
#include "PluginData.h"
#include "PlatformStrategies.h"
#include "PluginStrategy.h"
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 AllowedPluginTypes allowedPluginTypes) const
{
for (unsigned i = 0; i < m_mimes.size(); ++i) {
if (m_mimes[i].type == mimeType && (allowedPluginTypes == AllPlugins || m_plugins[m_mimePluginIndices[i]].isApplicationPlugin))
return true;
}
return false;
}
const PluginInfo* PluginData::pluginInfoForMimeType(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]];
}
return 0;
}
String PluginData::pluginNameForMimeType(const String& mimeType) const
{
if (const PluginInfo* info = pluginInfoForMimeType(mimeType))
return info->name;
return String();
}
String PluginData::pluginFileForMimeType(const String& mimeType) const
{
if (const PluginInfo* info = pluginInfoForMimeType(mimeType))
return info->file;
return String();
}
void PluginData::refresh()
{
platformStrategies()->pluginStrategy()->refreshPlugins();
}
void PluginData::initPlugins(const Page* page)
{
ASSERT(m_plugins.isEmpty());
platformStrategies()->pluginStrategy()->getPluginInfo(page, m_plugins);
}
}