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

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

Issue 1980763002: ApplicationConnection devolution, part 2.3. (Closed) Base URL: https://github.com/domokit/mojo.git@work794_app_conn_devo_2.2
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 11 matching lines...) Expand all
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 ApplicationConnection* connection) {
32 connection->AddService<TestService>(this); 32 connection->GetServiceProviderImpl().AddService<TestService>(
33 connection->AddService<TestTimeService>(this); 33 [this](const ConnectionContext& connection_context,
34 InterfaceRequest<TestService> request) {
35 new TestServiceImpl(app_impl_, this, request.Pass());
36 AddRef();
37 });
38 connection->GetServiceProviderImpl().AddService<TestTimeService>(
39 [this](const ConnectionContext& connection_context,
40 InterfaceRequest<TestTimeService> request) {
41 new TestTimeServiceImpl(app_impl_, request.Pass());
42 });
34 return true; 43 return true;
35 } 44 }
36 45
37 void TestServiceApplication::Create(const ConnectionContext& connection_context,
38 InterfaceRequest<TestService> request) {
39 new TestServiceImpl(app_impl_, this, request.Pass());
40 AddRef();
41 }
42
43 void TestServiceApplication::Create(const ConnectionContext& connection_context,
44 InterfaceRequest<TestTimeService> request) {
45 new TestTimeServiceImpl(app_impl_, request.Pass());
46 }
47
48 void TestServiceApplication::AddRef() { 46 void TestServiceApplication::AddRef() {
49 assert(ref_count_ >= 0); 47 assert(ref_count_ >= 0);
50 ref_count_++; 48 ref_count_++;
51 } 49 }
52 50
53 void TestServiceApplication::ReleaseRef() { 51 void TestServiceApplication::ReleaseRef() {
54 assert(ref_count_ > 0); 52 assert(ref_count_ > 0);
55 ref_count_--; 53 ref_count_--;
56 if (ref_count_ <= 0) 54 if (ref_count_ <= 0)
57 RunLoop::current()->Quit(); 55 RunLoop::current()->Quit();
58 } 56 }
59 57
60 } // namespace test 58 } // namespace test
61 } // namespace mojo 59 } // namespace mojo
62 60
63 MojoResult MojoMain(MojoHandle application_request) { 61 MojoResult MojoMain(MojoHandle application_request) {
64 mojo::ApplicationRunner runner( 62 mojo::ApplicationRunner runner(
65 std::unique_ptr<mojo::test::TestServiceApplication>( 63 std::unique_ptr<mojo::test::TestServiceApplication>(
66 new mojo::test::TestServiceApplication())); 64 new mojo::test::TestServiceApplication()));
67 return runner.Run(application_request); 65 return runner.Run(application_request);
68 } 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