Merge pull request #5152 from electron/fix-win-printing
Fix printing not working on Windows
This commit is contained in:
commit
9e85cb4c11
7 changed files with 18 additions and 131 deletions
|
@ -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;
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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_
|
||||||
|
|
|
@ -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
2
vendor/brightray
vendored
|
@ -1 +1 @@
|
||||||
Subproject commit 79ceba8890c42b6dcd71c43dccf2c6653d69dede
|
Subproject commit 7b037805e0dbb5976bdca5808f0ef4c937db1f6e
|
Loading…
Reference in a new issue