blob: 2912cefb3319ad084ea56fdaeb95eaded50a41af [file] [log] [blame]
// Copyright (c) 2011 The Chromium Authors. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#include <string>
#include <vector>
#include "base/basictypes.h"
#include "base/files/file_path.h"
#include "content/common/content_export.h"
namespace base {
class Version;
namespace content {
struct CONTENT_EXPORT WebPluginMimeType {
// A constructor for the common case of a single file extension and an ASCII
// description.
WebPluginMimeType(const std::string& m,
const std::string& f,
const std::string& d);
// The name of the mime type (e.g., "application/x-shockwave-flash").
std::string mime_type;
// A list of all the file extensions for this mime type.
std::vector<std::string> file_extensions;
// Description of the mime type.
base::string16 description;
// Extra parameters to include when instantiating the plugin.
std::vector<base::string16> additional_param_names;
std::vector<base::string16> additional_param_values;
// Describes an available NPAPI or Pepper plugin.
struct CONTENT_EXPORT WebPluginInfo {
enum PluginType {
WebPluginInfo(const WebPluginInfo& rhs);
WebPluginInfo& operator=(const WebPluginInfo& rhs);
// Special constructor only used during unit testing:
WebPluginInfo(const base::string16& fake_name,
const base::FilePath& fake_path,
const base::string16& fake_version,
const base::string16& fake_desc);
bool is_pepper_plugin() const {
return ((type == PLUGIN_TYPE_PEPPER_IN_PROCESS ) ||
// Parse a version string as used by a plug-in. This method is more lenient
// in accepting weird version strings than base::Version::GetFromString()
static void CreateVersionFromString(const base::string16& version_string,
base::Version* parsed_version);
// The name of the plugin (i.e. Flash).
base::string16 name;
// The path to the plugin file (DLL/bundle/library).
base::FilePath path;
// The version number of the plugin file (may be OS-specific)
base::string16 version;
// A description of the plugin that we get from its version info.
base::string16 desc;
// A list of all the mime types that this plugin supports.
std::vector<WebPluginMimeType> mime_types;
// Plugin type. See the PluginType enum.
int type;
// When type is PLUGIN_TYPE_PEPPER_* this indicates the permission bits.
int32 pepper_permissions;
} // namespace content