| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (C) 2009 Apple Inc. All rights reserved. | 2 * Copyright (C) 2009 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 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 79 { | 79 { |
| 80 if (!m_isClientUpdating) | 80 if (!m_isClientUpdating) |
| 81 return; | 81 return; |
| 82 m_isClientUpdating = false; | 82 m_isClientUpdating = false; |
| 83 m_client->stopUpdating(); | 83 m_client->stopUpdating(); |
| 84 } | 84 } |
| 85 | 85 |
| 86 GeolocationController::~GeolocationController() | 86 GeolocationController::~GeolocationController() |
| 87 { | 87 { |
| 88 ASSERT(m_observers.isEmpty()); | 88 ASSERT(m_observers.isEmpty()); |
| 89 detach(); | |
| 90 } | |
| 91 | |
| 92 void GeolocationController::detach() | |
| 93 { | |
| 94 #if !ENABLE(OILPAN) | 89 #if !ENABLE(OILPAN) |
| 95 if (page() && m_inspectorAgent) { | 90 if (page() && m_inspectorAgent) { |
| 96 m_inspectorAgent->removeController(this); | 91 m_inspectorAgent->removeController(this); |
| 97 m_inspectorAgent = nullptr; | 92 m_inspectorAgent = nullptr; |
| 98 } | 93 } |
| 99 #endif | |
| 100 | 94 |
| 101 if (m_hasClientForTest) { | 95 if (m_hasClientForTest) { |
| 102 m_client->controllerForTestRemoved(this); | 96 m_client->controllerForTestRemoved(this); |
| 103 m_hasClientForTest = false; | 97 m_hasClientForTest = false; |
| 104 } | 98 } |
| 105 } | 99 #endif |
| 106 | |
| 107 // FIXME: Oilpan: Once GeolocationClient is on-heap m_client should be a strong | |
| 108 // pointer and |willBeDestroyed| can potentially be removed from Supplement. | |
| 109 void GeolocationController::willBeDestroyed() | |
| 110 { | |
| 111 detach(); | |
| 112 if (m_client) { | |
| 113 m_client->geolocationDestroyed(); | |
| 114 m_client = 0; | |
| 115 } | |
| 116 } | 100 } |
| 117 | 101 |
| 118 void GeolocationController::persistentHostHasBeenDestroyed() | 102 void GeolocationController::persistentHostHasBeenDestroyed() |
| 119 { | 103 { |
| 120 observeContext(0); | 104 observeContext(0); |
| 121 } | 105 } |
| 122 | 106 |
| 123 PassOwnPtrWillBeRawPtr<GeolocationController> GeolocationController::create(Loca
lFrame& frame, GeolocationClient* client) | 107 PassOwnPtrWillBeRawPtr<GeolocationController> GeolocationController::create(Loca
lFrame& frame, GeolocationClient* client) |
| 124 { | 108 { |
| 125 return adoptPtrWillBeNoop(new GeolocationController(frame, client)); | 109 return adoptPtrWillBeNoop(new GeolocationController(frame, client)); |
| (...skipping 98 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 224 stopUpdatingIfNeeded(); | 208 stopUpdatingIfNeeded(); |
| 225 } | 209 } |
| 226 | 210 |
| 227 const char* GeolocationController::supplementName() | 211 const char* GeolocationController::supplementName() |
| 228 { | 212 { |
| 229 return "GeolocationController"; | 213 return "GeolocationController"; |
| 230 } | 214 } |
| 231 | 215 |
| 232 void GeolocationController::trace(Visitor* visitor) | 216 void GeolocationController::trace(Visitor* visitor) |
| 233 { | 217 { |
| 218 visitor->trace(m_client); |
| 234 visitor->trace(m_lastPosition); | 219 visitor->trace(m_lastPosition); |
| 235 visitor->trace(m_observers); | 220 visitor->trace(m_observers); |
| 236 visitor->trace(m_highAccuracyObservers); | 221 visitor->trace(m_highAccuracyObservers); |
| 237 visitor->trace(m_inspectorAgent); | 222 visitor->trace(m_inspectorAgent); |
| 238 WillBeHeapSupplement<LocalFrame>::trace(visitor); | 223 WillBeHeapSupplement<LocalFrame>::trace(visitor); |
| 239 } | 224 } |
| 240 | 225 |
| 241 void provideGeolocationTo(LocalFrame& frame, GeolocationClient* client) | 226 void provideGeolocationTo(LocalFrame& frame, GeolocationClient* client) |
| 242 { | 227 { |
| 243 WillBeHeapSupplement<LocalFrame>::provideTo(frame, GeolocationController::su
pplementName(), GeolocationController::create(frame, client)); | 228 WillBeHeapSupplement<LocalFrame>::provideTo(frame, GeolocationController::su
pplementName(), GeolocationController::create(frame, client)); |
| 244 } | 229 } |
| 245 | 230 |
| 246 } // namespace blink | 231 } // namespace blink |
| OLD | NEW |