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

Side by Side Diff: services/test_service/test_request_tracker_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
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_request_tracker_application.h" 5 #include "services/test_service/test_request_tracker_application.h"
6 6
7 #include <memory> 7 #include <memory>
8 8
9 #include "mojo/public/c/system/main.h" 9 #include "mojo/public/c/system/main.h"
10 #include "mojo/public/cpp/application/application_connection.h" 10 #include "mojo/public/cpp/application/application_connection.h"
11 #include "mojo/public/cpp/application/application_runner.h" 11 #include "mojo/public/cpp/application/application_runner.h"
12 #include "services/test_service/test_time_service_impl.h" 12 #include "services/test_service/test_time_service_impl.h"
13 13
14 namespace mojo { 14 namespace mojo {
15 namespace test { 15 namespace test {
16 16
17 TestRequestTrackerApplication::TestRequestTrackerApplication() 17 TestRequestTrackerApplication::TestRequestTrackerApplication()
18 : app_impl_(nullptr) { 18 : app_impl_(nullptr) {
19 } 19 }
20 20
21 TestRequestTrackerApplication::~TestRequestTrackerApplication() { 21 TestRequestTrackerApplication::~TestRequestTrackerApplication() {
22 } 22 }
23 23
24 void TestRequestTrackerApplication::Initialize(ApplicationImpl* app) { 24 void TestRequestTrackerApplication::Initialize(ApplicationImpl* app) {
25 app_impl_ = app; 25 app_impl_ = app;
26 } 26 }
27 27
28 bool TestRequestTrackerApplication::ConfigureIncomingConnection( 28 bool TestRequestTrackerApplication::ConfigureIncomingConnection(
29 ApplicationConnection* connection) { 29 ServiceProviderImpl* service_provider_impl) {
30 // Every instance of the service and recorder shares the context. 30 // Every instance of the service and recorder shares the context.
31 // Note, this app is single-threaded, so this is thread safe. 31 // Note, this app is single-threaded, so this is thread safe.
32 connection->GetServiceProviderImpl().AddService<TestTimeService>( 32 service_provider_impl->AddService<TestTimeService>(
33 [this](const ConnectionContext& connection_context, 33 [this](const ConnectionContext& connection_context,
34 InterfaceRequest<TestTimeService> request) { 34 InterfaceRequest<TestTimeService> request) {
35 new TestTimeServiceImpl(app_impl_, request.Pass()); 35 new TestTimeServiceImpl(app_impl_, request.Pass());
36 }); 36 });
37 connection->GetServiceProviderImpl().AddService<TestRequestTracker>( 37 service_provider_impl->AddService<TestRequestTracker>(
38 [this](const ConnectionContext& connection_context, 38 [this](const ConnectionContext& connection_context,
39 InterfaceRequest<TestRequestTracker> request) { 39 InterfaceRequest<TestRequestTracker> request) {
40 new TestRequestTrackerImpl(request.Pass(), &context_); 40 new TestRequestTrackerImpl(request.Pass(), &context_);
41 }); 41 });
42 connection->GetServiceProviderImpl().AddService<TestTrackedRequestService>( 42 service_provider_impl->AddService<TestTrackedRequestService>(
43 [this](const ConnectionContext& connection_context, 43 [this](const ConnectionContext& connection_context,
44 InterfaceRequest<TestTrackedRequestService> request) { 44 InterfaceRequest<TestTrackedRequestService> request) {
45 new TestTrackedRequestServiceImpl(request.Pass(), &context_); 45 new TestTrackedRequestServiceImpl(request.Pass(), &context_);
46 }); 46 });
47 return true; 47 return true;
48 } 48 }
49 49
50 } // namespace test 50 } // namespace test
51 } // namespace mojo 51 } // namespace mojo
52 52
53 MojoResult MojoMain(MojoHandle application_request) { 53 MojoResult MojoMain(MojoHandle application_request) {
54 mojo::ApplicationRunner runner( 54 mojo::ApplicationRunner runner(
55 std::unique_ptr<mojo::test::TestRequestTrackerApplication>( 55 std::unique_ptr<mojo::test::TestRequestTrackerApplication>(
56 new mojo::test::TestRequestTrackerApplication())); 56 new mojo::test::TestRequestTrackerApplication()));
57 return runner.Run(application_request); 57 return runner.Run(application_request);
58 } 58 }
OLDNEW
« no previous file with comments | « services/test_service/test_request_tracker_application.h ('k') | services/test_service/test_service_application.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698