Chromium Code Reviews| OLD | NEW |
|---|---|
| 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_ANDROID_ROUTER_MEDIA_ROUTER_ANDROID_H_ | 5 #ifndef CHROME_BROWSER_MEDIA_ANDROID_ROUTER_MEDIA_ROUTER_ANDROID_H_ |
| 6 #define CHROME_BROWSER_MEDIA_ANDROID_ROUTER_MEDIA_ROUTER_ANDROID_H_ | 6 #define CHROME_BROWSER_MEDIA_ANDROID_ROUTER_MEDIA_ROUTER_ANDROID_H_ |
| 7 | 7 |
| 8 #include <jni.h> | 8 #include <jni.h> |
| 9 | 9 |
| 10 #include "base/android/scoped_java_ref.h" | 10 #include "base/android/scoped_java_ref.h" |
| (...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 45 const std::string& message, | 45 const std::string& message, |
| 46 const SendRouteMessageCallback& callback) override; | 46 const SendRouteMessageCallback& callback) override; |
| 47 void SendRouteBinaryMessage( | 47 void SendRouteBinaryMessage( |
| 48 const MediaRoute::Id& route_id, | 48 const MediaRoute::Id& route_id, |
| 49 scoped_ptr<std::vector<uint8>> data, | 49 scoped_ptr<std::vector<uint8>> data, |
| 50 const SendRouteMessageCallback& callback) override; | 50 const SendRouteMessageCallback& callback) override; |
| 51 void ClearIssue(const Issue::Id& issue_id) override; | 51 void ClearIssue(const Issue::Id& issue_id) override; |
| 52 | 52 |
| 53 // JNI functions. | 53 // JNI functions. |
| 54 void OnSinksReceived( | 54 void OnSinksReceived( |
| 55 JNIEnv* env, jobject obj, jstring source_urn, jint count); | 55 JNIEnv* env, jobject obj, jstring jsource_urn, jint jcount); |
| 56 void OnRouteCreated( | 56 void OnRouteCreated( |
| 57 JNIEnv* env, | 57 JNIEnv* env, |
| 58 jobject obj, | 58 jobject obj, |
| 59 jstring media_route_id, | 59 jstring jmedia_route_id, |
| 60 jint jcreate_route_request_id, | 60 jint jcreate_route_request_id, |
| 61 jboolean jis_local); | 61 jboolean jis_local); |
| 62 void OnRouteCreationError( | 62 void OnRouteCreationError( |
| 63 JNIEnv* env, | 63 JNIEnv* env, |
| 64 jobject obj, | 64 jobject obj, |
| 65 jstring error_text, | 65 jstring jerror_text, |
| 66 jint jcreate_route_request_id); | 66 jint jcreate_route_request_id); |
| 67 void OnRouteClosed(JNIEnv* env, jobject obj, jstring jmedia_route_id); | |
| 67 | 68 |
| 68 private: | 69 private: |
| 69 friend class MediaRouterFactory; | 70 friend class MediaRouterFactory; |
| 70 | 71 |
| 71 explicit MediaRouterAndroid(content::BrowserContext*); | 72 explicit MediaRouterAndroid(content::BrowserContext*); |
| 72 | 73 |
| 74 void UpdateRoutesObservers(); | |
| 75 | |
| 73 // MediaRouter implementation. | 76 // MediaRouter implementation. |
| 74 void RegisterMediaSinksObserver(MediaSinksObserver* observer) override; | 77 void RegisterMediaSinksObserver(MediaSinksObserver* observer) override; |
| 75 void UnregisterMediaSinksObserver(MediaSinksObserver* observer) override; | 78 void UnregisterMediaSinksObserver(MediaSinksObserver* observer) override; |
| 76 void RegisterMediaRoutesObserver(MediaRoutesObserver* observer) override; | 79 void RegisterMediaRoutesObserver(MediaRoutesObserver* observer) override; |
| 77 void UnregisterMediaRoutesObserver(MediaRoutesObserver* observer) override; | 80 void UnregisterMediaRoutesObserver(MediaRoutesObserver* observer) override; |
| 78 void RegisterIssuesObserver(IssuesObserver* observer) override; | 81 void RegisterIssuesObserver(IssuesObserver* observer) override; |
| 79 void UnregisterIssuesObserver(IssuesObserver* observer) override; | 82 void UnregisterIssuesObserver(IssuesObserver* observer) override; |
| 80 void RegisterPresentationSessionMessagesObserver( | 83 void RegisterPresentationSessionMessagesObserver( |
| 81 PresentationSessionMessagesObserver* observer) override; | 84 PresentationSessionMessagesObserver* observer) override; |
| 82 void UnregisterPresentationSessionMessagesObserver( | 85 void UnregisterPresentationSessionMessagesObserver( |
| 83 PresentationSessionMessagesObserver* observer) override; | 86 PresentationSessionMessagesObserver* observer) override; |
| 84 | 87 |
| 85 base::android::ScopedJavaGlobalRef<jobject> java_media_router_; | 88 base::android::ScopedJavaGlobalRef<jobject> java_media_router_; |
| 86 | 89 |
| 87 using MediaSinkObservers = base::ScopedPtrHashMap< | 90 using MediaSinkObservers = base::ScopedPtrHashMap< |
| 88 MediaSource::Id, | 91 MediaSource::Id, |
| 89 scoped_ptr<base::ObserverList<MediaSinksObserver>>>; | 92 scoped_ptr<base::ObserverList<MediaSinksObserver>>>; |
| 90 MediaSinkObservers sinks_observers_; | 93 MediaSinkObservers sinks_observers_; |
| 91 | 94 |
| 95 base::ObserverList<MediaRoutesObserver> routes_observers_; | |
| 96 | |
| 92 struct CreateMediaRouteRequest { | 97 struct CreateMediaRouteRequest { |
| 93 CreateMediaRouteRequest( | 98 CreateMediaRouteRequest( |
| 94 const MediaSource& source, | 99 const MediaSource& source, |
| 95 const MediaSink& sink, | 100 const MediaSink& sink, |
| 96 const std::string& presentation_id, | 101 const std::string& presentation_id, |
| 97 const std::vector<MediaRouteResponseCallback>& callbacks); | 102 const std::vector<MediaRouteResponseCallback>& callbacks); |
| 98 ~CreateMediaRouteRequest(); | 103 ~CreateMediaRouteRequest(); |
| 99 | 104 |
| 100 MediaSource media_source; | 105 MediaSource media_source; |
| 101 MediaSink media_sink; | 106 MediaSink media_sink; |
| 102 std::string presentation_id; | 107 std::string presentation_id; |
| 103 std::vector<MediaRouteResponseCallback> callbacks; | 108 std::vector<MediaRouteResponseCallback> callbacks; |
| 104 }; | 109 }; |
| 105 | 110 |
| 106 using CreateMediaRouteRequests = | 111 using CreateMediaRouteRequests = |
| 107 IDMap<CreateMediaRouteRequest, IDMapOwnPointer>; | 112 IDMap<CreateMediaRouteRequest, IDMapOwnPointer>; |
| 108 CreateMediaRouteRequests create_route_requests_; | 113 CreateMediaRouteRequests create_route_requests_; |
| 109 | 114 |
| 115 using MediaRoutes = base::ScopedPtrHashMap< | |
| 116 MediaRoute::Id, scoped_ptr<MediaRoute>>; | |
| 117 MediaRoutes active_routes_; | |
|
mlamouri (slow - plz ping)
2015/08/18 22:39:37
FWIW, I'm not sure if it is really helping to have
whywhat
2015/08/19 00:26:43
Agreed. I don't think a map is needed in the futur
| |
| 118 | |
| 110 DISALLOW_COPY_AND_ASSIGN(MediaRouterAndroid); | 119 DISALLOW_COPY_AND_ASSIGN(MediaRouterAndroid); |
| 111 }; | 120 }; |
| 112 | 121 |
| 113 } // namespace media_router | 122 } // namespace media_router |
| 114 | 123 |
| 115 #endif // CHROME_BROWSER_MEDIA_ANDROID_ROUTER_MEDIA_ROUTER_ANDROID_H_ | 124 #endif // CHROME_BROWSER_MEDIA_ANDROID_ROUTER_MEDIA_ROUTER_ANDROID_H_ |
| OLD | NEW |