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

Unified Diff: content/common/pepper_plugin_registry.h

Issue 6869051: Move PepperPluginRegistry to content, while leaving the Chrome specific bits (NaCl, registration ... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: '' Created 9 years, 8 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
Index: content/common/pepper_plugin_registry.h
===================================================================
--- content/common/pepper_plugin_registry.h (revision 0)
+++ content/common/pepper_plugin_registry.h (revision 0)
@@ -0,0 +1,125 @@
+// 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.
+
+#ifndef CONTENT_COMMON_PEPPER_PLUGIN_REGISTRY_H_
+#define CONTENT_COMMON_PEPPER_PLUGIN_REGISTRY_H_
+#pragma once
+
+#include <list>
+#include <map>
+#include <string>
+#include <vector>
+
+#include "base/file_path.h"
+#include "ppapi/proxy/dispatcher.h"
+#include "webkit/plugins/npapi/webplugininfo.h"
+#include "webkit/plugins/ppapi/plugin_delegate.h"
+#include "webkit/plugins/ppapi/plugin_module.h"
+
+struct PepperPluginInfo {
+ PepperPluginInfo();
+ ~PepperPluginInfo();
+
+ webkit::npapi::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;
+
+ // Whether the plugin is enabled. Defaults to true.
+ bool enabled;
+
+ FilePath path; // Internal plugins have "internal-[name]" as path.
+ std::string name;
+ std::string description;
+ std::string version;
+ std::vector<webkit::npapi::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;
+};
+
+// 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).
+class PepperPluginRegistry
+ : public webkit::ppapi::PluginDelegate::ModuleLifetime,
+ public pp::proxy::Dispatcher::Delegate {
+ 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
+ // has no need to load the pepper plugin modules. It will re-compute the
+ // plugin list every time it is called. Generally, code in the registry should
+ // be using the cached plugin_list_ instead.
+ static void ComputeList(std::vector<PepperPluginInfo>* plugins);
+
+ // 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();
+
+ // Retrieves the information associated with the given plugin path. The
+ // return value will be NULL if there is no such plugin.
+ //
+ // The returned pointer is owned by the PluginRegistry.
+ const PepperPluginInfo* GetInfoForPlugin(const FilePath& path) const;
+
+ // 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
+ // plugins matching the given name. Returns NULL if the plugin hasn't been
+ // loaded.
+ webkit::ppapi::PluginModule* GetLiveModule(const FilePath& path);
+
+ // Notifies the registry that a new non-preloaded module has been created.
+ // This is normally called for out-of-process plugins. Once this is called,
+ // the module is available to be returned by GetModule(). The module will
+ // automatically unregister itself by calling PluginModuleDestroyed().
+ void AddLiveModule(const FilePath& path, webkit::ppapi::PluginModule* module);
+
+ // ModuleLifetime implementation.
+ virtual void PluginModuleDead(webkit::ppapi::PluginModule* dead_module);
+
+ private:
+ PepperPluginRegistry();
+
+ // Dispatcher::Delegate implementation.
+ virtual MessageLoop* GetIPCMessageLoop();
+ virtual base::WaitableEvent* GetShutdownEvent();
+ virtual std::set<PP_Instance>* GetGloballySeenInstanceIDSet();
+
+ // 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);
+};
+
+#endif // CONTENT_COMMON_PEPPER_PLUGIN_REGISTRY_H_
Property changes on: content\common\pepper_plugin_registry.h
___________________________________________________________________
Added: svn:eol-style
+ LF

Powered by Google App Engine
This is Rietveld 408576698