Index: content/public/browser/background_tracing_manager.h |
diff --git a/content/public/browser/background_tracing_manager.h b/content/public/browser/background_tracing_manager.h |
new file mode 100644 |
index 0000000000000000000000000000000000000000..ec064b4f2d8f8663c1ec754f977510083b770775 |
--- /dev/null |
+++ b/content/public/browser/background_tracing_manager.h |
@@ -0,0 +1,56 @@ |
+// Copyright 2015 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+#ifndef CONTENT_PUBLIC_BROWSER_BACKGROUND_TRACING_MANAGER_H_ |
+#define CONTENT_PUBLIC_BROWSER_BACKGROUND_TRACING_MANAGER_H_ |
+ |
+#include "base/trace_event/trace_event_impl.h" |
+#include "base/values.h" |
+#include "content/common/content_export.h" |
+#include "content/public/browser/background_tracing_config.h" |
no sievers
2015/05/11 21:13:27
nit: I think you can fwd-declare some of these
shatch
2015/05/12 21:00:05
Done.
|
+#include "content/public/browser/background_tracing_upload_sink.h" |
+ |
+namespace content { |
+ |
+// BackgroundTracingManager is used on the browser process to trigger the |
+// collection of trace data and upload the results. Only the browser UI thread |
+// is allowed to interact with the BackgroundTracingManager. All callbacks are |
+// called on the UI thread. |
+class BackgroundTracingManager { |
+ public: |
+ CONTENT_EXPORT static BackgroundTracingManager* GetInstance(); |
+ |
+ // Set the triggering rules for when to start recording. |
+ virtual bool SetActiveScenario( |
+ scoped_refptr<BackgroundTracingConfig> config, |
+ scoped_refptr<BackgroundTracingUploadSink> upload_sink) = 0; |
+ |
+ // Notifies the caller when the manager is idle (not recording or uploading), |
+ // so that a call to SetActiveScenario() is likely to succeed. |
+ typedef base::Callback<void()> IdleCallback; |
+ virtual void WhenIdle(IdleCallback idle_callback) = 0; |
+ |
+ typedef base::Callback<void(bool)> StartedFinalizingCallback; |
+ typedef int TriggerHandle; |
+ |
+ // Notifies that a manual trigger event has occurred, and we may need to |
+ // either begin recording or finalize the trace, depending on the config. |
+ // If the trigger specified isn't active in the config, this will do nothing. |
+ virtual void DidTriggerHappen(TriggerHandle, |
+ StartedFinalizingCallback started_callback) = 0; |
+ |
+ // Registers a manual trigger handle, and returns a TriggerHandle which can |
+ // be passed to DidTriggerHappen(). |
+ virtual TriggerHandle RegisterTriggerType(const char* trigger_name) = 0; |
+ |
+ // Returns a list of all registered triggers. |
+ virtual void GetTriggerNameList(std::vector<std::string>& trigger_names) = 0; |
+ |
+ protected: |
+ virtual ~BackgroundTracingManager() {} |
+}; |
+ |
+} // namespace content |
+ |
+#endif // CONTENT_PUBLIC_BROWSER_BACKGROUND_TRACING_MANAGER_H_ |