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 #include "content/shell/browser/layout_test/layout_test_permission_manager.h" | 5 #include "content/shell/browser/layout_test/layout_test_permission_manager.h" |
6 | 6 |
7 #include <list> | 7 #include <list> |
| 8 #include <memory> |
| 9 #include <utility> |
8 | 10 |
9 #include "base/bind.h" | 11 #include "base/bind.h" |
10 #include "base/callback.h" | 12 #include "base/callback.h" |
11 #include "content/public/browser/browser_thread.h" | 13 #include "content/public/browser/browser_thread.h" |
12 #include "content/public/browser/permission_type.h" | 14 #include "content/public/browser/permission_type.h" |
13 #include "content/public/browser/web_contents.h" | 15 #include "content/public/browser/web_contents.h" |
14 #include "content/shell/browser/layout_test/layout_test_content_browser_client.h
" | 16 #include "content/shell/browser/layout_test/layout_test_content_browser_client.h
" |
15 #include "content/shell/browser/layout_test/layout_test_notification_manager.h" | 17 #include "content/shell/browser/layout_test/layout_test_notification_manager.h" |
16 | 18 |
17 namespace content { | 19 namespace content { |
(...skipping 122 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
140 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 142 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
141 } | 143 } |
142 | 144 |
143 int LayoutTestPermissionManager::SubscribePermissionStatusChange( | 145 int LayoutTestPermissionManager::SubscribePermissionStatusChange( |
144 PermissionType permission, | 146 PermissionType permission, |
145 const GURL& requesting_origin, | 147 const GURL& requesting_origin, |
146 const GURL& embedding_origin, | 148 const GURL& embedding_origin, |
147 const base::Callback<void(blink::mojom::PermissionStatus)>& callback) { | 149 const base::Callback<void(blink::mojom::PermissionStatus)>& callback) { |
148 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 150 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
149 | 151 |
150 Subscription* subscription = new Subscription(); | 152 auto subscription = base::MakeUnique<Subscription>(); |
151 subscription->permission = | 153 subscription->permission = |
152 PermissionDescription(permission, requesting_origin, embedding_origin); | 154 PermissionDescription(permission, requesting_origin, embedding_origin); |
153 subscription->callback = callback; | 155 subscription->callback = callback; |
154 subscription->current_value = | 156 subscription->current_value = |
155 GetPermissionStatus(permission, | 157 GetPermissionStatus(permission, |
156 subscription->permission.origin, | 158 subscription->permission.origin, |
157 subscription->permission.embedding_origin); | 159 subscription->permission.embedding_origin); |
158 | 160 |
159 return subscriptions_.Add(subscription); | 161 return subscriptions_.Add(std::move(subscription)); |
160 } | 162 } |
161 | 163 |
162 void LayoutTestPermissionManager::UnsubscribePermissionStatusChange( | 164 void LayoutTestPermissionManager::UnsubscribePermissionStatusChange( |
163 int subscription_id) { | 165 int subscription_id) { |
164 DCHECK_CURRENTLY_ON(BrowserThread::UI); | 166 DCHECK_CURRENTLY_ON(BrowserThread::UI); |
165 | 167 |
166 // Whether |subscription_id| is known will be checked by the Remove() call. | 168 // Whether |subscription_id| is known will be checked by the Remove() call. |
167 subscriptions_.Remove(subscription_id); | 169 subscriptions_.Remove(subscription_id); |
168 } | 170 } |
169 | 171 |
(...skipping 46 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
216 // Add the callback to |callbacks| which will be run after the loop to | 218 // Add the callback to |callbacks| which will be run after the loop to |
217 // prevent re-entrance issues. | 219 // prevent re-entrance issues. |
218 callbacks.push_back(base::Bind(subscription->callback, status)); | 220 callbacks.push_back(base::Bind(subscription->callback, status)); |
219 } | 221 } |
220 | 222 |
221 for (const auto& callback : callbacks) | 223 for (const auto& callback : callbacks) |
222 callback.Run(); | 224 callback.Run(); |
223 } | 225 } |
224 | 226 |
225 } // namespace content | 227 } // namespace content |
OLD | NEW |