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

Unified Diff: ppapi/proxy/plugin_globals.h

Issue 8316008: Add a new globals object for PPAPI tracking information. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 9 years, 2 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: ppapi/proxy/plugin_globals.h
diff --git a/ppapi/proxy/plugin_globals.h b/ppapi/proxy/plugin_globals.h
new file mode 100644
index 0000000000000000000000000000000000000000..141b90456dd866305dbe042f326aec78c65eaabf
--- /dev/null
+++ b/ppapi/proxy/plugin_globals.h
@@ -0,0 +1,50 @@
+// Copyright (c) 2011 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 PPAPI_PROXY_PLUGIN_GLOBALS_H_
+#define PPAPI_PROXY_PLUGIN_GLOBALS_H_
+
+#include "base/compiler_specific.h"
+#include "ppapi/proxy/plugin_resource_tracker.h"
+#include "ppapi/proxy/plugin_var_tracker.h"
+#include "ppapi/shared_impl/ppapi_globals.h"
+
+namespace ppapi {
+namespace proxy {
+
+class PluginGlobals : public PpapiGlobals {
+ public:
+ PluginGlobals();
+ virtual ~PluginGlobals();
+
+ // Getter for the global singleton. Generally, you should use
+ // PpapiGlobals::Get() when possible. Use this only when you need some
+ // plugin-specific functionality.
+ inline static PluginGlobals* Get() { return plugin_globals_; }
+
+ // PpapiGlobals implementation.
+ virtual ResourceTracker* GetResourceTracker() OVERRIDE;
yzshen1 2011/10/18 20:09:57 [optional] It seems good to me to make PluginGloba
brettw 2011/10/18 20:43:54 This function is an implementation of the pure vir
yzshen1 2011/10/18 20:53:35 [optional, not intended to block your check in.] I
+ virtual VarTracker* GetVarTracker() OVERRIDE;
+
+ // Getters for the plugin-specific versions.
+ PluginResourceTracker* plugin_resource_tracker() {
+ return &plugin_resource_tracker_;
+ }
+ PluginVarTracker* plugin_var_tracker() {
+ return &plugin_var_tracker_;
+ }
+
+ private:
+ static PluginGlobals* plugin_globals_;
+
+ PluginResourceTracker plugin_resource_tracker_;
+ PluginVarTracker plugin_var_tracker_;
+
+ DISALLOW_COPY_AND_ASSIGN(PluginGlobals);
+};
+
+} // namespace proxy
+} // namespace ppapi
+
+#endif // PPAPI_PROXY_PLUGIN_GLOBALS_H_

Powered by Google App Engine
This is Rietveld 408576698