| OLD | NEW |
| (Empty) |
| 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 | |
| 3 // found in the LICENSE file. | |
| 4 | |
| 5 [DartPackage="mojo_services"] | |
| 6 module tracing; | |
| 7 | |
| 8 // To participate in the tracing ecosystem, implement the TraceProvider | |
| 9 // interface and connect to the tracing app. Then, when the provider's Start() | |
| 10 // function is called collect tracing data and pass it back via the provided | |
| 11 // TraceRecorder interface up until Stop() is called. | |
| 12 | |
| 13 interface TraceProvider { | |
| 14 // Categories can either be the empty string to mean the default set of | |
| 15 // categories or a comma-delimited list of categories to trace. | |
| 16 StartTracing(string categories, TraceRecorder recorder); | |
| 17 StopTracing(); | |
| 18 }; | |
| 19 | |
| 20 interface TraceRecorder { | |
| 21 Record(string json); | |
| 22 }; | |
| 23 | |
| 24 interface TraceCollector { | |
| 25 // Request tracing data from all connected providers to stream to | |
| 26 // |stream|. | |
| 27 Start(handle<data_pipe_producer> stream, string categories); | |
| 28 | |
| 29 // Stop tracing and flush results to the |stream| passed in to Start(). | |
| 30 // Closes |stream| when all data is collected. | |
| 31 StopAndFlush(); | |
| 32 }; | |
| OLD | NEW |