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

Side by Side Diff: content/browser/devtools/protocol/tracing_handler.h

Issue 1307073002: DevTools: provide an option to return traces as streams (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: work around MSVC compiler error due to missing Client definition Created 5 years, 3 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 #ifndef CONTENT_BROWSER_DEVTOOLS_PROTOCOL_TRACING_HANDLER_H_ 5 #ifndef CONTENT_BROWSER_DEVTOOLS_PROTOCOL_TRACING_HANDLER_H_
6 #define CONTENT_BROWSER_DEVTOOLS_PROTOCOL_TRACING_HANDLER_H_ 6 #define CONTENT_BROWSER_DEVTOOLS_PROTOCOL_TRACING_HANDLER_H_
7 7
8 #include <set> 8 #include <set>
9 #include <string> 9 #include <string>
10 10
11 #include "base/memory/weak_ptr.h" 11 #include "base/memory/weak_ptr.h"
12 #include "base/trace_event/trace_event.h" 12 #include "base/trace_event/trace_event.h"
13 #include "content/browser/devtools/protocol/devtools_protocol_dispatcher.h" 13 #include "content/browser/devtools/protocol/devtools_protocol_dispatcher.h"
14 #include "content/public/browser/tracing_controller.h" 14 #include "content/public/browser/tracing_controller.h"
15 15
16 namespace base { 16 namespace base {
17 class RefCountedString; 17 class RefCountedString;
18 class Timer; 18 class Timer;
19 } 19 }
20 20
21 namespace content { 21 namespace content {
22 namespace devtools { 22 namespace devtools {
23
24 class DevToolsIOContext;
25
23 namespace tracing { 26 namespace tracing {
24 27
25 class TracingHandler { 28 class TracingHandler {
26 public: 29 public:
27 typedef DevToolsProtocolClient::Response Response; 30 typedef DevToolsProtocolClient::Response Response;
28 31
29 enum Target { Browser, Renderer }; 32 enum Target { Browser, Renderer };
30 explicit TracingHandler(Target target); 33 TracingHandler(Target target, DevToolsIOContext* io_context);
31 virtual ~TracingHandler(); 34 virtual ~TracingHandler();
32 35
33 void SetClient(scoped_ptr<Client> client); 36 void SetClient(scoped_ptr<Client> client);
34 void Detached(); 37 void Detached();
35 38
36 void OnTraceDataCollected(const std::string& trace_fragment); 39 void OnTraceDataCollected(const std::string& trace_fragment);
37 void OnTraceComplete(); 40 void OnTraceComplete();
41 void OnTraceToStreamComplete(const std::string& stream_handle);
38 42
43 // Protocol methods.
39 Response Start(DevToolsCommandId command_id, 44 Response Start(DevToolsCommandId command_id,
40 const std::string* categories, 45 const std::string* categories,
41 const std::string* options, 46 const std::string* options,
42 const double* buffer_usage_reporting_interval); 47 const double* buffer_usage_reporting_interval);
48 Response Start(DevToolsCommandId command_id,
49 const std::string* categories,
50 const std::string* options,
51 const double* buffer_usage_reporting_interval,
52 const std::string* transfer_mode);
43 Response End(DevToolsCommandId command_id); 53 Response End(DevToolsCommandId command_id);
44 Response GetCategories(DevToolsCommandId command); 54 Response GetCategories(DevToolsCommandId command);
45 Response RequestMemoryDump(DevToolsCommandId command_id); 55 Response RequestMemoryDump(DevToolsCommandId command_id);
56
46 bool did_initiate_recording() { return did_initiate_recording_; } 57 bool did_initiate_recording() { return did_initiate_recording_; }
47 58
48 private: 59 private:
49 void OnRecordingEnabled(DevToolsCommandId command_id); 60 void OnRecordingEnabled(DevToolsCommandId command_id);
50 void OnBufferUsage(float percent_full, size_t approximate_event_count); 61 void OnBufferUsage(float percent_full, size_t approximate_event_count);
51 62
52 void OnCategoriesReceived(DevToolsCommandId command_id, 63 void OnCategoriesReceived(DevToolsCommandId command_id,
53 const std::set<std::string>& category_set); 64 const std::set<std::string>& category_set);
54 void OnMemoryDumpFinished(DevToolsCommandId command_id, 65 void OnMemoryDumpFinished(DevToolsCommandId command_id,
55 uint64 dump_guid, 66 uint64 dump_guid,
56 bool success); 67 bool success);
57 68
58 void SetupTimer(double usage_reporting_interval); 69 void SetupTimer(double usage_reporting_interval);
59 70
60 void DisableRecording(bool abort); 71 void DisableRecording(
72 const scoped_refptr<TracingController::TraceDataSink>& trace_data_sink);
61 73
62 bool IsRecording() const; 74 bool IsRecording() const;
63 75
64 scoped_ptr<base::Timer> buffer_usage_poll_timer_; 76 scoped_ptr<base::Timer> buffer_usage_poll_timer_;
65 Target target_; 77 Target target_;
66 78
67 scoped_ptr<Client> client_; 79 scoped_ptr<Client> client_;
80 DevToolsIOContext* io_context_;
68 bool did_initiate_recording_; 81 bool did_initiate_recording_;
69 base::WeakPtrFactory<TracingHandler> weak_factory_; 82 base::WeakPtrFactory<TracingHandler> weak_factory_;
70 83
71 DISALLOW_COPY_AND_ASSIGN(TracingHandler); 84 DISALLOW_COPY_AND_ASSIGN(TracingHandler);
72 }; 85 };
73 86
74 } // namespace tracing 87 } // namespace tracing
75 } // namespace devtools 88 } // namespace devtools
76 } // namespace content 89 } // namespace content
77 90
78 #endif // CONTENT_BROWSER_DEVTOOLS_PROTOCOL_TRACING_HANDLER_H_ 91 #endif // CONTENT_BROWSER_DEVTOOLS_PROTOCOL_TRACING_HANDLER_H_
OLDNEW
« no previous file with comments | « content/browser/devtools/protocol/io_handler.cc ('k') | content/browser/devtools/protocol/tracing_handler.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698