OLD | NEW |
---|---|
1 /* | 1 /* |
2 * Copyright (C) 2008 Apple Inc. All Rights Reserved. | 2 * Copyright (C) 2008 Apple Inc. All Rights Reserved. |
3 * | 3 * |
4 * Redistribution and use in source and binary forms, with or without | 4 * Redistribution and use in source and binary forms, with or without |
5 * modification, are permitted provided that the following conditions | 5 * modification, are permitted provided that the following conditions |
6 * are met: | 6 * are met: |
7 * 1. Redistributions of source code must retain the above copyright | 7 * 1. Redistributions of source code must retain the above copyright |
8 * notice, this list of conditions and the following disclaimer. | 8 * notice, this list of conditions and the following disclaimer. |
9 * 2. Redistributions in binary form must reproduce the above copyright | 9 * 2. Redistributions in binary form must reproduce the above copyright |
10 * notice, this list of conditions and the following disclaimer in the | 10 * notice, this list of conditions and the following disclaimer in the |
(...skipping 24 matching lines...) Expand all Loading... | |
35 #include "wtf/Threading.h" | 35 #include "wtf/Threading.h" |
36 | 36 |
37 namespace blink { | 37 namespace blink { |
38 | 38 |
39 NetworkStateNotifier& networkStateNotifier() | 39 NetworkStateNotifier& networkStateNotifier() |
40 { | 40 { |
41 DEFINE_THREAD_SAFE_STATIC_LOCAL(NetworkStateNotifier, networkStateNotifier, new NetworkStateNotifier); | 41 DEFINE_THREAD_SAFE_STATIC_LOCAL(NetworkStateNotifier, networkStateNotifier, new NetworkStateNotifier); |
42 return networkStateNotifier; | 42 return networkStateNotifier; |
43 } | 43 } |
44 | 44 |
45 void NetworkStateNotifier::setOnLine(bool onLine) | 45 void NetworkStateNotifier::setOnLine(bool onLineValue) |
46 { | 46 { |
47 ASSERT(isMainThread()); | 47 DCHECK(isMainThread()); |
48 | 48 |
49 { | 49 { |
50 MutexLocker locker(m_mutex); | 50 MutexLocker locker(m_mutex); |
51 if (m_isOnLine == onLine) | 51 m_onLineInitialized = true; |
52 | |
53 if (m_isOnLine == onLineValue) | |
52 return; | 54 return; |
55 m_isOnLine = onLineValue; | |
53 | 56 |
54 m_isOnLine = onLine; | 57 if (m_hasOverride) |
58 return; | |
55 } | 59 } |
56 | 60 |
57 Page::networkStateChanged(onLine); | 61 Page::networkStateChanged(onLine()); |
58 } | 62 } |
59 | 63 |
60 void NetworkStateNotifier::setWebConnection(WebConnectionType type, double maxBa ndwidthMbps) | 64 void NetworkStateNotifier::setWebConnection(WebConnectionType type, double maxBa ndwidthMbps) |
61 { | 65 { |
62 ASSERT(isMainThread()); | 66 DCHECK(isMainThread()); |
63 if (m_testUpdatesOnly) | |
64 return; | |
65 | 67 |
66 setWebConnectionImpl(type, maxBandwidthMbps); | 68 { |
69 MutexLocker locker(m_mutex); | |
70 m_connectionInitialized = true; | |
71 | |
72 if (m_type == type && m_maxBandwidthMbps == maxBandwidthMbps) | |
73 return; | |
74 m_type = type; | |
75 m_maxBandwidthMbps = maxBandwidthMbps; | |
76 | |
77 if (m_hasOverride) | |
78 return; | |
79 } | |
80 | |
81 notifyObservers(); | |
67 } | 82 } |
68 | 83 |
69 void NetworkStateNotifier::addObserver(NetworkStateObserver* observer, Execution Context* context) | 84 void NetworkStateNotifier::addObserver(NetworkStateObserver* observer, Execution Context* context) |
70 { | 85 { |
71 ASSERT(context->isContextThread()); | 86 ASSERT(context->isContextThread()); |
72 ASSERT(observer); | 87 ASSERT(observer); |
73 | 88 |
74 MutexLocker locker(m_mutex); | 89 MutexLocker locker(m_mutex); |
75 ObserverListMap::AddResult result = m_observers.add(context, nullptr); | 90 ObserverListMap::AddResult result = m_observers.add(context, nullptr); |
76 if (result.isNewEntry) | 91 if (result.isNewEntry) |
(...skipping 16 matching lines...) Expand all Loading... | |
93 size_t index = observers.find(observer); | 108 size_t index = observers.find(observer); |
94 if (index != kNotFound) { | 109 if (index != kNotFound) { |
95 observers[index] = 0; | 110 observers[index] = 0; |
96 observerList->zeroedObservers.append(index); | 111 observerList->zeroedObservers.append(index); |
97 } | 112 } |
98 | 113 |
99 if (!observerList->iterating && !observerList->zeroedObservers.isEmpty()) | 114 if (!observerList->iterating && !observerList->zeroedObservers.isEmpty()) |
100 collectZeroedObservers(observerList, context); | 115 collectZeroedObservers(observerList, context); |
101 } | 116 } |
102 | 117 |
103 void NetworkStateNotifier::setTestUpdatesOnly(bool updatesOnly) | 118 void NetworkStateNotifier::setOverride(bool onLineValue, WebConnectionType type, double maxBandwidthMbps) |
119 { | |
120 DCHECK(isMainThread()); | |
121 | |
122 { | |
123 MutexLocker locker(m_mutex); | |
124 m_hasOverride = true; | |
125 m_overrideOnLine = onLineValue; | |
126 m_overrideType = type; | |
127 m_overrideMaxBandwidthMbps = maxBandwidthMbps; | |
128 } | |
129 | |
130 notifyObservers(); | |
131 Page::networkStateChanged(onLine()); | |
jkarlin
2016/06/24 14:47:50
setOnline and setWebConnection check if anything h
dgozman
2016/06/24 15:13:44
I think this would be undesirable. Consider two ca
jkarlin
2016/06/24 19:20:16
The clients of NetworkStateNotifier (e.g., the onl
dgozman
2016/06/27 23:03:49
Alright, you convinced me. Can't go against the sp
| |
132 } | |
133 | |
134 void NetworkStateNotifier::clearOverride() | |
135 { | |
136 DCHECK(isMainThread()); | |
137 | |
138 { | |
139 MutexLocker locker(m_mutex); | |
140 m_hasOverride = false; | |
141 } | |
142 | |
143 notifyObservers(); | |
144 Page::networkStateChanged(onLine()); | |
jkarlin
2016/06/24 14:47:50
setOnline and setWebConnection check if anything h
| |
145 } | |
146 | |
147 void NetworkStateNotifier::notifyObservers() | |
104 { | 148 { |
105 ASSERT(isMainThread()); | 149 ASSERT(isMainThread()); |
106 MutexLocker locker(m_mutex); | 150 WebConnectionType type = connectionType(); |
107 | 151 double maxBandwidthMbps = maxBandwidth(); |
108 // Reset state to default when entering or leaving test mode. | |
109 if (updatesOnly != m_testUpdatesOnly) { | |
110 m_isOnLine = true; | |
111 m_type = WebConnectionTypeOther; | |
112 m_maxBandwidthMbps = std::numeric_limits<double>::infinity(); | |
113 } | |
114 | |
115 m_testUpdatesOnly = updatesOnly; | |
116 } | |
117 | |
118 void NetworkStateNotifier::setWebConnectionForTest(WebConnectionType type, doubl e maxBandwidthMbps) | |
119 { | |
120 ASSERT(isMainThread()); | |
121 ASSERT(m_testUpdatesOnly); | |
122 setWebConnectionImpl(type, maxBandwidthMbps); | |
123 } | |
124 | |
125 void NetworkStateNotifier::setWebConnectionImpl(WebConnectionType type, double m axBandwidthMbps) | |
126 { | |
127 ASSERT(isMainThread()); | |
128 | 152 |
129 MutexLocker locker(m_mutex); | 153 MutexLocker locker(m_mutex); |
130 m_initialized = true; | |
131 | |
132 if (m_type == type && m_maxBandwidthMbps == maxBandwidthMbps) | |
133 return; | |
134 m_type = type; | |
135 m_maxBandwidthMbps = maxBandwidthMbps; | |
136 | |
137 for (const auto& entry : m_observers) { | 154 for (const auto& entry : m_observers) { |
138 ExecutionContext* context = entry.key; | 155 ExecutionContext* context = entry.key; |
139 context->postTask(BLINK_FROM_HERE, createCrossThreadTask(&NetworkStateNo tifier::notifyObserversOfConnectionChangeOnContext, crossThreadUnretained(this), type, maxBandwidthMbps)); | 156 context->postTask(BLINK_FROM_HERE, createCrossThreadTask(&NetworkStateNo tifier::notifyObserversOfConnectionChangeOnContext, crossThreadUnretained(this), type, maxBandwidthMbps)); |
140 } | 157 } |
141 } | 158 } |
142 | 159 |
143 void NetworkStateNotifier::notifyObserversOfConnectionChangeOnContext(WebConnect ionType type, double maxBandwidthMbps, ExecutionContext* context) | 160 void NetworkStateNotifier::notifyObserversOfConnectionChangeOnContext(WebConnect ionType type, double maxBandwidthMbps, ExecutionContext* context) |
144 { | 161 { |
145 ObserverList* observerList = lockAndFindObserverList(context); | 162 ObserverList* observerList = lockAndFindObserverList(context); |
146 | 163 |
(...skipping 36 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
183 | 200 |
184 list->zeroedObservers.clear(); | 201 list->zeroedObservers.clear(); |
185 | 202 |
186 if (list->observers.isEmpty()) { | 203 if (list->observers.isEmpty()) { |
187 MutexLocker locker(m_mutex); | 204 MutexLocker locker(m_mutex); |
188 m_observers.remove(context); // deletes list | 205 m_observers.remove(context); // deletes list |
189 } | 206 } |
190 } | 207 } |
191 | 208 |
192 } // namespace blink | 209 } // namespace blink |
OLD | NEW |