summaryrefslogtreecommitdiffstats
path: root/base
diff options
context:
space:
mode:
authordeanm@google.com <deanm@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-08-13 13:57:21 +0000
committerdeanm@google.com <deanm@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-08-13 13:57:21 +0000
commit1cf1b34a696fcda6d8f84a31e372c0d85e7ef1ec (patch)
treebfa2162524dd6e2d2162410a7701801295c8fd64 /base
parent9e950bddb6d7f49634757d373e3f13a7d0425ae5 (diff)
downloadchromium_src-1cf1b34a696fcda6d8f84a31e372c0d85e7ef1ec.zip
chromium_src-1cf1b34a696fcda6d8f84a31e372c0d85e7ef1ec.tar.gz
chromium_src-1cf1b34a696fcda6d8f84a31e372c0d85e7ef1ec.tar.bz2
Avoid a global std::stack. Instead embed a next pointer in the managers.
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@795 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'base')
-rw-r--r--base/at_exit.cc38
-rw-r--r--base/at_exit.h2
2 files changed, 20 insertions, 20 deletions
diff --git a/base/at_exit.cc b/base/at_exit.cc
index 62efcc8..12ddf40 100644
--- a/base/at_exit.cc
+++ b/base/at_exit.cc
@@ -36,54 +36,52 @@ namespace base {
// recent, and we should never have more than one outside of testing, when we
// use the shadow version of the constructor. We don't protect this for
// thread-safe access, since it will only be modified in testing.
-static std::stack<AtExitManager*> g_managers;
+static AtExitManager* g_top_manager = NULL;
-AtExitManager::AtExitManager() {
- DCHECK(g_managers.empty());
- g_managers.push(this);
+AtExitManager::AtExitManager() : next_manager_(NULL) {
+ DCHECK(!g_top_manager);
+ g_top_manager = this;
}
-AtExitManager::AtExitManager(bool shadow) {
- DCHECK(shadow || g_managers.empty());
- g_managers.push(this);
+AtExitManager::AtExitManager(bool shadow) : next_manager_(g_top_manager) {
+ DCHECK(shadow || !g_top_manager);
+ g_top_manager = this;
}
AtExitManager::~AtExitManager() {
- if (g_managers.empty()) {
+ if (!g_top_manager) {
NOTREACHED() << "Tried to ~AtExitManager without an AtExitManager";
return;
}
- DCHECK(g_managers.top() == this);
+ DCHECK(g_top_manager == this);
ProcessCallbacksNow();
- g_managers.pop();
+ g_top_manager = next_manager_;
}
// static
void AtExitManager::RegisterCallback(AtExitCallbackType func) {
- if (g_managers.empty()) {
+ if (!g_top_manager) {
NOTREACHED() << "Tried to RegisterCallback without an AtExitManager";
return;
}
- AtExitManager* manager = g_managers.top();
- AutoLock lock(manager->lock_);
- manager->stack_.push(func);
+ AutoLock lock(g_top_manager->lock_);
+ g_top_manager->stack_.push(func);
}
// static
void AtExitManager::ProcessCallbacksNow() {
- if (g_managers.empty()) {
+ if (!g_top_manager) {
NOTREACHED() << "Tried to ProcessCallbacksNow without an AtExitManager";
return;
}
- AtExitManager* manager = g_managers.top();
- AutoLock lock(manager->lock_);
+ AutoLock lock(g_top_manager->lock_);
- while (!manager->stack_.empty()) {
- AtExitCallbackType func = manager->stack_.top();
- manager->stack_.pop();
+ while (!g_top_manager->stack_.empty()) {
+ AtExitCallbackType func = g_top_manager->stack_.top();
+ g_top_manager->stack_.pop();
if (func)
func();
}
diff --git a/base/at_exit.h b/base/at_exit.h
index 38e7b54..9ff41c9 100644
--- a/base/at_exit.h
+++ b/base/at_exit.h
@@ -79,6 +79,8 @@ class AtExitManager {
private:
Lock lock_;
std::stack<AtExitCallbackType> stack_;
+ AtExitManager* next_manager_; // Stack of managers to allow shadowing.
+
DISALLOW_COPY_AND_ASSIGN(AtExitManager);
};