Chromium Code Reviews| OLD | NEW |
|---|---|
| (Empty) | |
| 1 // Copyright 2016 The Chromium Authors. All rights reserved. | |
| 2 // Use of this source code is governed by a BSD-style license that can be | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 #include "chromeos/printing/fake_printer_detector.h" | |
| 6 | |
| 7 #include <algorithm> | |
| 8 #include <iterator> | |
| 9 #include <memory> | |
| 10 | |
| 11 #include "base/bind.h" | |
| 12 #include "base/memory/ptr_util.h" | |
| 13 #include "base/strings/stringprintf.h" | |
| 14 #include "base/threading/sequenced_task_runner_handle.h" | |
| 15 #include "base/time/time.h" | |
| 16 #include "chromeos/printing/printer_detector.h" | |
| 17 | |
| 18 namespace chromeos { | |
| 19 | |
| 20 // static | |
| 21 std::unique_ptr<PrinterDetector> PrinterDetector::Create() { | |
| 22 return base::MakeUnique<FakePrinterDetector>(); | |
| 23 } | |
| 24 | |
| 25 FakePrinterDetector::~FakePrinterDetector() {} | |
| 26 | |
| 27 bool FakePrinterDetector::StartDiscovery() { | |
| 28 discovery_running_ = true; | |
| 29 base::SequencedTaskRunnerHandle::Get()->PostNonNestableDelayedTask( | |
| 30 FROM_HERE, base::Bind(&FakePrinterDetector::EmitPrinters, | |
| 31 weak_ptr_factory_.GetWeakPtr(), 0, 2), | |
| 32 base::TimeDelta::FromMilliseconds(2000)); | |
| 33 return true; | |
| 34 } | |
| 35 | |
| 36 bool FakePrinterDetector::StopDiscovery() { | |
| 37 discovery_running_ = false; | |
| 38 return true; | |
| 39 } | |
| 40 | |
| 41 void FakePrinterDetector::AddObserver(PrinterDetector::Observer* observer) { | |
| 42 observers_.push_back(observer); | |
| 43 } | |
| 44 | |
| 45 void FakePrinterDetector::RemoveObserver(PrinterDetector::Observer* observer) { | |
| 46 auto found = std::find(observers_.begin(), observers_.end(), observer); | |
| 47 if (found != observers_.end()) | |
| 48 observers_.erase(found); | |
| 49 } | |
| 50 | |
| 51 FakePrinterDetector::FakePrinterDetector() | |
| 52 : discovery_running_(false), weak_ptr_factory_(this) { | |
| 53 for (int i = 0; i < 12; i++) { | |
| 54 // printer doesn't have a ppd | |
| 55 printers_.emplace_back(base::StringPrintf("GUID%2d", i)); | |
| 56 printers_[i].set_display_name(base::StringPrintf("PrinterName%2d", i)); | |
| 57 printers_[i].set_description( | |
| 58 base::StringPrintf("Printer%2dDescription", i)); | |
| 59 printers_[i].set_manufacturer("Chromium"); | |
| 60 printers_[i].set_model(i % 3 == 0 ? "Inkjet" : "Laser Maker"); | |
| 61 printers_[i].set_uri( | |
| 62 base::StringPrintf("lpr://192.168.1.%d:9100/bldg/printer", i)); | |
| 63 printers_[i].set_uuid( | |
| 64 base::StringPrintf("UUID-%4d-%4d-%4d-UUID", i * 3, i * 2, i)); | |
| 65 } | |
| 66 } | |
| 67 | |
| 68 void FakePrinterDetector::EmitPrinters(size_t start, size_t end) { | |
| 69 if (!discovery_running_) | |
| 70 return; | |
|
xdai1
2016/09/20 04:16:50
Return early if start >= printers_.size()
skau
2016/10/03 22:57:26
Done.
| |
| 71 | |
| 72 size_t clipped_end = std::min(printers_.size(), end); | |
|
xdai1
2016/09/20 04:16:50
should be size_t clipped_end = std::min(printers_.
skau
2016/10/03 22:57:26
No. Subset is exclusive of the upper bound.
| |
| 73 if (!observers_.empty()) { | |
| 74 auto start_iter = printers_.begin(); | |
| 75 std::advance(start_iter, start); | |
| 76 auto end_iter = printers_.begin(); | |
| 77 std::advance(end_iter, clipped_end); | |
| 78 std::vector<Printer> subset(start_iter, end_iter); | |
| 79 for (auto observer : observers_) | |
| 80 observer->OnPrintersFound(subset); | |
| 81 } | |
| 82 | |
| 83 if (end < printers_.size()) { | |
| 84 base::SequencedTaskRunnerHandle::Get()->PostNonNestableDelayedTask( | |
| 85 FROM_HERE, | |
| 86 base::Bind(&FakePrinterDetector::EmitPrinters, | |
| 87 weak_ptr_factory_.GetWeakPtr(), clipped_end, end + end), | |
| 88 base::TimeDelta::FromMilliseconds(2000)); | |
| 89 } | |
| 90 } | |
| 91 | |
| 92 } // namespace chromeos | |
| OLD | NEW |