Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(75)

Side by Side Diff: net/base/capturing_net_log.cc

Issue 4118004: Update NetLog to be thread safe. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src/
Patch Set: Final sync with trunk Created 10 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « net/base/capturing_net_log.h ('k') | net/base/forwarding_net_log.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright (c) 2010 The Chromium Authors. All rights reserved. 1 // Copyright (c) 2010 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 "net/base/capturing_net_log.h" 5 #include "net/base/capturing_net_log.h"
6 6
7 namespace net { 7 namespace net {
8 8
9 CapturingNetLog::Entry::Entry(EventType type, 9 CapturingNetLog::Entry::Entry(EventType type,
10 const base::TimeTicks& time, 10 const base::TimeTicks& time,
11 Source source, 11 Source source,
12 EventPhase phase, 12 EventPhase phase,
13 EventParameters* extra_parameters) 13 EventParameters* extra_parameters)
14 : type(type), time(time), source(source), phase(phase), 14 : type(type), time(time), source(source), phase(phase),
15 extra_parameters(extra_parameters) { 15 extra_parameters(extra_parameters) {
16 } 16 }
17 17
18 CapturingNetLog::Entry::~Entry() {} 18 CapturingNetLog::Entry::~Entry() {}
19 19
20 CapturingNetLog::CapturingNetLog(size_t max_num_entries) 20 CapturingNetLog::CapturingNetLog(size_t max_num_entries)
21 : next_id_(0), max_num_entries_(max_num_entries) { 21 : last_id_(-1), max_num_entries_(max_num_entries) {
22 } 22 }
23 23
24 CapturingNetLog::~CapturingNetLog() {} 24 CapturingNetLog::~CapturingNetLog() {}
25 25
26 void CapturingNetLog::AddEntry(EventType type, 26 void CapturingNetLog::AddEntry(EventType type,
27 const base::TimeTicks& time, 27 const base::TimeTicks& time,
28 const Source& source, 28 const Source& source,
29 EventPhase phase, 29 EventPhase phase,
30 EventParameters* extra_parameters) { 30 EventParameters* extra_parameters) {
31 AutoLock lock(lock_);
31 Entry entry(type, time, source, phase, extra_parameters); 32 Entry entry(type, time, source, phase, extra_parameters);
32 if (entries_.size() + 1 < max_num_entries_) 33 if (entries_.size() + 1 < max_num_entries_)
33 entries_.push_back(entry); 34 entries_.push_back(entry);
34 } 35 }
35 36
36 uint32 CapturingNetLog::NextID() { 37 uint32 CapturingNetLog::NextID() {
37 return next_id_++; 38 return base::subtle::NoBarrier_AtomicIncrement(&last_id_, 1);
39 }
40
41 void CapturingNetLog::GetEntries(EntryList* entry_list) const {
42 AutoLock lock(lock_);
43 *entry_list = entries_;
38 } 44 }
39 45
40 void CapturingNetLog::Clear() { 46 void CapturingNetLog::Clear() {
47 AutoLock lock(lock_);
41 entries_.clear(); 48 entries_.clear();
42 } 49 }
43 50
44 CapturingBoundNetLog::CapturingBoundNetLog(const NetLog::Source& source, 51 CapturingBoundNetLog::CapturingBoundNetLog(const NetLog::Source& source,
45 CapturingNetLog* net_log) 52 CapturingNetLog* net_log)
46 : source_(source), capturing_net_log_(net_log) { 53 : source_(source), capturing_net_log_(net_log) {
47 } 54 }
48 55
49 CapturingBoundNetLog::CapturingBoundNetLog(size_t max_num_entries) 56 CapturingBoundNetLog::CapturingBoundNetLog(size_t max_num_entries)
50 : capturing_net_log_(new CapturingNetLog(max_num_entries)) {} 57 : capturing_net_log_(new CapturingNetLog(max_num_entries)) {}
51 58
52 CapturingBoundNetLog::~CapturingBoundNetLog() {} 59 CapturingBoundNetLog::~CapturingBoundNetLog() {}
53 60
61 void CapturingBoundNetLog::GetEntries(
62 CapturingNetLog::EntryList* entry_list) const {
63 capturing_net_log_->GetEntries(entry_list);
64 }
65
54 void CapturingBoundNetLog::Clear() { 66 void CapturingBoundNetLog::Clear() {
55 capturing_net_log_->Clear(); 67 capturing_net_log_->Clear();
56 } 68 }
57 69
58 void CapturingBoundNetLog::AppendTo(const BoundNetLog& net_log) const {
59 for (size_t i = 0; i < entries().size(); ++i) {
60 const CapturingNetLog::Entry& entry = entries()[i];
61 net_log.AddEntryWithTime(entry.type, entry.time, entry.phase,
62 entry.extra_parameters);
63 }
64 }
65
66 } // namespace net 70 } // namespace net
OLDNEW
« no previous file with comments | « net/base/capturing_net_log.h ('k') | net/base/forwarding_net_log.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698