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

Unified Diff: chrome/browser/lifetime/keep_alive_registry.h

Issue 1708343002: Add ScopedKeepAlive to c/b/lifetime (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 4 years, 10 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 side-by-side diff with in-line comments
Download patch
Index: chrome/browser/lifetime/keep_alive_registry.h
diff --git a/chrome/browser/lifetime/keep_alive_registry.h b/chrome/browser/lifetime/keep_alive_registry.h
new file mode 100644
index 0000000000000000000000000000000000000000..b521bbb39c3cbf726be7808da2317cfe2ce6243e
--- /dev/null
+++ b/chrome/browser/lifetime/keep_alive_registry.h
@@ -0,0 +1,32 @@
+// Copyright 2016 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef CHROME_BROWSER_LIFETIME_KEEP_ALIVE_REGISTRY_H_
+#define CHROME_BROWSER_LIFETIME_KEEP_ALIVE_REGISTRY_H_
+
+#include <set>
+#include <string>
+
+#include "base/macros.h"
+#include "base/memory/singleton.h"
+
+class KeepAliveRegistry {
+ public:
+ static KeepAliveRegistry* GetInstance();
+
+ void RegisterToken(const std::string& token);
+ void UnregisterToken(const std::string& token);
+
+ private:
+ friend struct base::DefaultSingletonTraits<KeepAliveRegistry>;
+
+ KeepAliveRegistry();
+ virtual ~KeepAliveRegistry();
sky 2016/02/19 21:02:49 Why the virtual?
dgn 2016/02/22 18:01:20 No subclass involved here, so removed it.
+
+ std::multiset<std::string> registered_tokens_;
sky 2016/02/19 21:02:49 Is there a reason why you aren't using a map<strin
dgn 2016/02/22 18:01:20 With the int being the number of registered tokens
sky 2016/02/24 18:53:21 Couldn't you just as well use two map<enum,int> an
dgn 2016/02/24 19:55:45 I think we had different assumptions. I started wo
dgn 2016/02/24 21:04:18 Done.
+
+ DISALLOW_COPY_AND_ASSIGN(KeepAliveRegistry);
+};
+
+#endif // CHROME_BROWSER_LIFETIME_KEEP_ALIVE_REGISTRY_H_

Powered by Google App Engine
This is Rietveld 408576698