Merge pull request #5152 from electron/fix-win-printing

Fix printing not working on Windows
This commit is contained in:
Cheng Zhao 2016-04-14 19:22:56 +09:00
commit 9e85cb4c11
7 changed files with 18 additions and 131 deletions

View file

@ -98,10 +98,6 @@ void AtomMainDelegate::PreSandboxStartup() {
std::string process_type = command_line->GetSwitchValueASCII( std::string process_type = command_line->GetSwitchValueASCII(
switches::kProcessType); switches::kProcessType);
if (process_type == switches::kUtilityProcess) {
AtomContentUtilityClient::PreSandboxStartup();
}
// Only append arguments for browser process. // Only append arguments for browser process.
if (!IsBrowserProcess(command_line)) if (!IsBrowserProcess(command_line))
return; return;

View file

@ -37,7 +37,7 @@ int64_t AtomContentUtilityClient::max_ipc_message_size_ =
AtomContentUtilityClient::AtomContentUtilityClient() AtomContentUtilityClient::AtomContentUtilityClient()
: filter_messages_(false) { : filter_messages_(false) {
#if defined(OS_WIN) #if defined(OS_WIN)
handlers_.push_back(new PrintingHandlerWin()); handlers_.push_back(new printing::PrintingHandlerWin());
#endif #endif
} }
@ -71,11 +71,4 @@ void AtomContentUtilityClient::OnStartupPing() {
// Don't release the process, we assume further messages are on the way. // Don't release the process, we assume further messages are on the way.
} }
// static
void AtomContentUtilityClient::PreSandboxStartup() {
#if defined(OS_WIN)
PrintingHandlerWin::PreSandboxStartup();
#endif
}
} // namespace atom } // namespace atom

View file

