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

Side by Side Diff: base/threading/thread_id_name_manager.cc

Issue 11438022: Add ability to retrieve a thread_name given a thread_id. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: API and various other cleanups based on review feedback. Created 7 years, 11 months 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
OLDNEW
(Empty)
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
3 // found in the LICENSE file.
4
5 #include "base/threading/thread_id_name_manager.h"
6
7 #include <stdlib.h>
8 #include <string.h>
9
10 #include "base/logging.h"
11 #include "base/memory/singleton.h"
12 #include "base/string_util.h"
13
14 namespace base {
15 namespace {
16
17 const char* kDefaultName("");
18
19 typedef std::map<PlatformThreadId, std::string>::iterator
20 IdToInternedNameIterator;
21 typedef std::map<std::string, std::string>::iterator NameToInternedNameIterator;
22 }
23
24 ThreadIdNameManager::ThreadIdNameManager() {
25 name_to_interned_name_[kDefaultName] = kDefaultName;
26 }
27
28 ThreadIdNameManager::~ThreadIdNameManager() {
29 }
30
31 ThreadIdNameManager* ThreadIdNameManager::GetInstance() {
32 return Singleton<ThreadIdNameManager,
33 LeakySingletonTraits<ThreadIdNameManager> >::get();
34 }
35
36 const char* ThreadIdNameManager::GetDefaultInternedString() {
37 return kDefaultName;
38 }
39
40 void ThreadIdNameManager::SetNameForId(PlatformThreadId id, const char* name) {
41 std::string str_name(name);
42
43 AutoLock locked(lock_);
44 NameToInternedNameIterator iter = name_to_interned_name_.find(str_name);
45 if (iter == name_to_interned_name_.end())
46 name_to_interned_name_[str_name] = str_name;
jar (doing other things) 2013/01/24 01:05:14 I'm a little confused now, as you set values into
dsinclair 2013/01/24 15:13:06 Bug, I should have used iter->second in the assign
47
48 id_to_interned_name_[id] = str_name;
jar (doing other things) 2013/01/24 01:05:14 nit: suggest thread_id_to_interned_name I was con
dsinclair 2013/01/24 15:13:06 Done.
49 }
50
51 const char* ThreadIdNameManager::GetNameForId(PlatformThreadId id) {
jar (doing other things) 2013/01/24 01:05:14 nit: Clearer might be GetNameForThread(...), or po
dsinclair 2013/01/24 15:13:06 Done.
52 AutoLock locked(lock_);
53 IdToInternedNameIterator iter = id_to_interned_name_.find(id);
54 DCHECK(iter != id_to_interned_name_.end());
55 return iter->second.c_str();
jar (doing other things) 2013/01/24 01:05:14 This sort of return tends to suggest that the stri
dsinclair 2013/01/24 15:13:06 This should be long lived as it will continue to l
56 }
57
58 void ThreadIdNameManager::RemoveNameForId(PlatformThreadId id) {
59 if (id == kInvalidThreadId)
60 return;
61
62 AutoLock locked(lock_);
63 IdToInternedNameIterator iter = id_to_interned_name_.find(id);
64 DCHECK((iter != id_to_interned_name_.end()));
65 id_to_interned_name_.erase(iter);
66 }
67
68 } // namespace base
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698