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

Side by Side Diff: services/test_service/test_service_application.cc

Issue 1979723002: ApplicationConnection devolution, part 3. (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Created 4 years, 7 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 | « services/test_service/test_service_application.h ('k') | services/tracing/tracing_app.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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 "services/test_service/test_service_application.h" 5 #include "services/test_service/test_service_application.h"
6 6
7 #include <assert.h> 7 #include <assert.h>
8 8
9 #include <memory> 9 #include <memory>
10 10
(...skipping 10 matching lines...) Expand all
21 TestServiceApplication::TestServiceApplication() 21 TestServiceApplication::TestServiceApplication()
22 : ref_count_(0), app_impl_(nullptr) {} 22 : ref_count_(0), app_impl_(nullptr) {}
23 23
24 TestServiceApplication::~TestServiceApplication() {} 24 TestServiceApplication::~TestServiceApplication() {}
25 25
26 void TestServiceApplication::Initialize(ApplicationImpl* app) { 26 void TestServiceApplication::Initialize(ApplicationImpl* app) {
27 app_impl_ = app; 27 app_impl_ = app;
28 } 28 }
29 29
30 bool TestServiceApplication::ConfigureIncomingConnection( 30 bool TestServiceApplication::ConfigureIncomingConnection(
31 ApplicationConnection* connection) { 31 ServiceProviderImpl* service_provider_impl) {
32 connection->GetServiceProviderImpl().AddService<TestService>( 32 service_provider_impl->AddService<TestService>(
33 [this](const ConnectionContext& connection_context, 33 [this](const ConnectionContext& connection_context,
34 InterfaceRequest<TestService> request) { 34 InterfaceRequest<TestService> request) {
35 new TestServiceImpl(app_impl_, this, request.Pass()); 35 new TestServiceImpl(app_impl_, this, request.Pass());
36 AddRef(); 36 AddRef();
37 }); 37 });
38 connection->GetServiceProviderImpl().AddService<TestTimeService>( 38 service_provider_impl->AddService<TestTimeService>(
39 [this](const ConnectionContext& connection_context, 39 [this](const ConnectionContext& connection_context,
40 InterfaceRequest<TestTimeService> request) { 40 InterfaceRequest<TestTimeService> request) {
41 new TestTimeServiceImpl(app_impl_, request.Pass()); 41 new TestTimeServiceImpl(app_impl_, request.Pass());
42 }); 42 });
43 return true; 43 return true;
44 } 44 }
45 45
46 void TestServiceApplication::AddRef() { 46 void TestServiceApplication::AddRef() {
47 assert(ref_count_ >= 0); 47 assert(ref_count_ >= 0);
48 ref_count_++; 48 ref_count_++;
49 } 49 }
50 50
51 void TestServiceApplication::ReleaseRef() { 51 void TestServiceApplication::ReleaseRef() {
52 assert(ref_count_ > 0); 52 assert(ref_count_ > 0);
53 ref_count_--; 53 ref_count_--;
54 if (ref_count_ <= 0) 54 if (ref_count_ <= 0)
55 RunLoop::current()->Quit(); 55 RunLoop::current()->Quit();
56 } 56 }
57 57
58 } // namespace test 58 } // namespace test
59 } // namespace mojo 59 } // namespace mojo
60 60
61 MojoResult MojoMain(MojoHandle application_request) { 61 MojoResult MojoMain(MojoHandle application_request) {
62 mojo::ApplicationRunner runner( 62 mojo::ApplicationRunner runner(
63 std::unique_ptr<mojo::test::TestServiceApplication>( 63 std::unique_ptr<mojo::test::TestServiceApplication>(
64 new mojo::test::TestServiceApplication())); 64 new mojo::test::TestServiceApplication()));
65 return runner.Run(application_request); 65 return runner.Run(application_request);
66 } 66 }
OLDNEW
« no previous file with comments | « services/test_service/test_service_application.h ('k') | services/tracing/tracing_app.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698