@ -31,8 +31,6 @@ class AtomContentUtilityClient : public content::ContentUtilityClient {
void UtilityThreadStarted() override; void UtilityThreadStarted() override;
bool OnMessageReceived(const IPC::Message& message) override; bool OnMessageReceived(const IPC::Message& message) override;
static void PreSandboxStartup();
static void set_max_ipc_message_size_for_test(int64_t max_message_size) { static void set_max_ipc_message_size_for_test(int64_t max_message_size) {
max_ipc_message_size_ = max_message_size; max_ipc_message_size_ = max_message_size;
} }

View file

@ -10,11 +10,14 @@
#include "base/scoped_native_library.h" #include "base/scoped_native_library.h"
#include "chrome/common/print_messages.h" #include "chrome/common/print_messages.h"
#include "content/public/utility/utility_thread.h" #include "content/public/utility/utility_thread.h"
#include "pdf/pdf.h"
#include "printing/emf_win.h" #include "printing/emf_win.h"
#include "printing/page_range.h" #include "printing/page_range.h"
#include "printing/pdf_render_settings.h" #include "printing/pdf_render_settings.h"
#include "ui/gfx/gdi_util.h" #include "ui/gfx/gdi_util.h"
namespace printing {
namespace { namespace {
bool Send(IPC::Message* message) { bool Send(IPC::Message* message) {
@ -25,114 +28,12 @@ void ReleaseProcessIfNeeded() {
content::UtilityThread::Get()->ReleaseProcessIfNeeded(); content::UtilityThread::Get()->ReleaseProcessIfNeeded();
} }
class PdfFunctions {
public:
PdfFunctions() : get_pdf_doc_info_func_(NULL),
render_pdf_to_dc_func_(NULL) {}
bool Init() {
base::FilePath module_path;
if (!PathService::Get(base::DIR_MODULE, &module_path))
return false;
base::FilePath::StringType name(FILE_PATH_LITERAL("pdf.dll"));
pdf_lib_.Reset(base::LoadNativeLibrary(module_path.Append(name), NULL));
if (!pdf_lib_.is_valid()) {
LOG(WARNING) << "Couldn't load PDF plugin";
return false;
}
get_pdf_doc_info_func_ =
reinterpret_cast<GetPDFDocInfoProc>(
pdf_lib_.GetFunctionPointer("GetPDFDocInfo"));
LOG_IF(WARNING, !get_pdf_doc_info_func_) << "Missing GetPDFDocInfo";
render_pdf_to_dc_func_ =
reinterpret_cast<RenderPDFPageToDCProc>(
pdf_lib_.GetFunctionPointer("RenderPDFPageToDC"));
LOG_IF(WARNING, !render_pdf_to_dc_func_) << "Missing RenderPDFPageToDC";
if (!get_pdf_doc_info_func_ || !render_pdf_to_dc_func_) {
Reset();
}
return IsValid();
}
bool IsValid() const {
return pdf_lib_.is_valid();
}
void Reset() {
pdf_lib_.Reset(NULL);
}
bool GetPDFDocInfo(const void* pdf_buffer,
int buffer_size,
int* page_count,
double* max_page_width) {
if (!get_pdf_doc_info_func_)
return false;
return get_pdf_doc_info_func_(pdf_buffer, buffer_size, page_count,
max_page_width);
}
bool RenderPDFPageToDC(const void* pdf_buffer,
int buffer_size,
int page_number,
HDC dc,
int dpi,
int bounds_origin_x,
int bounds_origin_y,
int bounds_width,
int bounds_height,
bool fit_to_bounds,
bool stretch_to_bounds,
bool keep_aspect_ratio,
bool center_in_bounds,
bool autorotate) {
if (!render_pdf_to_dc_func_)
return false;
return render_pdf_to_dc_func_(pdf_buffer, buffer_size, page_number,
dc, dpi, bounds_origin_x,
bounds_origin_y, bounds_width, bounds_height,
fit_to_bounds, stretch_to_bounds,
keep_aspect_ratio, center_in_bounds,
autorotate);
}
private:
// Exported by PDF plugin.
typedef bool (*GetPDFDocInfoProc)(const void* pdf_buffer,
int buffer_size, int* page_count,
double* max_page_width);
typedef bool (*RenderPDFPageToDCProc)(
const void* pdf_buffer, int buffer_size, int page_number, HDC dc,
int dpi, int bounds_origin_x, int bounds_origin_y,
int bounds_width, int bounds_height, bool fit_to_bounds,
bool stretch_to_bounds, bool keep_aspect_ratio, bool center_in_bounds,
bool autorotate);
RenderPDFPageToDCProc render_pdf_to_dc_func_;
GetPDFDocInfoProc get_pdf_doc_info_func_;
base::ScopedNativeLibrary pdf_lib_;
DISALLOW_COPY_AND_ASSIGN(PdfFunctions);
};
base::LazyInstance<PdfFunctions> g_pdf_lib = LAZY_INSTANCE_INITIALIZER;
} // namespace } // namespace
PrintingHandlerWin::PrintingHandlerWin() {} PrintingHandlerWin::PrintingHandlerWin() {}
PrintingHandlerWin::~PrintingHandlerWin() {} PrintingHandlerWin::~PrintingHandlerWin() {}
// static
void PrintingHandlerWin::PreSandboxStartup() {
g_pdf_lib.Get().Init();
}
bool PrintingHandlerWin::OnMessageReceived(const IPC::Message& message) { bool PrintingHandlerWin::OnMessageReceived(const IPC::Message& message) {
bool handled = true; bool handled = true;
IPC_BEGIN_MESSAGE_MAP(PrintingHandlerWin, message) IPC_BEGIN_MESSAGE_MAP(PrintingHandlerWin, message)
@ -149,7 +50,7 @@ bool PrintingHandlerWin::OnMessageReceived(const IPC::Message& message) {
void PrintingHandlerWin::OnRenderPDFPagesToMetafile( void PrintingHandlerWin::OnRenderPDFPagesToMetafile(
IPC::PlatformFileForTransit pdf_transit, IPC::PlatformFileForTransit pdf_transit,
const printing::PdfRenderSettings& settings) { const PdfRenderSettings& settings) {
pdf_rendering_settings_ = settings; pdf_rendering_settings_ = settings;
base::File pdf_file = IPC::PlatformFileForTransitToFile(pdf_transit); base::File pdf_file = IPC::PlatformFileForTransitToFile(pdf_transit);
int page_count = LoadPDF(pdf_file.Pass()); int page_count = LoadPDF(pdf_file.Pass());
@ -174,9 +75,6 @@ void PrintingHandlerWin::OnRenderPDFPagesToMetafileStop() {
} }
int PrintingHandlerWin::LoadPDF(base::File pdf_file) { int PrintingHandlerWin::LoadPDF(base::File pdf_file) {
if (!g_pdf_lib.Get().IsValid())
return 0;
int64_t length64 = pdf_file.GetLength(); int64_t length64 = pdf_file.GetLength();
if (length64 <= 0 || length64 > std::numeric_limits<int>::max()) if (length64 <= 0 || length64 > std::numeric_limits<int>::max())
return 0; return 0;
@ -187,8 +85,8 @@ int PrintingHandlerWin::LoadPDF(base::File pdf_file) {
return 0; return 0;
int total_page_count = 0; int total_page_count = 0;
if (!g_pdf_lib.Get().GetPDFDocInfo( if (!chrome_pdf::GetPDFDocInfo(&pdf_data_.front(), pdf_data_.size(),
&pdf_data_.front(), pdf_data_.size(), &total_page_count, NULL)) { &total_page_count, nullptr)) {
return 0; return 0;
} }
return total_page_count; return total_page_count;
@ -197,7 +95,7 @@ int PrintingHandlerWin::LoadPDF(base::File pdf_file) {
bool PrintingHandlerWin::RenderPdfPageToMetafile(int page_number, bool PrintingHandlerWin::RenderPdfPageToMetafile(int page_number,
base::File output_file, base::File output_file,
float* scale_factor) { float* scale_factor) {
printing::Emf metafile; Emf metafile;
metafile.Init(); metafile.Init();
// We need to scale down DC to fit an entire page into DC available area. // We need to scale down DC to fit an entire page into DC available area.
@ -216,7 +114,7 @@ bool PrintingHandlerWin::RenderPdfPageToMetafile(int page_number,
// The underlying metafile is of type Emf and ignores the arguments passed // The underlying metafile is of type Emf and ignores the arguments passed
// to StartPage. // to StartPage.
metafile.StartPage(gfx::Size(), gfx::Rect(), 1); metafile.StartPage(gfx::Size(), gfx::Rect(), 1);
if (!g_pdf_lib.Get().RenderPDFPageToDC( if (!chrome_pdf::RenderPDFPageToDC(
&pdf_data_.front(), &pdf_data_.front(),
pdf_data_.size(), pdf_data_.size(),
page_number, page_number,
@ -237,3 +135,5 @@ bool PrintingHandlerWin::RenderPdfPageToMetafile(int page_number,
metafile.FinishDocument(); metafile.FinishDocument();
return metafile.SaveTo(&output_file); return metafile.SaveTo(&output_file);
} }
} // printing

View file

@ -12,10 +12,10 @@
#include "printing/pdf_render_settings.h" #include "printing/pdf_render_settings.h"
namespace printing { namespace printing {
class PdfRenderSettings; class PdfRenderSettings;
struct PwgRasterSettings; struct PwgRasterSettings;
struct PageRange; struct PageRange;
}
// Dispatches IPCs for printing. // Dispatches IPCs for printing.
class PrintingHandlerWin : public UtilityMessageHandler { class PrintingHandlerWin : public UtilityMessageHandler {
@ -26,12 +26,10 @@ class PrintingHandlerWin : public UtilityMessageHandler {
// IPC::Listener: // IPC::Listener:
bool OnMessageReceived(const IPC::Message& message) override; bool OnMessageReceived(const IPC::Message& message) override;
static void PrintingHandlerWin::PreSandboxStartup();
private: private:
// IPC message handlers. // IPC message handlers.
void OnRenderPDFPagesToMetafile(IPC::PlatformFileForTransit pdf_transit, void OnRenderPDFPagesToMetafile(IPC::PlatformFileForTransit pdf_transit,
const printing::PdfRenderSettings& settings); const PdfRenderSettings& settings);
void OnRenderPDFPagesToMetafileGetPage( void OnRenderPDFPagesToMetafileGetPage(
int page_number, int page_number,
IPC::PlatformFileForTransit output_file); IPC::PlatformFileForTransit output_file);
@ -43,9 +41,11 @@ class PrintingHandlerWin : public UtilityMessageHandler {
float* scale_factor); float* scale_factor);
std::vector<char> pdf_data_; std::vector<char> pdf_data_;
printing::PdfRenderSettings pdf_rendering_settings_; PdfRenderSettings pdf_rendering_settings_;
DISALLOW_COPY_AND_ASSIGN(PrintingHandlerWin); DISALLOW_COPY_AND_ASSIGN(PrintingHandlerWin);
}; };
} // namespace printing
#endif // CHROME_UTILITY_PRINTING_HANDLER_WIN_H_ #endif // CHROME_UTILITY_PRINTING_HANDLER_WIN_H_

View file

@ -8,7 +8,7 @@ import sys
BASE_URL = os.getenv('LIBCHROMIUMCONTENT_MIRROR') or \ BASE_URL = os.getenv('LIBCHROMIUMCONTENT_MIRROR') or \
'https://s3.amazonaws.com/github-janky-artifacts/libchromiumcontent' 'https://s3.amazonaws.com/github-janky-artifacts/libchromiumcontent'
LIBCHROMIUMCONTENT_COMMIT = '4e506867ad95907e0a9cbec4ab3ee0f84214de94' LIBCHROMIUMCONTENT_COMMIT = '1a4c5e51a670633ff3ecd4448ad01ba21b440542'
PLATFORM = { PLATFORM = {
'cygwin': 'win32', 'cygwin': 'win32',

2
vendor/brightray vendored

@ -1 +1 @@
Subproject commit 79ceba8890c42b6dcd71c43dccf2c6653d69dede Subproject commit 7b037805e0dbb5976bdca5808f0ef4c937db1f6e