| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 CONTENT_BROWSER_LOADER_RESOURCE_SCHEDULER_H_ | 5 #ifndef CONTENT_BROWSER_LOADER_RESOURCE_SCHEDULER_H_ |
| 6 #define CONTENT_BROWSER_LOADER_RESOURCE_SCHEDULER_H_ | 6 #define CONTENT_BROWSER_LOADER_RESOURCE_SCHEDULER_H_ |
| 7 | 7 |
| 8 #include <map> | 8 #include <map> |
| 9 #include <set> | 9 #include <set> |
| 10 | 10 |
| 11 #include "base/basictypes.h" | 11 #include "base/basictypes.h" |
| 12 #include "base/compiler_specific.h" | 12 #include "base/compiler_specific.h" |
| 13 #include "base/memory/scoped_ptr.h" | 13 #include "base/memory/scoped_ptr.h" |
| 14 #include "base/threading/non_thread_safe.h" | 14 #include "base/threading/non_thread_safe.h" |
| 15 #include "base/timer/timer.h" | 15 #include "base/timer/timer.h" |
| 16 #include "content/browser/web_contents/web_contents_impl.h" |
| 16 #include "content/common/content_export.h" | 17 #include "content/common/content_export.h" |
| 17 #include "net/base/priority_queue.h" | 18 #include "net/base/priority_queue.h" |
| 18 #include "net/base/request_priority.h" | 19 #include "net/base/request_priority.h" |
| 19 | 20 |
| 20 namespace net { | 21 namespace net { |
| 21 class HostPortPair; | 22 class HostPortPair; |
| 22 class URLRequest; | 23 class URLRequest; |
| 23 } | 24 } |
| 24 | 25 |
| 25 namespace content { | 26 namespace content { |
| (...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 74 // Note that clients which would be COALESCED are UNTHROTTLED until | 75 // Note that clients which would be COALESCED are UNTHROTTLED until |
| 75 // coalescing is turned on. | 76 // coalescing is turned on. |
| 76 UNTHROTTLED, | 77 UNTHROTTLED, |
| 77 // Observable (active) loading client. | 78 // Observable (active) loading client. |
| 78 ACTIVE_AND_LOADING, | 79 ACTIVE_AND_LOADING, |
| 79 }; | 80 }; |
| 80 | 81 |
| 81 ResourceScheduler(); | 82 ResourceScheduler(); |
| 82 ~ResourceScheduler(); | 83 ~ResourceScheduler(); |
| 83 | 84 |
| 85 // VisualObserver observes WebContents and lives on the UI thread. It notifies |
| 86 // the client about the visibility change. Each VisualObserver corresponds to |
| 87 // one and only one Client. The VisualObserver will be deleted when the client |
| 88 // is destructed. |
| 89 class VisualObserver; |
| 90 VisualObserver* CreateVisualObserver(WebContentsImpl* web_content); |
| 91 void DeleteVisualObserver(VisualObserver* observer); |
| 92 |
| 84 // Use a mock timer when testing. | 93 // Use a mock timer when testing. |
| 85 void set_timer_for_testing(scoped_ptr<base::Timer> timer) { | 94 void set_timer_for_testing(scoped_ptr<base::Timer> timer) { |
| 86 coalescing_timer_.reset(timer.release()); | 95 coalescing_timer_.reset(timer.release()); |
| 87 } | 96 } |
| 88 | 97 |
| 89 // TODO(aiolos): Remove when throttling and coalescing have landed | 98 // TODO(aiolos): Remove when throttling and coalescing have landed |
| 90 void SetThrottleOptionsForTesting(bool should_throttle, bool should_coalesce); | 99 void SetThrottleOptionsForTesting(bool should_throttle, bool should_coalesce); |
| 91 | 100 |
| 92 bool should_coalesce() const { return should_coalesce_; } | 101 bool should_coalesce() const { return should_coalesce_; } |
| 93 bool should_throttle() const { return should_throttle_; } | 102 bool should_throttle() const { return should_throttle_; } |
| 94 | 103 |
| 95 ClientThrottleState GetClientStateForTesting(int child_id, int route_id); | 104 ClientThrottleState GetClientStateForTesting(int child_id, int route_id); |
| 96 | 105 |
| 97 // Requests that this ResourceScheduler schedule, and eventually loads, the | 106 // Requests that this ResourceScheduler schedule, and eventually loads, the |
| 98 // specified |url_request|. Caller should delete the returned ResourceThrottle | 107 // specified |url_request|. Caller should delete the returned ResourceThrottle |
| 99 // when the load completes or is canceled. | 108 // when the load completes or is canceled. |
| 100 scoped_ptr<ResourceThrottle> ScheduleRequest( | 109 scoped_ptr<ResourceThrottle> ScheduleRequest( |
| 101 int child_id, int route_id, net::URLRequest* url_request); | 110 int child_id, int route_id, net::URLRequest* url_request); |
| 102 | 111 |
| 103 // Signals from the UI thread, posted as tasks on the IO thread: | 112 // Signals from the UI thread, posted as tasks on the IO thread: |
| 104 | 113 |
| 105 // Called when a renderer is created. | 114 // Called when a renderer is created. |
| 106 void OnClientCreated(int child_id, int route_id); | 115 void OnClientCreated(int child_id, |
| 116 int route_id, |
| 117 VisualObserver* visual_observer, |
| 118 bool is_visible); |
| 107 | 119 |
| 108 // Called when a renderer is destroyed. | 120 // Called when a renderer is destroyed. It will also delete the corresponding |
| 121 // VisualObserver in turn. |
| 109 void OnClientDeleted(int child_id, int route_id); | 122 void OnClientDeleted(int child_id, int route_id); |
| 110 | 123 |
| 111 // Signals from IPC messages directly from the renderers: | 124 // Signals from IPC messages directly from the renderers: |
| 112 | 125 |
| 113 // Called when a client navigates to a new main document. | 126 // Called when a client navigates to a new main document. |
| 114 void OnNavigate(int child_id, int route_id); | 127 void OnNavigate(int child_id, int route_id); |
| 115 | 128 |
| 116 // Called when the client has parsed the <body> element. This is a signal that | 129 // Called when the client has parsed the <body> element. This is a signal that |
| 117 // resource loads won't interfere with first paint. | 130 // resource loads won't interfere with first paint. |
| 118 void OnWillInsertBody(int child_id, int route_id); | 131 void OnWillInsertBody(int child_id, int route_id); |
| 119 | 132 |
| 120 // Signals from the IO thread: | 133 // Signals from the IO thread: |
| 121 | 134 |
| 122 // Called when we received a response to a http request that was served | 135 // Called when we received a response to a http request that was served |
| 123 // from a proxy using SPDY. | 136 // from a proxy using SPDY. |
| 124 void OnReceivedSpdyProxiedHttpResponse(int child_id, int route_id); | 137 void OnReceivedSpdyProxiedHttpResponse(int child_id, int route_id); |
| 125 | 138 |
| 126 // Client functions: | 139 // Client functions: |
| 127 | 140 |
| 128 // Called to check if all user observable tabs have completed loading. | 141 // Called to check if all user observable tabs have completed loading. |
| 129 bool active_clients_loaded() const { return active_clients_loading_ == 0; } | 142 bool active_clients_loaded() const { return active_clients_loading_ == 0; } |
| 130 | 143 |
| 131 // Called when a Client starts or stops playing audio. | 144 // Called when a Client starts or stops playing audio. |
| 132 void OnAudibilityChanged(int child_id, int route_id, bool is_audible); | 145 void OnAudibilityChanged(int child_id, int route_id, bool is_audible); |
| 133 | 146 |
| 134 // Called when a Client is shown or hidden. | 147 void OnLoadingStateChanged(int child_id, int route_id, bool is_loaded); |
| 135 void OnVisibilityChanged(int child_id, int route_id, bool is_visible); | |
| 136 | 148 |
| 137 void OnLoadingStateChanged(int child_id, int route_id, bool is_loaded); | 149 bool IsClientVisibleForTesting(int child_id, int route_id); |
| 138 | 150 |
| 139 private: | 151 private: |
| 140 class RequestQueue; | 152 class RequestQueue; |
| 141 class ScheduledResourceRequest; | 153 class ScheduledResourceRequest; |
| 142 struct RequestPriorityParams; | 154 struct RequestPriorityParams; |
| 143 struct ScheduledResourceSorter { | 155 struct ScheduledResourceSorter { |
| 144 bool operator()(const ScheduledResourceRequest* a, | 156 bool operator()(const ScheduledResourceRequest* a, |
| 145 const ScheduledResourceRequest* b) const; | 157 const ScheduledResourceRequest* b) const; |
| 146 }; | 158 }; |
| 147 class Client; | 159 class Client; |
| (...skipping 48 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 196 size_t active_clients_loading_; | 208 size_t active_clients_loading_; |
| 197 size_t coalesced_clients_; | 209 size_t coalesced_clients_; |
| 198 // This is a repeating timer to initiate requests on COALESCED Clients. | 210 // This is a repeating timer to initiate requests on COALESCED Clients. |
| 199 scoped_ptr<base::Timer> coalescing_timer_; | 211 scoped_ptr<base::Timer> coalescing_timer_; |
| 200 RequestSet unowned_requests_; | 212 RequestSet unowned_requests_; |
| 201 }; | 213 }; |
| 202 | 214 |
| 203 } // namespace content | 215 } // namespace content |
| 204 | 216 |
| 205 #endif // CONTENT_BROWSER_LOADER_RESOURCE_SCHEDULER_H_ | 217 #endif // CONTENT_BROWSER_LOADER_RESOURCE_SCHEDULER_H_ |
| OLD | NEW |