Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(16)

Side by Side Diff: content/browser/service_worker/service_worker_registration.cc

Issue 556003006: [ServiceWorker] Check is_uninstalled in ServiceWorkerRegisterJob::ContinueWithRegistration() (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: move is_uninstalled_ = true; Created 6 years, 3 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « content/browser/service_worker/service_worker_registration.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2013 The Chromium Authors. All rights reserved. 1 // Copyright 2013 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/browser/service_worker/service_worker_registration.h" 5 #include "content/browser/service_worker/service_worker_registration.h"
6 6
7 #include "content/browser/service_worker/service_worker_context_core.h" 7 #include "content/browser/service_worker/service_worker_context_core.h"
8 #include "content/browser/service_worker/service_worker_info.h" 8 #include "content/browser/service_worker/service_worker_info.h"
9 #include "content/browser/service_worker/service_worker_register_job.h" 9 #include "content/browser/service_worker/service_worker_register_job.h"
10 #include "content/browser/service_worker/service_worker_utils.h" 10 #include "content/browser/service_worker/service_worker_utils.h"
(...skipping 12 matching lines...) Expand all
23 } // namespace 23 } // namespace
24 24
25 ServiceWorkerRegistration::ServiceWorkerRegistration( 25 ServiceWorkerRegistration::ServiceWorkerRegistration(
26 const GURL& pattern, 26 const GURL& pattern,
27 int64 registration_id, 27 int64 registration_id,
28 base::WeakPtr<ServiceWorkerContextCore> context) 28 base::WeakPtr<ServiceWorkerContextCore> context)
29 : pattern_(pattern), 29 : pattern_(pattern),
30 registration_id_(registration_id), 30 registration_id_(registration_id),
31 is_deleted_(false), 31 is_deleted_(false),
32 is_uninstalling_(false), 32 is_uninstalling_(false),
33 is_uninstalled_(false),
33 should_activate_when_ready_(false), 34 should_activate_when_ready_(false),
34 context_(context) { 35 context_(context) {
35 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); 36 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
36 DCHECK(context_); 37 DCHECK(context_);
37 context_->AddLiveRegistration(this); 38 context_->AddLiveRegistration(this);
38 } 39 }
39 40
40 ServiceWorkerRegistration::~ServiceWorkerRegistration() { 41 ServiceWorkerRegistration::~ServiceWorkerRegistration() {
41 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO)); 42 DCHECK(BrowserThread::CurrentlyOn(BrowserThread::IO));
42 DCHECK(!listeners_.might_have_observers()); 43 DCHECK(!listeners_.might_have_observers());
(...skipping 237 matching lines...) Expand 10 before | Expand all | Expand 10 after
280 } 281 }
281 282
282 void ServiceWorkerRegistration::OnDeleteFinished( 283 void ServiceWorkerRegistration::OnDeleteFinished(
283 ServiceWorkerStatusCode status) { 284 ServiceWorkerStatusCode status) {
284 // Intentionally empty completion callback, used to prevent 285 // Intentionally empty completion callback, used to prevent
285 // |this| from being deleted until the storage method completes. 286 // |this| from being deleted until the storage method completes.
286 } 287 }
287 288
288 void ServiceWorkerRegistration::Clear() { 289 void ServiceWorkerRegistration::Clear() {
289 is_uninstalling_ = false; 290 is_uninstalling_ = false;
291 is_uninstalled_ = true;
290 if (context_) 292 if (context_)
291 context_->storage()->NotifyDoneUninstallingRegistration(this); 293 context_->storage()->NotifyDoneUninstallingRegistration(this);
292 294
293 ChangedVersionAttributesMask mask; 295 ChangedVersionAttributesMask mask;
294 if (installing_version_.get()) { 296 if (installing_version_.get()) {
295 installing_version_->Doom(); 297 installing_version_->Doom();
296 installing_version_ = NULL; 298 installing_version_ = NULL;
297 mask.add(ChangedVersionAttributesMask::INSTALLING_VERSION); 299 mask.add(ChangedVersionAttributesMask::INSTALLING_VERSION);
298 } 300 }
299 if (waiting_version_.get()) { 301 if (waiting_version_.get()) {
(...skipping 24 matching lines...) Expand all
324 if (!context_) { 326 if (!context_) {
325 callback.Run(SERVICE_WORKER_ERROR_ABORT); 327 callback.Run(SERVICE_WORKER_ERROR_ABORT);
326 return; 328 return;
327 } 329 }
328 context_->storage()->NotifyDoneInstallingRegistration( 330 context_->storage()->NotifyDoneInstallingRegistration(
329 this, version.get(), status); 331 this, version.get(), status);
330 callback.Run(status); 332 callback.Run(status);
331 } 333 }
332 334
333 } // namespace content 335 } // namespace content
OLDNEW
« no previous file with comments | « content/browser/service_worker/service_worker_registration.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698