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

Side by Side Diff: chrome/browser/media/router/media_routes_observer.h

Issue 1415103006: Non-Local Join for Media Router and Presentation API (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Review Fixes Created 5 years 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 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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 #ifndef CHROME_BROWSER_MEDIA_ROUTER_MEDIA_ROUTES_OBSERVER_H_ 5 #ifndef CHROME_BROWSER_MEDIA_ROUTER_MEDIA_ROUTES_OBSERVER_H_
6 #define CHROME_BROWSER_MEDIA_ROUTER_MEDIA_ROUTES_OBSERVER_H_ 6 #define CHROME_BROWSER_MEDIA_ROUTER_MEDIA_ROUTES_OBSERVER_H_
7 7
8 #include <vector> 8 #include <vector>
9 9
10 #include "base/macros.h" 10 #include "base/macros.h"
11 #include "chrome/browser/media/router/media_route.h" 11 #include "chrome/browser/media/router/media_route.h"
12 12
13 namespace media_router { 13 namespace media_router {
14 14
15 class MediaRouter; 15 class MediaRouter;
16 16
17 // Base class for observing when the set of MediaRoutes and their associated 17 // Base class for observing when the set of MediaRoutes and their associated
18 // MediaSinks have been updated. 18 // MediaSinks have been updated.
19 class MediaRoutesObserver { 19 class MediaRoutesObserver {
20 public: 20 public:
21 explicit MediaRoutesObserver(MediaRouter* router); 21 explicit MediaRoutesObserver(MediaRouter* router,
22 const MediaSource::Id source_id = MediaSource::Id());
22 virtual ~MediaRoutesObserver(); 23 virtual ~MediaRoutesObserver();
23 24
24 // Invoked when the list of routes and their associated sinks have been 25 // Invoked when the list of routes and their associated sinks have been
25 // updated. 26 // updated with the context of the |source_id|. This will return a list of
27 // |routes| and a list of |joinable_route_ids|. A route is joinable only if
28 // it is joinable in the context of the |source_id|.
26 // Implementations may not perform operations that modify the Media Router's 29 // Implementations may not perform operations that modify the Media Router's
27 // observer list. In particular, invoking this observer's destructor within 30 // observer list. In particular, invoking this observer's destructor within
28 // OnRoutesUpdated will result in undefined behavior. 31 // OnRoutesUpdated will result in undefined behavior.
29 virtual void OnRoutesUpdated(const std::vector<MediaRoute>& routes) {} 32 virtual void OnRoutesUpdated(
33 const std::vector<MediaRoute>& routes,
34 const std::vector<MediaRoute::Id>& joinable_route_ids) {}
35
36 const MediaSource::Id source_id() const { return source_id_; }
30 37
31 private: 38 private:
32 MediaRouter* router_; 39 MediaRouter* router_;
imcheng 2015/12/01 23:45:06 would it be possible to make this MediaRouter* con
matt.boetger 2015/12/03 01:19:20 No. I tried and it started cascading the change d
40 const MediaSource::Id source_id_;
33 41
34 DISALLOW_COPY_AND_ASSIGN(MediaRoutesObserver); 42 DISALLOW_COPY_AND_ASSIGN(MediaRoutesObserver);
35 }; 43 };
36 44
37 } // namespace media_router 45 } // namespace media_router
38 46
39 #endif // CHROME_BROWSER_MEDIA_ROUTER_MEDIA_ROUTES_OBSERVER_H_ 47 #endif // CHROME_BROWSER_MEDIA_ROUTER_MEDIA_ROUTES_OBSERVER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698