OLD | NEW |
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 #ifndef WEBKIT_GLUE_PLUGINS_PEPPER_RESOURCE_TRACKER_H_ | 5 #ifndef WEBKIT_GLUE_PLUGINS_PEPPER_RESOURCE_TRACKER_H_ |
6 #define WEBKIT_GLUE_PLUGINS_PEPPER_RESOURCE_TRACKER_H_ | 6 #define WEBKIT_GLUE_PLUGINS_PEPPER_RESOURCE_TRACKER_H_ |
7 | 7 |
8 #include <map> | 8 #include <map> |
9 #include <utility> | 9 #include <utility> |
10 | 10 |
(...skipping 11 matching lines...) Expand all Loading... |
22 class PluginModule; | 22 class PluginModule; |
23 class Resource; | 23 class Resource; |
24 | 24 |
25 // This class maintains a global list of all live pepper resources. It allows | 25 // This class maintains a global list of all live pepper resources. It allows |
26 // us to check resource ID validity and to map them to a specific module. | 26 // us to check resource ID validity and to map them to a specific module. |
27 // | 27 // |
28 // This object is threadsafe. | 28 // This object is threadsafe. |
29 class ResourceTracker { | 29 class ResourceTracker { |
30 public: | 30 public: |
31 // Returns the pointer to the singleton object. | 31 // Returns the pointer to the singleton object. |
32 static ResourceTracker* Get() { | 32 static ResourceTracker* Get(); |
33 return Singleton<ResourceTracker>::get(); | |
34 } | |
35 | 33 |
36 // PP_Resources -------------------------------------------------------------- | 34 // PP_Resources -------------------------------------------------------------- |
37 | 35 |
38 // The returned pointer will be NULL if there is no resource. Note that this | 36 // The returned pointer will be NULL if there is no resource. Note that this |
39 // return value is a scoped_refptr so that we ensure the resource is valid | 37 // return value is a scoped_refptr so that we ensure the resource is valid |
40 // from the point of the lookup to the point that the calling code needs it. | 38 // from the point of the lookup to the point that the calling code needs it. |
41 // Otherwise, the plugin could Release() the resource on another thread and | 39 // Otherwise, the plugin could Release() the resource on another thread and |
42 // the object will get deleted out from under us. | 40 // the object will get deleted out from under us. |
43 scoped_refptr<Resource> GetResource(PP_Resource res) const; | 41 scoped_refptr<Resource> GetResource(PP_Resource res) const; |
44 | 42 |
(...skipping 80 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
125 // destructor will notify us when the module is deleted. | 123 // destructor will notify us when the module is deleted. |
126 typedef std::map<PP_Module, PluginModule*> ModuleMap; | 124 typedef std::map<PP_Module, PluginModule*> ModuleMap; |
127 ModuleMap module_map_; | 125 ModuleMap module_map_; |
128 | 126 |
129 DISALLOW_COPY_AND_ASSIGN(ResourceTracker); | 127 DISALLOW_COPY_AND_ASSIGN(ResourceTracker); |
130 }; | 128 }; |
131 | 129 |
132 } // namespace pepper | 130 } // namespace pepper |
133 | 131 |
134 #endif // WEBKIT_GLUE_PLUGINS_PEPPER_RESOURCE_TRACKER_H_ | 132 #endif // WEBKIT_GLUE_PLUGINS_PEPPER_RESOURCE_TRACKER_H_ |
OLD | NEW |