Chromium Code Reviews| Index: extensions/shell/common/shell_content_client.cc |
| diff --git a/extensions/shell/common/shell_content_client.cc b/extensions/shell/common/shell_content_client.cc |
| index 5f0df03509fb3748a42f785145c9023da21625e5..f875755fc128e58ec7fd9e644daa54e6c946d721 100644 |
| --- a/extensions/shell/common/shell_content_client.cc |
| +++ b/extensions/shell/common/shell_content_client.cc |
| @@ -11,7 +11,48 @@ |
| #include "ui/base/l10n/l10n_util.h" |
| #include "ui/base/resource/resource_bundle.h" |
| +#if !defined(DISABLE_NACL) |
| +#include "base/base_paths.h" |
| +#include "base/files/file_path.h" |
| +#include "base/path_service.h" |
| +#include "content/public/common/pepper_plugin_info.h" |
| +#include "ppapi/native_client/src/trusted/plugin/ppapi_entrypoints.h" |
| +#include "ppapi/shared_impl/ppapi_permissions.h" |
| +#endif |
| + |
| namespace extensions { |
| +namespace { |
| + |
| +// TODO(jamescook): Should these be shared with ChromeContentClient? They are |
| +// too specific for the ppapi module and not really part of the extensions |
| +// module. Perhaps they should live in components/nacl. |
|
teravest
2014/08/12 15:48:32
components/nacl is probably a better place for thi
James Cook
2014/08/12 18:17:06
Moved into components/nacl/common and updated all
|
| +#if !defined(DISABLE_NACL) |
| +const char kNaClPluginName[] = "Native Client"; |
| + |
| +const char kNaClPluginMimeType[] = "application/x-nacl"; |
| +const char kNaClPluginExtension[] = ""; |
| +const char kNaClPluginDescription[] = "Native Client Executable"; |
| +const uint32 kNaClPluginPermissions = ppapi::PERMISSION_PRIVATE | |
| + ppapi::PERMISSION_DEV; |
| + |
| +const char kPnaclPluginMimeType[] = "application/x-pnacl"; |
| +const char kPnaclPluginExtension[] = ""; |
| +const char kPnaclPluginDescription[] = "Portable Native Client Executable"; |
| + |
| +const base::FilePath::CharType kInternalNaClPluginFileName[] = |
| + FILE_PATH_LITERAL("internal-nacl-plugin"); |
| + |
| +bool GetNaClPluginPath(base::FilePath* path) { |
| + // On Posix, plugins live in the module directory. |
| + base::FilePath module; |
| + if (!PathService::Get(base::DIR_MODULE, &module)) |
| + return false; |
| + *path = module.Append(kInternalNaClPluginFileName); |
| + return true; |
| +} |
| +#endif // !defined(DISABLE_NACL) |
| + |
| +} // namespace |
| ShellContentClient::ShellContentClient() { |
| } |
| @@ -19,6 +60,36 @@ ShellContentClient::ShellContentClient() { |
| ShellContentClient::~ShellContentClient() { |
| } |
| +void ShellContentClient::AddPepperPlugins( |
| + std::vector<content::PepperPluginInfo>* plugins) { |
| +#if !defined(DISABLE_NACL) |
| + base::FilePath path; |
| + if (!GetNaClPluginPath(&path)) |
| + return; |
| + |
| + content::PepperPluginInfo nacl; |
| + // The nacl plugin is now built into the binary. |
| + nacl.is_internal = true; |
| + nacl.path = path; |
| + nacl.name = kNaClPluginName; |
| + content::WebPluginMimeType nacl_mime_type(kNaClPluginMimeType, |
| + kNaClPluginExtension, |
| + kNaClPluginDescription); |
| + nacl.mime_types.push_back(nacl_mime_type); |
| + content::WebPluginMimeType pnacl_mime_type(kPnaclPluginMimeType, |
| + kPnaclPluginExtension, |
| + kPnaclPluginDescription); |
| + nacl.mime_types.push_back(pnacl_mime_type); |
| + nacl.internal_entry_points.get_interface = nacl_plugin::PPP_GetInterface; |
| + nacl.internal_entry_points.initialize_module = |
| + nacl_plugin::PPP_InitializeModule; |
| + nacl.internal_entry_points.shutdown_module = |
| + nacl_plugin::PPP_ShutdownModule; |
| + nacl.permissions = kNaClPluginPermissions; |
| + plugins->push_back(nacl); |
| +#endif // !defined(DISABLE_NACL) |
| +} |
| + |
| void ShellContentClient::AddAdditionalSchemes( |
| std::vector<std::string>* standard_schemes, |
| std::vector<std::string>* savable_schemes) { |