| OLD | NEW |
| 1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2011 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 CHROME_RENDERER_EXTENSIONS_BINDINGS_UTILS_H_ | 5 #ifndef CHROME_RENDERER_EXTENSIONS_BINDINGS_UTILS_H_ |
| 6 #define CHROME_RENDERER_EXTENSIONS_BINDINGS_UTILS_H_ | 6 #define CHROME_RENDERER_EXTENSIONS_BINDINGS_UTILS_H_ |
| 7 #pragma once | 7 #pragma once |
| 8 | 8 |
| 9 #include "base/memory/linked_ptr.h" | 9 #include "base/memory/linked_ptr.h" |
| 10 #include "base/memory/singleton.h" | 10 #include "base/memory/singleton.h" |
| (...skipping 73 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 84 ContextInfo(v8::Persistent<v8::Context> context, | 84 ContextInfo(v8::Persistent<v8::Context> context, |
| 85 const std::string& extension_id, | 85 const std::string& extension_id, |
| 86 WebKit::WebFrame* frame); | 86 WebKit::WebFrame* frame); |
| 87 ~ContextInfo(); | 87 ~ContextInfo(); |
| 88 | 88 |
| 89 v8::Persistent<v8::Context> context; | 89 v8::Persistent<v8::Context> context; |
| 90 | 90 |
| 91 // The extension ID this context is associated with. | 91 // The extension ID this context is associated with. |
| 92 std::string extension_id; | 92 std::string extension_id; |
| 93 | 93 |
| 94 // The frame the context is associated with. We can't always get this from | 94 // The frame the context is associated with. ContextInfo can outlive its |
| 95 // WebFrame::frameForContext() (in particular as the the frame is navigating | 95 // frame, so this should not be dereferenced. It is stored only for use for |
| 96 // or being destroyed). | 96 // comparison. |
| 97 WebKit::WebFrame* frame; | 97 void* unsafe_frame; |
| 98 | 98 |
| 99 // A count of the number of events that are listening in this context. When | 99 // A count of the number of events that are listening in this context. When |
| 100 // this is zero, |context| will be a weak handle. | 100 // this is zero, |context| will be a weak handle. |
| 101 int num_connected_events; | 101 int num_connected_events; |
| 102 }; | 102 }; |
| 103 typedef std::list< linked_ptr<ContextInfo> > ContextList; | 103 typedef std::list< linked_ptr<ContextInfo> > ContextList; |
| 104 | 104 |
| 105 // Returns a mutable reference to the ContextList. Note: be careful using this. | 105 // Returns a mutable reference to the ContextList. Note: be careful using this. |
| 106 // Calling into javascript may result in the list being modified, so don't rely | 106 // Calling into javascript may result in the list being modified, so don't rely |
| 107 // on iterators remaining valid between calls to javascript. | 107 // on iterators remaining valid between calls to javascript. |
| (...skipping 28 matching lines...) Expand all Loading... |
| 136 // be a sub-property like "Port.dispatchOnMessage". Returns the result of | 136 // be a sub-property like "Port.dispatchOnMessage". Returns the result of |
| 137 // the function call. If an exception is thrown an empty Handle will be | 137 // the function call. If an exception is thrown an empty Handle will be |
| 138 // returned. | 138 // returned. |
| 139 v8::Handle<v8::Value> CallFunctionInContext(v8::Handle<v8::Context> context, | 139 v8::Handle<v8::Value> CallFunctionInContext(v8::Handle<v8::Context> context, |
| 140 const std::string& function_name, int argc, | 140 const std::string& function_name, int argc, |
| 141 v8::Handle<v8::Value>* argv); | 141 v8::Handle<v8::Value>* argv); |
| 142 | 142 |
| 143 } // namespace bindings_utils | 143 } // namespace bindings_utils |
| 144 | 144 |
| 145 #endif // CHROME_RENDERER_EXTENSIONS_BINDINGS_UTILS_H_ | 145 #endif // CHROME_RENDERER_EXTENSIONS_BINDINGS_UTILS_H_ |
| OLD | NEW |