OLD | NEW |
1 // Copyright 2015 The Chromium Authors. All rights reserved. | 1 // Copyright 2015 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/tracing/tracing_app.h" | 5 #include "services/tracing/tracing_app.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/logging.h" | 8 #include "base/logging.h" |
9 #include "base/message_loop/message_loop.h" | 9 #include "base/message_loop/message_loop.h" |
10 #include "mojo/public/cpp/system/wait.h" | 10 #include "mojo/public/cpp/system/wait.h" |
11 | 11 |
12 namespace tracing { | 12 namespace tracing { |
13 | 13 |
14 TracingApp::TracingApp() : collector_binding_(this), tracing_active_(false) {} | 14 TracingApp::TracingApp() : collector_binding_(this), tracing_active_(false) {} |
15 | 15 |
16 TracingApp::~TracingApp() {} | 16 TracingApp::~TracingApp() {} |
17 | 17 |
18 bool TracingApp::ConfigureIncomingConnection( | 18 bool TracingApp::ConfigureIncomingConnection( |
19 mojo::ApplicationConnection* connection) { | 19 mojo::ServiceProviderImpl* service_provider_impl) { |
20 connection->GetServiceProviderImpl().AddService<TraceCollector>( | 20 service_provider_impl->AddService<TraceCollector>( |
21 [this](const mojo::ConnectionContext& connection_context, | 21 [this](const mojo::ConnectionContext& connection_context, |
22 mojo::InterfaceRequest<TraceCollector> trace_collector_request) { | 22 mojo::InterfaceRequest<TraceCollector> trace_collector_request) { |
23 if (collector_binding_.is_bound()) { | 23 if (collector_binding_.is_bound()) { |
24 LOG(ERROR) << "Another application is already connected to tracing."; | 24 LOG(ERROR) << "Another application is already connected to tracing."; |
25 return; | 25 return; |
26 } | 26 } |
27 | 27 |
28 collector_binding_.Bind(trace_collector_request.Pass()); | 28 collector_binding_.Bind(trace_collector_request.Pass()); |
29 }); | 29 }); |
30 connection->GetServiceProviderImpl().AddService<TraceProviderRegistry>( | 30 service_provider_impl->AddService<TraceProviderRegistry>( |
31 [this](const mojo::ConnectionContext& connection_context, | 31 [this](const mojo::ConnectionContext& connection_context, |
32 mojo::InterfaceRequest<TraceProviderRegistry> | 32 mojo::InterfaceRequest<TraceProviderRegistry> |
33 trace_provider_registry_request) { | 33 trace_provider_registry_request) { |
34 provider_registry_bindings_.AddBinding( | 34 provider_registry_bindings_.AddBinding( |
35 this, trace_provider_registry_request.Pass()); | 35 this, trace_provider_registry_request.Pass()); |
36 }); | 36 }); |
37 return true; | 37 return true; |
38 } | 38 } |
39 | 39 |
40 void TracingApp::Start(mojo::ScopedDataPipeProducerHandle stream, | 40 void TracingApp::Start(mojo::ScopedDataPipeProducerHandle stream, |
(...skipping 85 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
126 } | 126 } |
127 provider_ptrs_.AddInterfacePtr(provider_ptr.Pass()); | 127 provider_ptrs_.AddInterfacePtr(provider_ptr.Pass()); |
128 } | 128 } |
129 | 129 |
130 void TracingApp::AllDataCollected() { | 130 void TracingApp::AllDataCollected() { |
131 recorder_impls_.clear(); | 131 recorder_impls_.clear(); |
132 sink_.reset(); | 132 sink_.reset(); |
133 } | 133 } |
134 | 134 |
135 } // namespace tracing | 135 } // namespace tracing |
OLD | NEW |