summaryrefslogtreecommitdiffstats
path: root/base/trace_event.h
diff options
context:
space:
mode:
authorerikkay@google.com <erikkay@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-09-18 20:42:55 +0000
committererikkay@google.com <erikkay@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-09-18 20:42:55 +0000
commit113ab13f317a212284c022771438705c6cba6227 (patch)
tree7c92495aa899a2cdf20be7819ef69b3d06a42533 /base/trace_event.h
parent37cbdcc9964ad7b3af8a5420fdbaebe67d11a60c (diff)
downloadchromium_src-113ab13f317a212284c022771438705c6cba6227.zip
chromium_src-113ab13f317a212284c022771438705c6cba6227.tar.gz
chromium_src-113ab13f317a212284c022771438705c6cba6227.tar.bz2
* Change output of trace_event log to JSON to enable easier integration with visualization UI.
* Simple (manual) trace visualizer with some sample data. * a few more trace events * add process_util function for current process handle Review URL: http://codereview.chromium.org/3086 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@2381 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'base/trace_event.h')
-rw-r--r--base/trace_event.h19
1 files changed, 14 insertions, 5 deletions
diff --git a/base/trace_event.h b/base/trace_event.h
index b01a71e..932c784 100644
--- a/base/trace_event.h
+++ b/base/trace_event.h
@@ -24,8 +24,10 @@
#include <string>
#include "base/lock.h"
+#include "base/scoped_ptr.h"
#include "base/singleton.h"
#include "base/time.h"
+#include "base/timer.h"
// Use the following macros rather than using the TraceLog class directly as the
// underlying implementation may change in the future. Here's a sample usage:
@@ -40,7 +42,7 @@
#define TRACE_EVENT_BEGIN(name, id, extra) \
Singleton<base::TraceLog>::get()->Trace(name, \
base::TraceLog::EVENT_BEGIN, \
- reinterpret_cast<void*>(id), \
+ reinterpret_cast<const void*>(id), \
extra, \
__FILE__, \
__LINE__)
@@ -50,7 +52,7 @@
#define TRACE_EVENT_END(name, id, extra) \
Singleton<base::TraceLog>::get()->Trace(name, \
base::TraceLog::EVENT_END, \
- reinterpret_cast<void*>(id), \
+ reinterpret_cast<const void*>(id), \
extra, \
__FILE__, \
__LINE__)
@@ -59,7 +61,7 @@
#define TRACE_EVENT_INSTANT(name, id, extra) \
Singleton<base::TraceLog>::get()->Trace(name, \
base::TraceLog::EVENT_INSTANT, \
- reinterpret_cast<void*>(id), \
+ reinterpret_cast<const void*>(id), \
extra, \
__FILE__, \
__LINE__)
@@ -77,6 +79,10 @@ typedef HANDLE FileHandle;
typedef FILE* FileHandle;
#endif
+namespace process_util {
+class ProcessMetrics;
+}
+
namespace base {
class TraceLog {
@@ -97,13 +103,13 @@ class TraceLog {
// Log a trace event of (name, type, id) with the optional extra string.
void Trace(const std::string& name,
EventType type,
- void* id,
+ const void* id,
const std::wstring& extra,
const char* file,
int line);
void Trace(const std::string& name,
EventType type,
- void* id,
+ const void* id,
const std::string& extra,
const char* file,
int line);
@@ -119,12 +125,15 @@ class TraceLog {
void CloseLogFile();
bool Start();
void Stop();
+ void Heartbeat();
void Log(const std::string& msg);
bool enabled_;
FileHandle log_file_;
Lock file_lock_;
TimeTicks trace_start_time_;
+ scoped_ptr<process_util::ProcessMetrics> process_metrics_;
+ RepeatingTimer<TraceLog> timer_;
};
} // namespace base