mirror of
https://github.com/dart-lang/sdk
synced 2024-10-06 12:35:03 +00:00
b3535bf501
R=turnidge@google.com Review URL: https://codereview.chromium.org//215893006 git-svn-id: https://dart.googlecode.com/svn/branches/bleeding_edge/dart@34749 260f80e4-7a28-3924-810f-c04153c831b5
58 lines
2.2 KiB
C++
58 lines
2.2 KiB
C++
// Copyright (c) 2011, the Dart project authors. Please see the AUTHORS file
|
|
// for details. All rights reserved. Use of this source code is governed by a
|
|
// BSD-style license that can be found in the LICENSE file.
|
|
|
|
#include "platform/globals.h"
|
|
#include "vm/timer.h"
|
|
#include "vm/json_stream.h"
|
|
|
|
namespace dart {
|
|
|
|
// Define timer command line flags.
|
|
#define DEFINE_TIMER_FLAG(name, msg) \
|
|
DEFINE_FLAG(bool, name, false, ""#name);
|
|
TIMER_LIST(DEFINE_TIMER_FLAG)
|
|
#undef DEFINE_TIMER_FLAG
|
|
DEFINE_FLAG(bool, time_all, false, "Time all functionality");
|
|
|
|
|
|
// Maintains a list of timers per isolate.
|
|
#define INIT_TIMERS(name, msg) \
|
|
name##_((FLAG_##name || FLAG_time_all), msg),
|
|
TimerList::TimerList()
|
|
: TIMER_LIST(INIT_TIMERS)
|
|
padding_(false) {
|
|
}
|
|
#undef INIT_TIMERS
|
|
|
|
|
|
#define TIMER_FIELD_REPORT(name, msg) \
|
|
if (name().report() && name().message() != NULL) { \
|
|
OS::Print("%s : %.3f ms total; %.3f ms max.\n", \
|
|
name().message(), \
|
|
MicrosecondsToMilliseconds(name().TotalElapsedTime()), \
|
|
MicrosecondsToMilliseconds(name().MaxContiguous())); \
|
|
}
|
|
void TimerList::ReportTimers() {
|
|
TIMER_LIST(TIMER_FIELD_REPORT);
|
|
}
|
|
#undef TIMER_FIELD_REPORT
|
|
|
|
|
|
#define JSON_TIMER(name, msg) \
|
|
{ \
|
|
JSONObject jsobj(&jsarr); \
|
|
jsobj.AddProperty("name", #name); \
|
|
jsobj.AddProperty("time", \
|
|
MicrosecondsToSeconds(name().TotalElapsedTime())); \
|
|
jsobj.AddProperty("max_contiguous", \
|
|
MicrosecondsToSeconds(name().MaxContiguous())); \
|
|
}
|
|
void TimerList::PrintTimersToJSONProperty(JSONObject* jsobj) {
|
|
JSONArray jsarr(jsobj, "timers");
|
|
TIMER_LIST(JSON_TIMER);
|
|
}
|
|
#undef JSON_TIMER
|
|
|
|
} // namespace dart
|