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

Side by Side Diff: services/image_decoder/image_decoder_service.cc

Issue 2701883002: service_manager: More consistent Service lifecycle API (Closed)
Patch Set: . Created 3 years, 10 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
OLDNEW
1 // Copyright 2016 The Chromium Authors. All rights reserved. 1 // Copyright 2016 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 "services/image_decoder/image_decoder_service.h" 5 #include "services/image_decoder/image_decoder_service.h"
6 6
7 #include "base/macros.h" 7 #include "base/macros.h"
8 #include "base/memory/ptr_util.h" 8 #include "base/memory/ptr_util.h"
9 #include "base/threading/thread_task_runner_handle.h" 9 #include "base/threading/thread_task_runner_handle.h"
10 #include "base/time/time.h" 10 #include "base/time/time.h"
(...skipping 44 matching lines...) Expand 10 before | Expand all | Expand 10 after
55 // InterfaceRegistry's connection. 55 // InterfaceRegistry's connection.
56 std::unique_ptr<service_manager::ServiceContextRef> connection_ref = 56 std::unique_ptr<service_manager::ServiceContextRef> connection_ref =
57 ref_factory_->CreateRef(); 57 ref_factory_->CreateRef();
58 registry->AddConnectionLostClosure( 58 registry->AddConnectionLostClosure(
59 base::Bind(&OnConnectionLost, base::Passed(&connection_ref))); 59 base::Bind(&OnConnectionLost, base::Passed(&connection_ref)));
60 registry->AddInterface( 60 registry->AddInterface(
61 base::Bind(&OnImageDecoderRequest, ref_factory_.get())); 61 base::Bind(&OnImageDecoderRequest, ref_factory_.get()));
62 return true; 62 return true;
63 } 63 }
64 64
65 bool ImageDecoderService::OnStop() {
66 return true;
67 }
68
69 void ImageDecoderService::MaybeRequestQuitDelayed() { 65 void ImageDecoderService::MaybeRequestQuitDelayed() {
70 base::ThreadTaskRunnerHandle::Get()->PostDelayedTask( 66 base::ThreadTaskRunnerHandle::Get()->PostDelayedTask(
71 FROM_HERE, 67 FROM_HERE,
72 base::Bind(&ImageDecoderService::MaybeRequestQuit, 68 base::Bind(&ImageDecoderService::MaybeRequestQuit,
73 weak_factory_.GetWeakPtr()), 69 weak_factory_.GetWeakPtr()),
74 base::TimeDelta::FromSeconds(5)); 70 base::TimeDelta::FromSeconds(5));
75 } 71 }
76 72
77 void ImageDecoderService::MaybeRequestQuit() { 73 void ImageDecoderService::MaybeRequestQuit() {
78 DCHECK(ref_factory_); 74 DCHECK(ref_factory_);
79 if (ref_factory_->HasNoRefs()) 75 if (ref_factory_->HasNoRefs())
80 context()->RequestQuit(); 76 context()->RequestQuit();
81 } 77 }
82 78
83 } // namespace image_decoder 79 } // namespace image_decoder
OLDNEW
« no previous file with comments | « services/image_decoder/image_decoder_service.h ('k') | services/service_manager/background/tests/test_service.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698