| OLD | NEW |
| 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 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 #include "base/debug/trace_event_impl.h" | 5 #include "base/debug/trace_event_impl.h" |
| 6 | 6 |
| 7 #include <algorithm> | 7 #include <algorithm> |
| 8 | 8 |
| 9 #include "base/bind.h" | 9 #include "base/bind.h" |
| 10 #include "base/debug/leak_annotations.h" | 10 #include "base/debug/leak_annotations.h" |
| (...skipping 1030 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1041 | 1041 |
| 1042 void TraceLog::RemoveEnabledStateObserver(EnabledStateObserver* listener) { | 1042 void TraceLog::RemoveEnabledStateObserver(EnabledStateObserver* listener) { |
| 1043 std::vector<EnabledStateObserver*>::iterator it = | 1043 std::vector<EnabledStateObserver*>::iterator it = |
| 1044 std::find(enabled_state_observer_list_.begin(), | 1044 std::find(enabled_state_observer_list_.begin(), |
| 1045 enabled_state_observer_list_.end(), | 1045 enabled_state_observer_list_.end(), |
| 1046 listener); | 1046 listener); |
| 1047 if (it != enabled_state_observer_list_.end()) | 1047 if (it != enabled_state_observer_list_.end()) |
| 1048 enabled_state_observer_list_.erase(it); | 1048 enabled_state_observer_list_.erase(it); |
| 1049 } | 1049 } |
| 1050 | 1050 |
| 1051 bool TraceLog::HasEnabledStateObserver(EnabledStateObserver* listener) const { |
| 1052 std::vector<EnabledStateObserver*>::const_iterator it = |
| 1053 std::find(enabled_state_observer_list_.begin(), |
| 1054 enabled_state_observer_list_.end(), |
| 1055 listener); |
| 1056 return it != enabled_state_observer_list_.end(); |
| 1057 } |
| 1058 |
| 1051 float TraceLog::GetBufferPercentFull() const { | 1059 float TraceLog::GetBufferPercentFull() const { |
| 1052 return (float)((double)logged_events_->Size()/(double)kTraceEventBufferSize); | 1060 return (float)((double)logged_events_->Size()/(double)kTraceEventBufferSize); |
| 1053 } | 1061 } |
| 1054 | 1062 |
| 1055 void TraceLog::SetNotificationCallback( | 1063 void TraceLog::SetNotificationCallback( |
| 1056 const TraceLog::NotificationCallback& cb) { | 1064 const TraceLog::NotificationCallback& cb) { |
| 1057 AutoLock lock(lock_); | 1065 AutoLock lock(lock_); |
| 1058 notification_callback_ = cb; | 1066 notification_callback_ = cb; |
| 1059 } | 1067 } |
| 1060 | 1068 |
| 1061 TraceBuffer* TraceLog::GetTraceBuffer() { | 1069 TraceBuffer* TraceLog::GetTraceBuffer() { |
| 1062 if (trace_options_ & RECORD_CONTINUOUSLY) | 1070 if (trace_options_ & RECORD_CONTINUOUSLY) |
| 1063 return new TraceBufferRingBuffer(); | 1071 return new TraceBufferRingBuffer(); |
| 1064 else if (trace_options_ & ECHO_TO_VLOG) | 1072 else if (trace_options_ & ECHO_TO_VLOG) |
| 1065 return new TraceBufferDiscardsEvents(); | 1073 return new TraceBufferDiscardsEvents(); |
| 1066 return new TraceBufferVector(); | 1074 return new TraceBufferVector(); |
| 1067 } | 1075 } |
| 1068 | 1076 |
| 1069 void TraceLog::SetEventCallback(EventCallback cb) { | 1077 void TraceLog::SetEventCallback(EventCallback cb) { |
| 1070 AutoLock lock(lock_); | 1078 AutoLock lock(lock_); |
| 1071 event_callback_ = cb; | 1079 event_callback_ = cb; |
| 1072 }; | 1080 }; |
| 1073 | 1081 |
| 1074 void TraceLog::Flush(const TraceLog::OutputCallback& cb) { | 1082 void TraceLog::Flush(const TraceLog::OutputCallback& cb) { |
| 1083 // Ignore memory allocations from here down. |
| 1084 TRACE_MEMORY(TRACE_DISABLED_BY_DEFAULT("memory"), TRACE_MEMORY_IGNORE); |
| 1075 scoped_ptr<TraceBuffer> previous_logged_events; | 1085 scoped_ptr<TraceBuffer> previous_logged_events; |
| 1076 { | 1086 { |
| 1077 AutoLock lock(lock_); | 1087 AutoLock lock(lock_); |
| 1078 previous_logged_events.swap(logged_events_); | 1088 previous_logged_events.swap(logged_events_); |
| 1079 logged_events_.reset(GetTraceBuffer()); | 1089 logged_events_.reset(GetTraceBuffer()); |
| 1080 } // release lock | 1090 } // release lock |
| 1081 | 1091 |
| 1082 while (previous_logged_events->HasMoreEvents()) { | 1092 while (previous_logged_events->HasMoreEvents()) { |
| 1083 scoped_refptr<RefCountedString> json_events_str_ptr = | 1093 scoped_refptr<RefCountedString> json_events_str_ptr = |
| 1084 new RefCountedString(); | 1094 new RefCountedString(); |
| (...skipping 461 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1546 0, // num_args | 1556 0, // num_args |
| 1547 NULL, // arg_names | 1557 NULL, // arg_names |
| 1548 NULL, // arg_types | 1558 NULL, // arg_types |
| 1549 NULL, // arg_values | 1559 NULL, // arg_values |
| 1550 NULL, // convertable values | 1560 NULL, // convertable values |
| 1551 TRACE_EVENT_FLAG_NONE); // flags | 1561 TRACE_EVENT_FLAG_NONE); // flags |
| 1552 } | 1562 } |
| 1553 } | 1563 } |
| 1554 | 1564 |
| 1555 } // namespace trace_event_internal | 1565 } // namespace trace_event_internal |
| OLD | NEW |