Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(97)

Side by Side Diff: chrome/browser/printing/print_preview_message_handler.cc

Issue 7621087: Print Preview: Go from event driven print preview back to print preview with sync messages. The s... (Closed) Base URL: svn://chrome-svn/chrome/trunk/src/
Patch Set: merge, undo print preview id change Created 9 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #include "chrome/browser/printing/print_preview_message_handler.h" 5 #include "chrome/browser/printing/print_preview_message_handler.h"
6 6
7 #include <vector> 7 #include <vector>
8 8
9 #include "base/memory/ref_counted.h" 9 #include "base/memory/ref_counted.h"
10 #include "base/memory/ref_counted_memory.h" 10 #include "base/memory/ref_counted_memory.h"
(...skipping 66 matching lines...) Expand 10 before | Expand all | Expand 10 after
77 77
78 return tab_controller->GetPrintPreviewForTab(tab_contents()); 78 return tab_controller->GetPrintPreviewForTab(tab_contents());
79 } 79 }
80 80
81 void PrintPreviewMessageHandler::OnRequestPrintPreview() { 81 void PrintPreviewMessageHandler::OnRequestPrintPreview() {
82 PrintPreviewTabController::PrintPreview(tab_contents()); 82 PrintPreviewTabController::PrintPreview(tab_contents());
83 } 83 }
84 84
85 void PrintPreviewMessageHandler::OnDidGetPreviewPageCount( 85 void PrintPreviewMessageHandler::OnDidGetPreviewPageCount(
86 const PrintHostMsg_DidGetPreviewPageCount_Params& params) { 86 const PrintHostMsg_DidGetPreviewPageCount_Params& params) {
87 if (params.page_count <= 0) 87 if (params.page_count <= 0) {
88 NOTREACHED();
88 return; 89 return;
90 }
89 91
90 TabContents* print_preview_tab = GetPrintPreviewTab(); 92 TabContents* print_preview_tab = GetPrintPreviewTab();
91 if (!print_preview_tab || !print_preview_tab->web_ui()) 93 if (!print_preview_tab || !print_preview_tab->web_ui())
92 return; 94 return;
93 95
94 PrintPreviewUI* print_preview_ui = 96 PrintPreviewUI* print_preview_ui =
95 static_cast<PrintPreviewUI*>(print_preview_tab->web_ui()); 97 static_cast<PrintPreviewUI*>(print_preview_tab->web_ui());
96 print_preview_ui->OnDidGetPreviewPageCount(params); 98 print_preview_ui->OnDidGetPreviewPageCount(params);
97 } 99 }
98 100
99 void PrintPreviewMessageHandler::OnDidPreviewPage( 101 void PrintPreviewMessageHandler::OnDidPreviewPage(
100 const PrintHostMsg_DidPreviewPage_Params& params) { 102 const PrintHostMsg_DidPreviewPage_Params& params) {
101 RenderViewHost* rvh = tab_contents()->render_view_host();
102 TabContents* print_preview_tab = GetPrintPreviewTab(); 103 TabContents* print_preview_tab = GetPrintPreviewTab();
103 if (!print_preview_tab || !print_preview_tab->web_ui()) { 104 if (!print_preview_tab || !print_preview_tab->web_ui())
104 // Can't find print preview tab means we should abort.
105 rvh->Send(new PrintMsg_AbortPreview(rvh->routing_id()));
106 return; 105 return;
107 }
108 106
109 PrintPreviewUI* print_preview_ui = 107 PrintPreviewUI* print_preview_ui =
110 static_cast<PrintPreviewUI*>(print_preview_tab->web_ui()); 108 static_cast<PrintPreviewUI*>(print_preview_tab->web_ui());
111 bool has_pending = print_preview_ui->HasPendingRequests();
112 if (has_pending) {
113 // Cancel. Next print preview request will cancel the current one. Just do
114 // the required maintenance work here.
115 StopWorker(print_preview_ui->document_cookie());
116 print_preview_ui->OnPrintPreviewCancelled();
117 return;
118 }
119
120 int requested_preview_page_index = INVALID_PAGE_INDEX;
121 int page_number = params.page_number; 109 int page_number = params.page_number;
122 110
123 if (page_number == FIRST_PAGE_INDEX) 111 if (page_number == FIRST_PAGE_INDEX)
124 print_preview_ui->ClearAllPreviewData(); 112 print_preview_ui->ClearAllPreviewData();
125 113
126 if (page_number >= FIRST_PAGE_INDEX && params.data_size) { 114 if (page_number >= FIRST_PAGE_INDEX && params.data_size) {
127 RefCountedBytes* data_bytes = 115 RefCountedBytes* data_bytes =
128 GetDataFromHandle(params.metafile_data_handle, params.data_size); 116 GetDataFromHandle(params.metafile_data_handle, params.data_size);
129 DCHECK(data_bytes); 117 DCHECK(data_bytes);
130 118
131 print_preview_ui->SetPrintPreviewDataForIndex(page_number, data_bytes); 119 print_preview_ui->SetPrintPreviewDataForIndex(page_number, data_bytes);
132 print_preview_ui->OnDidPreviewPage(page_number, params.preview_request_id); 120 print_preview_ui->OnDidPreviewPage(page_number, params.preview_request_id);
133 // TODO(kmadhusu): Query |PrintPreviewUI| and update
134 // |requested_preview_page_index| accordingly.
135 } 121 }
136
137 rvh->Send(new PrintMsg_ContinuePreview(rvh->routing_id(),
138 requested_preview_page_index));
139 } 122 }
140 123
141 void PrintPreviewMessageHandler::OnPagesReadyForPreview( 124 void PrintPreviewMessageHandler::OnPagesReadyForPreview(
142 const PrintHostMsg_DidPreviewDocument_Params& params) { 125 const PrintHostMsg_DidPreviewDocument_Params& params) {
126 if (params.expected_pages_count <= 0) {
127 NOTREACHED();
128 return;
129 }
143 StopWorker(params.document_cookie); 130 StopWorker(params.document_cookie);
kmadhusu 2011/08/22 21:23:57 Is it better to stop the worker before validating
Lei Zhang 2011/08/22 22:26:55 Sure. Why not.
144 131
145 // Get the print preview tab. 132 // Get the print preview tab.
146 TabContents* print_preview_tab = GetPrintPreviewTab(); 133 TabContents* print_preview_tab = GetPrintPreviewTab();
147 // User might have closed it already. 134 // User might have closed it already.
148 if (!print_preview_tab) 135 if (!print_preview_tab)
149 return; 136 return;
150 137
151 PrintPreviewUI* print_preview_ui = 138 PrintPreviewUI* print_preview_ui =
152 static_cast<PrintPreviewUI*>(print_preview_tab->web_ui()); 139 static_cast<PrintPreviewUI*>(print_preview_tab->web_ui());
153 140
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after
199 HasTabContents(wrapper)) { 186 HasTabContents(wrapper)) {
200 // Preview tab was hidden to serve the print request. 187 // Preview tab was hidden to serve the print request.
201 delete wrapper; 188 delete wrapper;
202 } else { 189 } else {
203 PrintPreviewUI* print_preview_ui = 190 PrintPreviewUI* print_preview_ui =
204 static_cast<PrintPreviewUI*>(print_preview_tab->web_ui()); 191 static_cast<PrintPreviewUI*>(print_preview_tab->web_ui());
205 print_preview_ui->OnPrintPreviewFailed(); 192 print_preview_ui->OnPrintPreviewFailed();
206 } 193 }
207 } 194 }
208 195
196 void PrintPreviewMessageHandler::OnPrintPreviewCancelled(int document_cookie) {
197 // Always need to stop the worker.
198 StopWorker(document_cookie);
199 }
200
209 bool PrintPreviewMessageHandler::OnMessageReceived( 201 bool PrintPreviewMessageHandler::OnMessageReceived(
210 const IPC::Message& message) { 202 const IPC::Message& message) {
211 bool handled = true; 203 bool handled = true;
212 IPC_BEGIN_MESSAGE_MAP(PrintPreviewMessageHandler, message) 204 IPC_BEGIN_MESSAGE_MAP(PrintPreviewMessageHandler, message)
213 IPC_MESSAGE_HANDLER(PrintHostMsg_RequestPrintPreview, 205 IPC_MESSAGE_HANDLER(PrintHostMsg_RequestPrintPreview,
214 OnRequestPrintPreview) 206 OnRequestPrintPreview)
215 IPC_MESSAGE_HANDLER(PrintHostMsg_DidGetPreviewPageCount, 207 IPC_MESSAGE_HANDLER(PrintHostMsg_DidGetPreviewPageCount,
216 OnDidGetPreviewPageCount) 208 OnDidGetPreviewPageCount)
217 IPC_MESSAGE_HANDLER(PrintHostMsg_DidPreviewPage, 209 IPC_MESSAGE_HANDLER(PrintHostMsg_DidPreviewPage,
218 OnDidPreviewPage) 210 OnDidPreviewPage)
219 IPC_MESSAGE_HANDLER(PrintHostMsg_PagesReadyForPreview, 211 IPC_MESSAGE_HANDLER(PrintHostMsg_PagesReadyForPreview,
220 OnPagesReadyForPreview) 212 OnPagesReadyForPreview)
221 IPC_MESSAGE_HANDLER(PrintHostMsg_PrintPreviewFailed, 213 IPC_MESSAGE_HANDLER(PrintHostMsg_PrintPreviewFailed,
222 OnPrintPreviewFailed) 214 OnPrintPreviewFailed)
215 IPC_MESSAGE_HANDLER(PrintHostMsg_PrintPreviewCancelled,
216 OnPrintPreviewCancelled)
223 IPC_MESSAGE_UNHANDLED(handled = false) 217 IPC_MESSAGE_UNHANDLED(handled = false)
224 IPC_END_MESSAGE_MAP() 218 IPC_END_MESSAGE_MAP()
225 return handled; 219 return handled;
226 } 220 }
227 221
228 void PrintPreviewMessageHandler::DidStartLoading() { 222 void PrintPreviewMessageHandler::DidStartLoading() {
229 if (tab_contents()->delegate() && 223 if (tab_contents()->delegate() &&
230 printing::PrintPreviewTabController::IsPrintPreviewTab(tab_contents())) { 224 printing::PrintPreviewTabController::IsPrintPreviewTab(tab_contents())) {
231 tab_contents()->SetContentRestrictions(CONTENT_RESTRICTION_PRINT); 225 tab_contents()->SetContentRestrictions(CONTENT_RESTRICTION_PRINT);
232 } 226 }
233 } 227 }
234 228
235 } // namespace printing 229 } // namespace printing
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698