OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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/service/cloud_print/printer_job_handler.h" | 5 #include "chrome/service/cloud_print/printer_job_handler.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/bind_helpers.h" | 8 #include "base/bind_helpers.h" |
9 #include "base/file_util.h" | 9 #include "base/file_util.h" |
10 #include "base/json/json_reader.h" | 10 #include "base/json/json_reader.h" |
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
47 local_job_id_(-1), | 47 local_job_id_(-1), |
48 next_json_data_handler_(NULL), | 48 next_json_data_handler_(NULL), |
49 next_data_handler_(NULL), | 49 next_data_handler_(NULL), |
50 server_error_count_(0), | 50 server_error_count_(0), |
51 print_thread_("Chrome_CloudPrintJobPrintThread"), | 51 print_thread_("Chrome_CloudPrintJobPrintThread"), |
52 job_handler_message_loop_proxy_( | 52 job_handler_message_loop_proxy_( |
53 base::MessageLoopProxy::current()), | 53 base::MessageLoopProxy::current()), |
54 shutting_down_(false), | 54 shutting_down_(false), |
55 job_check_pending_(false), | 55 job_check_pending_(false), |
56 printer_update_pending_(true), | 56 printer_update_pending_(true), |
57 task_in_progress_(false) { | 57 task_in_progress_(false), |
| 58 ALLOW_THIS_IN_INITIALIZER_LIST(weak_ptr_factory_(this)) { |
58 } | 59 } |
59 | 60 |
60 bool PrinterJobHandler::Initialize() { | 61 bool PrinterJobHandler::Initialize() { |
61 if (!print_system_->IsValidPrinter(printer_info_.printer_name)) | 62 if (!print_system_->IsValidPrinter(printer_info_.printer_name)) |
62 return false; | 63 return false; |
63 | 64 |
64 printer_watcher_ = print_system_->CreatePrinterWatcher( | 65 printer_watcher_ = print_system_->CreatePrinterWatcher( |
65 printer_info_.printer_name); | 66 printer_info_.printer_name); |
66 printer_watcher_->StartWatching(this); | 67 printer_watcher_->StartWatching(this); |
67 CheckForJobs(kJobFetchReasonStartup); | 68 CheckForJobs(kJobFetchReasonStartup); |
(...skipping 94 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
162 // (could be printer name, description, status or capabilities). | 163 // (could be printer name, description, status or capabilities). |
163 // First asynchronously fetch the capabilities. | 164 // First asynchronously fetch the capabilities. |
164 printing::PrinterBasicInfo printer_info; | 165 printing::PrinterBasicInfo printer_info; |
165 printer_watcher_->GetCurrentPrinterInfo(&printer_info); | 166 printer_watcher_->GetCurrentPrinterInfo(&printer_info); |
166 | 167 |
167 // Asynchronously fetch the printer caps and defaults. The story will | 168 // Asynchronously fetch the printer caps and defaults. The story will |
168 // continue in OnReceivePrinterCaps. | 169 // continue in OnReceivePrinterCaps. |
169 print_system_->GetPrinterCapsAndDefaults( | 170 print_system_->GetPrinterCapsAndDefaults( |
170 printer_info.printer_name.c_str(), | 171 printer_info.printer_name.c_str(), |
171 base::Bind(&PrinterJobHandler::OnReceivePrinterCaps, | 172 base::Bind(&PrinterJobHandler::OnReceivePrinterCaps, |
172 base::Unretained(this))); | 173 weak_ptr_factory_.GetWeakPtr())); |
173 | 174 |
174 // While we are waiting for the data, pretend we have work to do and return | 175 // While we are waiting for the data, pretend we have work to do and return |
175 // true. | 176 // true. |
176 return true; | 177 return true; |
177 } | 178 } |
178 | 179 |
179 void PrinterJobHandler::OnReceivePrinterCaps( | 180 void PrinterJobHandler::OnReceivePrinterCaps( |
180 bool succeeded, | 181 bool succeeded, |
181 const std::string& printer_name, | 182 const std::string& printer_name, |
182 const printing::PrinterCapsAndDefaults& caps_and_defaults) { | 183 const printing::PrinterCapsAndDefaults& caps_and_defaults) { |
(...skipping 454 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
637 job_handler_message_loop_proxy_->PostTask( | 638 job_handler_message_loop_proxy_->PostTask( |
638 FROM_HERE, base::Bind(&PrinterJobHandler::JobSpooled, this, job_id)); | 639 FROM_HERE, base::Bind(&PrinterJobHandler::JobSpooled, this, job_id)); |
639 } | 640 } |
640 | 641 |
641 void PrinterJobHandler::OnJobSpoolFailed() { | 642 void PrinterJobHandler::OnJobSpoolFailed() { |
642 DCHECK(MessageLoop::current() == print_thread_.message_loop()); | 643 DCHECK(MessageLoop::current() == print_thread_.message_loop()); |
643 job_spooler_ = NULL; | 644 job_spooler_ = NULL; |
644 job_handler_message_loop_proxy_->PostTask( | 645 job_handler_message_loop_proxy_->PostTask( |
645 FROM_HERE, base::Bind(&PrinterJobHandler::JobFailed, this, PRINT_FAILED)); | 646 FROM_HERE, base::Bind(&PrinterJobHandler::JobFailed, this, PRINT_FAILED)); |
646 } | 647 } |
OLD | NEW |