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

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 3 * WITH UI Changes 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.
mark a. foltz 2015/12/16 07:17:35 The meaning of the media_source ctor parameter nee
matt.boetger 2015/12/18 23:37:15 Done.
19 class MediaRoutesObserver { 19 class MediaRoutesObserver {
20 public: 20 public:
21 explicit MediaRoutesObserver(MediaRouter* router); 21 explicit MediaRoutesObserver(MediaRouter* router) :
22 MediaRoutesObserver(router, MediaSource::Id()) {}
23 explicit MediaRoutesObserver(MediaRouter* router,
mark a. foltz 2015/12/16 07:17:35 explicit is not necessary for a two-arg ctor.
matt.boetger 2015/12/18 23:37:15 Done.
24 const MediaSource::Id source_id);
22 virtual ~MediaRoutesObserver(); 25 virtual ~MediaRoutesObserver();
23 26
24 // Invoked when the list of routes and their associated sinks have been 27 // Invoked when the list of routes and their associated sinks have been
25 // updated. 28 // updated with the context of the |source_id|. This will return a list of
29 // |routes| and a list of |joinable_route_ids|. A route is joinable only if
30 // it is joinable in the context of the |source_id|.
26 // Implementations may not perform operations that modify the Media Router's 31 // Implementations may not perform operations that modify the Media Router's
27 // observer list. In particular, invoking this observer's destructor within 32 // observer list. In particular, invoking this observer's destructor within
28 // OnRoutesUpdated will result in undefined behavior. 33 // OnRoutesUpdated will result in undefined behavior.
29 virtual void OnRoutesUpdated(const std::vector<MediaRoute>& routes) {} 34 virtual void OnRoutesUpdated(
35 const std::vector<MediaRoute>& routes,
36 const std::vector<MediaRoute::Id>& joinable_route_ids =
37 std::vector<MediaRoute::Id>()) {}
matt.boetger 2015/12/18 23:37:15 Are default parameters not allowed everywhere, or
imcheng 2015/12/21 20:00:35 Default arguments are not allowed in functions, bu
matt.boetger 2015/12/22 20:44:51 Thanks for the link. I removed the default parame
38
39 const MediaSource::Id source_id() const { return source_id_; }
30 40
31 private: 41 private:
32 MediaRouter* router_; 42 MediaRouter* router_;
43 const MediaSource::Id source_id_;
33 44
34 DISALLOW_COPY_AND_ASSIGN(MediaRoutesObserver); 45 DISALLOW_COPY_AND_ASSIGN(MediaRoutesObserver);
35 }; 46 };
36 47
37 } // namespace media_router 48 } // namespace media_router
38 49
39 #endif // CHROME_BROWSER_MEDIA_ROUTER_MEDIA_ROUTES_OBSERVER_H_ 50 #endif // CHROME_BROWSER_MEDIA_ROUTER_MEDIA_ROUTES_OBSERVER_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698