Instrumenting context getter and predictor to find jank.
[chromium-blink-merge.git] / chromeos / device_event_log.cc
bloba5486477ae5e2b01964560dc399dbf9b2a9fb37a
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.
5 #include "chromeos/device_event_log.h"
7 #include <string>
9 #include "base/logging.h"
10 #include "chromeos/device_event_log_impl.h"
12 namespace chromeos {
14 namespace device_event_log {
16 namespace {
18 const size_t kDefaultMaxEntries = 4000;
20 DeviceEventLogImpl* g_device_event_log = NULL;
22 } // namespace
24 const LogLevel kDefaultLogLevel = LOG_LEVEL_EVENT;
26 void Initialize(size_t max_entries) {
27 CHECK(!g_device_event_log);
28 if (max_entries == 0)
29 max_entries = kDefaultMaxEntries;
30 g_device_event_log = new DeviceEventLogImpl(max_entries);
33 void Shutdown() {
34 delete g_device_event_log;
35 g_device_event_log = NULL;
38 void AddEntry(const char* file,
39 int line,
40 LogType type,
41 LogLevel level,
42 const std::string& event) {
43 if (g_device_event_log) {
44 g_device_event_log->AddEntry(file, line, type, level, event);
45 } else {
46 DeviceEventLogImpl::SendToVLogOrErrorLog(file, line, type, level, event);
50 void AddEntryWithDescription(const char* file,
51 int line,
52 LogType type,
53 LogLevel level,
54 const std::string& event,
55 const std::string& desc) {
56 std::string event_with_desc = event;
57 if (!desc.empty())
58 event_with_desc += ": " + desc;
59 AddEntry(file, line, type, level, event_with_desc);
62 std::string GetAsString(StringOrder order,
63 const std::string& format,
64 LogType log_type,
65 LogLevel max_level,
66 size_t max_events) {
67 if (!g_device_event_log)
68 return "DeviceEventLog not initialized.";
69 return g_device_event_log->GetAsString(order, format, log_type, max_level,
70 max_events);
73 namespace internal {
75 DeviceEventLogInstance::DeviceEventLogInstance(const char* file,
76 int line,
77 device_event_log::LogType type,
78 device_event_log::LogLevel level)
79 : file_(file), line_(line), type_(type), level_(level) {
82 DeviceEventLogInstance::~DeviceEventLogInstance() {
83 device_event_log::AddEntry(file_, line_, type_, level_, stream_.str());
86 } // namespace internal
88 } // namespace device_event_log
90 } // namespace chromeos