OLD | NEW |
1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2006-2008 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_job_worker.h" | 5 #include "chrome/browser/printing/print_job_worker.h" |
6 | 6 |
7 #include "base/message_loop.h" | 7 #include "base/message_loop.h" |
8 #include "chrome/browser/chrome_thread.h" | 8 #include "chrome/browser/chrome_thread.h" |
9 #include "chrome/browser/printing/print_job.h" | 9 #include "chrome/browser/printing/print_job.h" |
10 #include "chrome/common/notification_service.h" | 10 #include "chrome/common/notification_service.h" |
(...skipping 60 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
71 bool use_overlays) { | 71 bool use_overlays) { |
72 DCHECK_EQ(message_loop(), MessageLoop::current()); | 72 DCHECK_EQ(message_loop(), MessageLoop::current()); |
73 DCHECK_EQ(page_number_, PageNumber::npos()); | 73 DCHECK_EQ(page_number_, PageNumber::npos()); |
74 | 74 |
75 // Recursive task processing is needed for the dialog in case it needs to be | 75 // Recursive task processing is needed for the dialog in case it needs to be |
76 // destroyed by a task. | 76 // destroyed by a task. |
77 MessageLoop::current()->SetNestableTasksAllowed(true); | 77 MessageLoop::current()->SetNestableTasksAllowed(true); |
78 printing_context_.SetUseOverlays(use_overlays); | 78 printing_context_.SetUseOverlays(use_overlays); |
79 | 79 |
80 if (ask_user_for_settings) { | 80 if (ask_user_for_settings) { |
81 #if defined(OS_MACOSX) | 81 #if defined(OS_MACOSX) || defined(USE_X11) |
82 ChromeThread::PostTask( | 82 ChromeThread::PostTask( |
83 ChromeThread::UI, FROM_HERE, | 83 ChromeThread::UI, FROM_HERE, |
84 NewRunnableMethod(this, &PrintJobWorker::GetSettingsWithUI, | 84 NewRunnableMethod(this, &PrintJobWorker::GetSettingsWithUI, |
85 parent_view, document_page_count, | 85 parent_view, document_page_count, |
86 has_selection)); | 86 has_selection)); |
87 #else | 87 #else |
88 printing_context_.AskUserForSettings( | 88 printing_context_.AskUserForSettings( |
89 parent_view, | 89 parent_view, |
90 document_page_count, | 90 document_page_count, |
91 has_selection, | 91 has_selection, |
92 NewCallback(this, &PrintJobWorker::GetSettingsDone)); | 92 NewCallback(this, &PrintJobWorker::GetSettingsDone)); |
93 #endif | 93 #endif // defined(OS_MACOSX) || defined(USE_X11) |
94 } else { | 94 } else { |
95 PrintingContext::Result result = printing_context_.UseDefaultSettings(); | 95 PrintingContext::Result result = printing_context_.UseDefaultSettings(); |
96 GetSettingsDone(result); | 96 GetSettingsDone(result); |
97 } | 97 } |
98 } | 98 } |
99 | 99 |
100 void PrintJobWorker::GetSettingsDone(PrintingContext::Result result) { | 100 void PrintJobWorker::GetSettingsDone(PrintingContext::Result result) { |
101 // Most PrintingContext functions may start a message loop and process | 101 // Most PrintingContext functions may start a message loop and process |
102 // message recursively, so disable recursive task processing. | 102 // message recursively, so disable recursive task processing. |
103 MessageLoop::current()->SetNestableTasksAllowed(false); | 103 MessageLoop::current()->SetNestableTasksAllowed(false); |
104 | 104 |
105 // We can't use OnFailure() here since owner_ may not support notifications. | 105 // We can't use OnFailure() here since owner_ may not support notifications. |
106 | 106 |
107 // PrintJob will create the new PrintedDocument. | 107 // PrintJob will create the new PrintedDocument. |
108 owner_->message_loop()->PostTask(FROM_HERE, NewRunnableMethod( | 108 owner_->message_loop()->PostTask(FROM_HERE, NewRunnableMethod( |
109 owner_, | 109 owner_, |
110 &PrintJobWorkerOwner::GetSettingsDone, | 110 &PrintJobWorkerOwner::GetSettingsDone, |
111 printing_context_.settings(), | 111 printing_context_.settings(), |
112 result)); | 112 result)); |
113 } | 113 } |
114 | 114 |
115 #if defined(OS_MACOSX) | 115 #if defined(OS_MACOSX) || defined(USE_X11) |
116 void PrintJobWorker::GetSettingsWithUI(gfx::NativeView parent_view, | 116 void PrintJobWorker::GetSettingsWithUI(gfx::NativeView parent_view, |
117 int document_page_count, | 117 int document_page_count, |
118 bool has_selection) { | 118 bool has_selection) { |
119 DCHECK(ChromeThread::CurrentlyOn(ChromeThread::UI)); | 119 DCHECK(ChromeThread::CurrentlyOn(ChromeThread::UI)); |
120 | 120 |
121 printing_context_.AskUserForSettings( | 121 printing_context_.AskUserForSettings( |
122 parent_view, | 122 parent_view, |
123 document_page_count, | 123 document_page_count, |
124 has_selection, | 124 has_selection, |
125 NewCallback(this, &PrintJobWorker::GetSettingsWithUIDone)); | 125 NewCallback(this, &PrintJobWorker::GetSettingsWithUIDone)); |
126 } | 126 } |
127 | 127 |
128 void PrintJobWorker::GetSettingsWithUIDone(PrintingContext::Result result) { | 128 void PrintJobWorker::GetSettingsWithUIDone(PrintingContext::Result result) { |
129 message_loop()->PostTask(FROM_HERE, NewRunnableMethod( | 129 message_loop()->PostTask(FROM_HERE, NewRunnableMethod( |
130 this, &PrintJobWorker::GetSettingsDone, result)); | 130 this, &PrintJobWorker::GetSettingsDone, result)); |
131 } | 131 } |
132 #endif | 132 #endif // defined(OS_MACOSX) || defined(USE_X11) |
133 | 133 |
134 void PrintJobWorker::StartPrinting(PrintedDocument* new_document) { | 134 void PrintJobWorker::StartPrinting(PrintedDocument* new_document) { |
135 DCHECK_EQ(message_loop(), MessageLoop::current()); | 135 DCHECK_EQ(message_loop(), MessageLoop::current()); |
136 DCHECK_EQ(page_number_, PageNumber::npos()); | 136 DCHECK_EQ(page_number_, PageNumber::npos()); |
137 DCHECK_EQ(document_, new_document); | 137 DCHECK_EQ(document_, new_document); |
138 DCHECK(document_.get()); | 138 DCHECK(document_.get()); |
139 DCHECK(new_document->settings().Equals(printing_context_.settings())); | 139 DCHECK(new_document->settings().Equals(printing_context_.settings())); |
140 #if !defined(OS_MACOSX) | 140 #if !defined(OS_MACOSX) |
141 DCHECK(printing_context_.context()); | 141 DCHECK(printing_context_.context()); |
142 #endif | 142 #endif |
(...skipping 178 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
321 printing::PrintJobWorker* obj) { | 321 printing::PrintJobWorker* obj) { |
322 DCHECK(!owner_.get()); | 322 DCHECK(!owner_.get()); |
323 owner_ = obj->owner_; | 323 owner_ = obj->owner_; |
324 } | 324 } |
325 | 325 |
326 void RunnableMethodTraits<printing::PrintJobWorker>::ReleaseCallee( | 326 void RunnableMethodTraits<printing::PrintJobWorker>::ReleaseCallee( |
327 printing::PrintJobWorker* obj) { | 327 printing::PrintJobWorker* obj) { |
328 DCHECK_EQ(owner_, obj->owner_); | 328 DCHECK_EQ(owner_, obj->owner_); |
329 owner_ = NULL; | 329 owner_ = NULL; |
330 } | 330 } |
OLD | NEW |