| 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 #ifndef NET_LOG_NET_LOG_H_ | 5 #ifndef NET_LOG_NET_LOG_H_ |
| 6 #define NET_LOG_NET_LOG_H_ | 6 #define NET_LOG_NET_LOG_H_ |
| 7 | 7 |
| 8 #include <string> | 8 #include <string> |
| 9 | 9 |
| 10 #include "build/build_config.h" | 10 #include "build/build_config.h" |
| 11 | 11 |
| 12 #include "base/atomicops.h" | 12 #include "base/atomicops.h" |
| 13 #include "base/basictypes.h" | 13 #include "base/basictypes.h" |
| 14 #include "base/callback_forward.h" | 14 #include "base/callback_forward.h" |
| 15 #include "base/compiler_specific.h" | 15 #include "base/compiler_specific.h" |
| 16 #include "base/observer_list.h" | 16 #include "base/observer_list.h" |
| 17 #include "base/strings/string16.h" | 17 #include "base/strings/string16.h" |
| 18 #include "base/synchronization/lock.h" | 18 #include "base/synchronization/lock.h" |
| 19 #include "base/time/time.h" | 19 #include "base/time/time.h" |
| 20 #include "base/values.h" |
| 20 #include "net/base/net_export.h" | 21 #include "net/base/net_export.h" |
| 21 #include "net/log/net_log_capture_mode.h" | 22 #include "net/log/net_log_capture_mode.h" |
| 22 | 23 |
| 23 namespace base { | 24 namespace base { |
| 24 class DictionaryValue; | 25 class DictionaryValue; |
| 25 class Value; | 26 class Value; |
| 26 } | 27 } |
| 27 | 28 |
| 28 namespace net { | 29 namespace net { |
| 29 | 30 |
| (...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 64 #define SOURCE_TYPE(label) SOURCE_##label, | 65 #define SOURCE_TYPE(label) SOURCE_##label, |
| 65 #include "net/log/net_log_source_type_list.h" | 66 #include "net/log/net_log_source_type_list.h" |
| 66 #undef SOURCE_TYPE | 67 #undef SOURCE_TYPE |
| 67 SOURCE_COUNT | 68 SOURCE_COUNT |
| 68 }; | 69 }; |
| 69 | 70 |
| 70 // A callback function that return a Value representation of the parameters | 71 // A callback function that return a Value representation of the parameters |
| 71 // associated with an event. If called, it will be called synchonously, | 72 // associated with an event. If called, it will be called synchonously, |
| 72 // so it need not have owning references. May be called more than once, or | 73 // so it need not have owning references. May be called more than once, or |
| 73 // not at all. May return NULL. | 74 // not at all. May return NULL. |
| 74 typedef base::Callback<base::Value*(NetLogCaptureMode)> ParametersCallback; | 75 typedef base::Callback<scoped_ptr<base::Value>(NetLogCaptureMode)> |
| 76 ParametersCallback; |
| 75 | 77 |
| 76 // Identifies the entity that generated this log. The |id| field should | 78 // Identifies the entity that generated this log. The |id| field should |
| 77 // uniquely identify the source, and is used by log observers to infer | 79 // uniquely identify the source, and is used by log observers to infer |
| 78 // message groupings. Can use NetLog::NextID() to create unique IDs. | 80 // message groupings. Can use NetLog::NextID() to create unique IDs. |
| 79 struct NET_EXPORT Source { | 81 struct NET_EXPORT Source { |
| 80 static const uint32 kInvalidId; | 82 static const uint32 kInvalidId; |
| 81 | 83 |
| 82 Source(); | 84 Source(); |
| 83 Source(SourceType type, uint32 id); | 85 Source(SourceType type, uint32 id); |
| 84 bool IsValid() const; | 86 bool IsValid() const; |
| (...skipping 39 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 124 Entry(const EntryData* data, NetLogCaptureMode capture_mode); | 126 Entry(const EntryData* data, NetLogCaptureMode capture_mode); |
| 125 ~Entry(); | 127 ~Entry(); |
| 126 | 128 |
| 127 EventType type() const { return data_->type; } | 129 EventType type() const { return data_->type; } |
| 128 Source source() const { return data_->source; } | 130 Source source() const { return data_->source; } |
| 129 EventPhase phase() const { return data_->phase; } | 131 EventPhase phase() const { return data_->phase; } |
| 130 | 132 |
| 131 // Serializes the specified event to a Value. The Value also includes the | 133 // Serializes the specified event to a Value. The Value also includes the |
| 132 // current time. Caller takes ownership of returned Value. Takes in a time | 134 // current time. Caller takes ownership of returned Value. Takes in a time |
| 133 // to allow back-dating entries. | 135 // to allow back-dating entries. |
| 134 base::Value* ToValue() const; | 136 scoped_ptr<base::Value> ToValue() const; |
| 135 | 137 |
| 136 // Returns the parameters as a Value. Returns NULL if there are no | 138 // Returns the parameters as a Value. Returns NULL if there are no |
| 137 // parameters. Caller takes ownership of returned Value. | 139 // parameters. Caller takes ownership of returned Value. |
| 138 base::Value* ParametersToValue() const; | 140 scoped_ptr<base::Value> ParametersToValue() const; |
| 139 | 141 |
| 140 private: | 142 private: |
| 141 const EntryData* const data_; | 143 const EntryData* const data_; |
| 142 | 144 |
| 143 // Log capture mode when the event occurred. | 145 // Log capture mode when the event occurred. |
| 144 const NetLogCaptureMode capture_mode_; | 146 const NetLogCaptureMode capture_mode_; |
| 145 | 147 |
| 146 // It is not safe to copy this class, since |parameters_callback_| may | 148 // It is not safe to copy this class, since |parameters_callback_| may |
| 147 // include pointers that become stale immediately after the event is added, | 149 // include pointers that become stale immediately after the event is added, |
| 148 // even if the code were modified to keep its own copy of the callback. | 150 // even if the code were modified to keep its own copy of the callback. |
| (...skipping 239 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 388 NetLog::Source source_; | 390 NetLog::Source source_; |
| 389 NetLog* net_log_; | 391 NetLog* net_log_; |
| 390 | 392 |
| 391 // TODO(eroman): Temporary until crbug.com/467797 is solved. | 393 // TODO(eroman): Temporary until crbug.com/467797 is solved. |
| 392 Liveness liveness_ = ALIVE; | 394 Liveness liveness_ = ALIVE; |
| 393 }; | 395 }; |
| 394 | 396 |
| 395 } // namespace net | 397 } // namespace net |
| 396 | 398 |
| 397 #endif // NET_LOG_NET_LOG_H_ | 399 #endif // NET_LOG_NET_LOG_H_ |
| OLD | NEW |