| OLD | NEW |
| 1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 "config.h" | 5 #include "config.h" |
| 6 #include "ServiceWorkerRegistration.h" | 6 #include "ServiceWorkerRegistration.h" |
| 7 | 7 |
| 8 #include "bindings/core/v8/CallbackPromiseAdapter.h" | 8 #include "bindings/core/v8/CallbackPromiseAdapter.h" |
| 9 #include "bindings/core/v8/ScriptPromise.h" | 9 #include "bindings/core/v8/ScriptPromise.h" |
| 10 #include "bindings/core/v8/ScriptPromiseResolver.h" | 10 #include "bindings/core/v8/ScriptPromiseResolver.h" |
| (...skipping 68 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 79 { | 79 { |
| 80 if (registration && !registration->proxy()) | 80 if (registration && !registration->proxy()) |
| 81 delete registration; | 81 delete registration; |
| 82 } | 82 } |
| 83 | 83 |
| 84 String ServiceWorkerRegistration::scope() const | 84 String ServiceWorkerRegistration::scope() const |
| 85 { | 85 { |
| 86 return m_outerRegistration->scope().string(); | 86 return m_outerRegistration->scope().string(); |
| 87 } | 87 } |
| 88 | 88 |
| 89 void ServiceWorkerRegistration::update(ScriptState* scriptState, ExceptionState&
exceptionState) | 89 ScriptPromise ServiceWorkerRegistration::update(ScriptState* scriptState) |
| 90 { | 90 { |
| 91 RefPtrWillBeRawPtr<ScriptPromiseResolver> resolver = ScriptPromiseResolver::
create(scriptState); |
| 92 ScriptPromise promise = resolver->promise(); |
| 93 |
| 91 if (!m_provider) { | 94 if (!m_provider) { |
| 92 exceptionState.throwDOMException(InvalidStateError, "Failed to update a
ServiceWorkerRegistration: No associated provider is available."); | 95 resolver->reject(DOMException::create(InvalidStateError, "Failed to upda
te a ServiceWorkerRegistration: No associated provider is available.")); |
| 93 return; | 96 return promise; |
| 94 } | 97 } |
| 95 m_outerRegistration->update(m_provider); | 98 |
| 99 m_outerRegistration->update(m_provider, new CallbackPromiseAdapter<void, Ser
viceWorkerError>(resolver)); |
| 100 return promise; |
| 96 } | 101 } |
| 97 | 102 |
| 98 ScriptPromise ServiceWorkerRegistration::unregister(ScriptState* scriptState) | 103 ScriptPromise ServiceWorkerRegistration::unregister(ScriptState* scriptState) |
| 99 { | 104 { |
| 100 RefPtrWillBeRawPtr<ScriptPromiseResolver> resolver = ScriptPromiseResolver::
create(scriptState); | 105 RefPtrWillBeRawPtr<ScriptPromiseResolver> resolver = ScriptPromiseResolver::
create(scriptState); |
| 101 ScriptPromise promise = resolver->promise(); | 106 ScriptPromise promise = resolver->promise(); |
| 102 | 107 |
| 103 if (!m_provider) { | 108 if (!m_provider) { |
| 104 resolver->reject(DOMException::create(InvalidStateError, "Failed to unre
gister a ServiceWorkerRegistration: No associated provider is available.")); | 109 resolver->reject(DOMException::create(InvalidStateError, "Failed to unre
gister a ServiceWorkerRegistration: No associated provider is available.")); |
| 105 return promise; | 110 return promise; |
| (...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 161 | 166 |
| 162 void ServiceWorkerRegistration::stop() | 167 void ServiceWorkerRegistration::stop() |
| 163 { | 168 { |
| 164 if (m_stopped) | 169 if (m_stopped) |
| 165 return; | 170 return; |
| 166 m_stopped = true; | 171 m_stopped = true; |
| 167 m_outerRegistration->proxyStopped(); | 172 m_outerRegistration->proxyStopped(); |
| 168 } | 173 } |
| 169 | 174 |
| 170 } // namespace blink | 175 } // namespace blink |
| OLD | NEW |