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

Unified Diff: chrome/browser/media/router/media_router_base.cc

Issue 1430413003: [Media Router] Connection state change listening redesign part 2. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 1 month 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/media/router/media_router_base.cc
diff --git a/chrome/browser/media/router/media_router_base.cc b/chrome/browser/media/router/media_router_base.cc
new file mode 100644
index 0000000000000000000000000000000000000000..1078152c7a9b329d130fe7efdff273fd4c7dd0bd
--- /dev/null
+++ b/chrome/browser/media/router/media_router_base.cc
@@ -0,0 +1,51 @@
+// Copyright 2015 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome/browser/media/router/media_router_base.h"
+
+#include "base/bind.h"
+
+namespace media_router {
+
+MediaRouterBase::MediaRouterBase() = default;
+
+MediaRouterBase::~MediaRouterBase() = default;
+
+scoped_ptr<PresentationConnectionStateSubscription>
+MediaRouterBase::AddPresentationConnectionStateChangedCallback(
+ const MediaRoute::Id& route_id,
+ const content::PresentationConnectionStateChangedCallback& callback) {
+ DCHECK(thread_checker_.CalledOnValidThread());
+
+ auto* callbacks = presentation_connection_state_callbacks_.get(route_id);
+ if (!callbacks) {
+ callbacks = new PresentationConnectionStateChangedCallbacks;
+ callbacks->set_removal_callback(base::Bind(
+ &MediaRouterBase::OnPresentationConnectionStateCallbackRemoved,
+ base::Unretained(this), route_id));
+ presentation_connection_state_callbacks_.add(route_id,
+ make_scoped_ptr(callbacks));
+ }
+
+ return callbacks->Add(callback);
+}
+
+void MediaRouterBase::NotifyPresentationConnectionStateChange(
+ const MediaRoute::Id& route_id,
+ content::PresentationConnectionState state) {
+ auto* callbacks = presentation_connection_state_callbacks_.get(route_id);
+ if (!callbacks)
+ return;
+
+ callbacks->Notify(state);
+}
+
+void MediaRouterBase::OnPresentationConnectionStateCallbackRemoved(
+ const MediaRoute::Id& route_id) {
+ auto* callbacks = presentation_connection_state_callbacks_.get(route_id);
+ if (callbacks && callbacks->empty())
+ presentation_connection_state_callbacks_.erase(route_id);
+}
+
+} // namespace media_router
« no previous file with comments | « chrome/browser/media/router/media_router_base.h ('k') | chrome/browser/media/router/media_router_mojo_impl.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698