Chromium Code Reviews| Index: chrome/renderer/printing/print_web_view_helper.cc |
| diff --git a/chrome/renderer/printing/print_web_view_helper.cc b/chrome/renderer/printing/print_web_view_helper.cc |
| index e4129eef490197b6e61ea78d3e06f191c558d3cd..d7d0ab14591547f92e19948305e5c49d01312e64 100644 |
| --- a/chrome/renderer/printing/print_web_view_helper.cc |
| +++ b/chrome/renderer/printing/print_web_view_helper.cc |
| @@ -820,7 +820,10 @@ void PrintWebViewHelper::DidStartLoading() { |
| void PrintWebViewHelper::DidStopLoading() { |
| is_loading_ = false; |
| - ShowScriptedPrintPreview(); |
| + if (!on_stop_loading_closure_.is_null()) { |
| + on_stop_loading_closure_.Run(); |
| + on_stop_loading_closure_.Reset(); |
| + } |
| } |
| // Prints |frame| which called window.print(). |
| @@ -1711,6 +1714,9 @@ void PrintWebViewHelper::RequestPrintPreview(PrintPreviewRequestType type) { |
| // Wait for DidStopLoading. Plugins may not know the correct |
| // |is_modifiable| value until they are fully loaded, which occurs when |
| // DidStopLoading() is called. Defer showing the preview until then. |
| + on_stop_loading_closure_ = |
| + base::Bind(&PrintWebViewHelper::ShowScriptedPrintPreview, |
| + base::Unretained(this)); |
| } else { |
| base::MessageLoop::current()->PostTask( |
| FROM_HERE, |
| @@ -1725,14 +1731,34 @@ void PrintWebViewHelper::RequestPrintPreview(PrintPreviewRequestType type) { |
| return; |
| } |
| case PRINT_PREVIEW_USER_INITIATED_ENTIRE_FRAME: { |
| + // Wait for DidStopLoading. Continuing with this function while |
| + // |is_loading_| is true will cause print preview to hang when try to |
| + // print a PDF document. |
| + if (is_loading_ && GetPlugin(print_preview_context_.source_frame())) { |
| + on_stop_loading_closure_ = |
| + base::Bind(&PrintWebViewHelper::RequestPrintPreview, |
| + base::Unretained(this), |
| + type); |
| + return; |
| + } |
| + |
| break; |
| } |
| case PRINT_PREVIEW_USER_INITIATED_SELECTION: { |
| DCHECK(has_selection); |
| + DCHECK(GetPlugin(print_preview_context_.source_frame())); |
|
Vitaly Buka (NO REVIEWS)
2014/08/15 00:58:36
DCHECK(!GetPlugin
PRINT_PREVIEW_USER_INITIATED_SE
Vitaly Buka (NO REVIEWS)
2014/08/15 04:16:26
Please fix.
This should be !GetPlugin
On 2014/08/
ivandavid
2014/08/15 17:57:20
Done.
|
| params.selection_only = has_selection; |
| break; |
| } |
| case PRINT_PREVIEW_USER_INITIATED_CONTEXT_NODE: { |
| + if (is_loading_ && GetPlugin(print_preview_context_.source_frame())) { |
| + on_stop_loading_closure_ = |
| + base::Bind(&PrintWebViewHelper::RequestPrintPreview, |
| + base::Unretained(this), |
| + type); |
| + return; |
| + } |
| + |
| params.webnode_only = true; |
| break; |
| } |