Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(791)

Unified Diff: content/common/pepper_plugin_registry.h

Issue 7978009: Split ppapi::PluginList from PepperPluginRegistry so that DRT could load pepper plugins. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Created 9 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « content/common/content_switches.cc ('k') | content/common/pepper_plugin_registry.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: content/common/pepper_plugin_registry.h
===================================================================
--- content/common/pepper_plugin_registry.h (revision 101488)
+++ content/common/pepper_plugin_registry.h (working copy)
@@ -6,61 +6,15 @@
#define CONTENT_COMMON_PEPPER_PLUGIN_REGISTRY_H_
#pragma once
-#include <list>
-#include <map>
-#include <string>
-#include <vector>
-
-#include "base/file_path.h"
+#include "base/memory/singleton.h"
#include "content/common/content_export.h"
#include "webkit/plugins/ppapi/plugin_delegate.h"
-#include "webkit/plugins/ppapi/plugin_module.h"
-#include "webkit/plugins/webplugininfo.h"
+#include "webkit/plugins/ppapi/ppapi_plugin_list.h"
-struct CONTENT_EXPORT PepperPluginInfo {
- PepperPluginInfo();
- ~PepperPluginInfo();
-
- webkit::WebPluginInfo ToWebPluginInfo() const;
-
- // Indicates internal plugins for which there's not actually a library.
- // These plugins are implemented in the Chrome binary using a separate set
- // of entry points (see internal_entry_points below).
- // Defaults to false.
- bool is_internal;
-
- // True when this plugin should be run out of process. Defaults to false.
- bool is_out_of_process;
-
- FilePath path; // Internal plugins have "internal-[name]" as path.
- std::string name;
- std::string description;
- std::string version;
- std::vector<webkit::WebPluginMimeType> mime_types;
-
- // When is_internal is set, this contains the function pointers to the
- // entry points for the internal plugins.
- webkit::ppapi::PluginModule::EntryPoints internal_entry_points;
-};
-
-// Constructs a PepperPluginInfo from a WebPluginInfo. Returns false if
-// the operation is not possible, in particular the WebPluginInfo::type
-// must be one of the pepper types.
-bool MakePepperPluginInfo(const webkit::WebPluginInfo& webplugin_info,
- PepperPluginInfo* pepper_info);
-
-// This class holds references to all of the known pepper plugin modules.
-//
-// It keeps two lists. One list of preloaded in-process modules, and one list
-// is a list of all live modules (some of which may be out-of-process and hence
-// not preloaded).
+// Static helper class to manage webkit::ppapi::PluginList.
class PepperPluginRegistry
: public webkit::ppapi::PluginDelegate::ModuleLifetime {
public:
- ~PepperPluginRegistry();
-
- static PepperPluginRegistry* GetInstance();
-
// Computes the list of known pepper plugins.
//
// This method is static so that it can be used by the browser process, which
@@ -68,19 +22,21 @@
// plugin list every time it is called. Generally, code in the registry should
// be using the cached plugin_list_ instead.
CONTENT_EXPORT static void ComputeList(
- std::vector<PepperPluginInfo>* plugins);
+ webkit::ppapi::PluginList* plugin_list);
// Loads the (native) libraries but does not initialize them (i.e., does not
// call PPP_InitializeModule). This is needed by the zygote on Linux to get
// access to the plugins before entering the sandbox.
static void PreloadModules();
+ static PepperPluginRegistry* GetInstance();
+
// Retrieves the information associated with the given plugin info. The
// return value will be NULL if there is no such plugin.
//
// The returned pointer is owned by the PluginRegistry.
- const PepperPluginInfo* GetInfoForPlugin(
- const webkit::WebPluginInfo& info);
+ const webkit::ppapi::PluginInfo* GetInfoForPlugin(
+ const FilePath& plugin_path);
// Returns an existing loaded module for the given path. It will search for
// both preloaded in-process or currently active (non crashed) out-of-process
@@ -99,26 +55,8 @@
private:
PepperPluginRegistry();
-
- // All known pepper plugins.
- std::vector<PepperPluginInfo> plugin_list_;
-
- // Plugins that have been preloaded so they can be executed in-process in
- // the renderer (the sandbox prevents on-demand loading).
- typedef std::map<FilePath, scoped_refptr<webkit::ppapi::PluginModule> >
- OwningModuleMap;
- OwningModuleMap preloaded_modules_;
-
- // A list of non-owning pointers to all currently-live plugin modules. This
- // includes both preloaded ones in preloaded_modules_, and out-of-process
- // modules whose lifetime is managed externally. This will contain only
- // non-crashed modules. If an out-of-process module crashes, it may
- // continue as long as there are WebKit references to it, but it will not
- // appear in this list.
- typedef std::map<FilePath, webkit::ppapi::PluginModule*> NonOwningModuleMap;
- NonOwningModuleMap live_modules_;
-
- DISALLOW_COPY_AND_ASSIGN(PepperPluginRegistry);
+ ~PepperPluginRegistry();
+ friend struct DefaultSingletonTraits<PepperPluginRegistry>;
};
#endif // CONTENT_COMMON_PEPPER_PLUGIN_REGISTRY_H_
« no previous file with comments | « content/common/content_switches.cc ('k') | content/common/pepper_plugin_registry.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698