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

Side by Side Diff: components/physical_web/data_source/physical_web_data_source_impl.cc

Issue 2765713002: Associate a scan mode with Physical Web listeners (Closed)
Patch Set: Created 3 years, 9 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
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 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 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 "base/observer_list.h" 5 #include "base/observer_list.h"
6 #include "components/physical_web/data_source/physical_web_data_source.h" 6 #include "components/physical_web/data_source/physical_web_data_source.h"
7 #include "components/physical_web/data_source/physical_web_data_source_impl.h" 7 #include "components/physical_web/data_source/physical_web_data_source_impl.h"
8 #include "components/physical_web/data_source/physical_web_listener.h" 8 #include "components/physical_web/data_source/physical_web_listener.h"
9 9
10 namespace physical_web { 10 namespace physical_web {
11 11
12 PhysicalWebDataSourceImpl::PhysicalWebDataSourceImpl() {} 12 PhysicalWebDataSourceImpl::PhysicalWebDataSourceImpl() {}
13 13
14 PhysicalWebDataSourceImpl::~PhysicalWebDataSourceImpl() {} 14 PhysicalWebDataSourceImpl::~PhysicalWebDataSourceImpl() {}
15 15
16 void PhysicalWebDataSourceImpl::RegisterListener( 16 void PhysicalWebDataSourceImpl::RegisterListener(
17 PhysicalWebListener* physical_web_listener) { 17 PhysicalWebListener* physical_web_listener, ScanMode scan_mode) {
18 observer_list_.AddObserver(physical_web_listener); 18 observer_list_.AddObserver(physical_web_listener);
mattreynolds 2017/03/21 19:02:56 ObserverList says observers shouldn't be added mor
cco3 2017/03/21 19:28:45 O snap.
19 scan_modes_[physical_web_listener] = scan_mode;
19 } 20 }
20 21
21 void PhysicalWebDataSourceImpl::UnregisterListener( 22 void PhysicalWebDataSourceImpl::UnregisterListener(
22 PhysicalWebListener* physical_web_listener) { 23 PhysicalWebListener* physical_web_listener) {
23 observer_list_.RemoveObserver(physical_web_listener); 24 observer_list_.RemoveObserver(physical_web_listener);
25 scan_modes_.erase(scan_modes_.find(physical_web_listener));
24 } 26 }
25 27
26 void PhysicalWebDataSourceImpl::NotifyOnFound(const GURL& url) { 28 void PhysicalWebDataSourceImpl::NotifyOnFound(const GURL& url) {
27 for (PhysicalWebListener& observer : observer_list_) 29 for (PhysicalWebListener& observer : observer_list_)
28 observer.OnFound(url); 30 observer.OnFound(url);
29 } 31 }
30 32
31 void PhysicalWebDataSourceImpl::NotifyOnLost(const GURL& url) { 33 void PhysicalWebDataSourceImpl::NotifyOnLost(const GURL& url) {
32 for (PhysicalWebListener& observer : observer_list_) 34 for (PhysicalWebListener& observer : observer_list_)
33 observer.OnLost(url); 35 observer.OnLost(url);
34 } 36 }
35 37
36 void PhysicalWebDataSourceImpl::NotifyOnDistanceChanged( 38 void PhysicalWebDataSourceImpl::NotifyOnDistanceChanged(
37 const GURL& url, 39 const GURL& url,
38 double distance_estimate) { 40 double distance_estimate) {
39 for (PhysicalWebListener& observer : observer_list_) 41 for (PhysicalWebListener& observer : observer_list_)
40 observer.OnDistanceChanged(url, distance_estimate); 42 observer.OnDistanceChanged(url, distance_estimate);
41 } 43 }
42 44
43 } // namespace physical_web 45 } // namespace physical_web
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698