diff options
Diffstat (limited to 'chrome/renderer/render_process_impl.cc')
-rw-r--r-- | chrome/renderer/render_process_impl.cc | 24 |
1 files changed, 6 insertions, 18 deletions
diff --git a/chrome/renderer/render_process_impl.cc b/chrome/renderer/render_process_impl.cc index b1b6bc6..e610df9 100644 --- a/chrome/renderer/render_process_impl.cc +++ b/chrome/renderer/render_process_impl.cc @@ -180,27 +180,15 @@ RenderProcessImpl::RenderProcessImpl() } #endif -#if defined(OS_WIN) || defined(OS_MACOSX) - // Load the pdf plugin before the sandbox is turned on. This is for Mac and - // Windows. On Linux, this needs to be done in the zygote process. +#if defined(OS_WIN) + // Need to patch a few functions for font loading to work correctly. FilePath pdf; if (PathService::Get(chrome::FILE_PDF_PLUGIN, &pdf) && file_util::PathExists(pdf)) { - static scoped_refptr<NPAPI::PluginLib> pdf_lib = - NPAPI::PluginLib::CreatePluginLib(pdf); - bool rv = pdf_lib && pdf_lib->EnsureAlwaysLoaded(); - DCHECK(rv) << "Couldn't load PDF plugin"; - -#if defined(OS_WIN) - if (rv) { - g_iat_patch_createdca.Patch( - pdf_lib->plugin_info().path.value().c_str(), - "gdi32.dll", "CreateDCA", CreateDCAPatch); - g_iat_patch_get_font_data.Patch( - pdf_lib->plugin_info().path.value().c_str(), - "gdi32.dll", "GetFontData", GetFontDataPatch); - } -#endif + g_iat_patch_createdca.Patch( + pdf.value().c_str(), "gdi32.dll", "CreateDCA", CreateDCAPatch); + g_iat_patch_get_font_data.Patch( + pdf.value().c_str(), "gdi32.dll", "GetFontData", GetFontDataPatch); } #endif } |