Chromium Code Reviews| Index: chrome/renderer/extensions/chrome_v8_extension.h |
| diff --git a/chrome/renderer/extensions/chrome_v8_extension.h b/chrome/renderer/extensions/chrome_v8_extension.h |
| index 511273fba3760c88da5b5fb51dc5fd455664e512..74c143ed47a060032a37ce4c3d93e4cdedf7598f 100644 |
| --- a/chrome/renderer/extensions/chrome_v8_extension.h |
| +++ b/chrome/renderer/extensions/chrome_v8_extension.h |
| @@ -10,6 +10,7 @@ |
| #include "base/memory/linked_ptr.h" |
| #include "base/string_piece.h" |
| #include "chrome/renderer/extensions/chrome_v8_extension_handler.h" |
| +#include "chrome/renderer/native_handler.h" |
| #include "v8/include/v8.h" |
| #include <map> |
| @@ -26,31 +27,17 @@ class RenderView; |
| // This is a base class for chrome extension bindings. Common features that |
| // are shared by different modules go here. |
| -class ChromeV8Extension : public v8::Extension { |
| +// TODO(koz): Rename this to ChromeNativeHandler. |
|
Aaron Boodman
2012/02/28 02:42:59
What about "NativeJavaScriptModule"? (You could re
koz (OOO until 15th September)
2012/03/01 03:41:56
Oh yeah, nice. How about:
ModuleSystem => JavaScr
|
| +class ChromeV8Extension : public NativeHandler { |
| public: |
| typedef std::set<ChromeV8Extension*> InstanceSet; |
| static const InstanceSet& GetAll(); |
| - ChromeV8Extension(const char* name, |
| - int resource_id, |
| - ExtensionDispatcher* extension_dispatcher); |
| - ChromeV8Extension(const char* name, |
| - int resource_id, |
| - int dependency_count, |
| - const char** dependencies, |
| - ExtensionDispatcher* extension_dispatcher); |
| + explicit ChromeV8Extension(ExtensionDispatcher* extension_dispatcher); |
| virtual ~ChromeV8Extension(); |
| ExtensionDispatcher* extension_dispatcher() { return extension_dispatcher_; } |
| - void ContextWillBeReleased(ChromeV8Context* context); |
| - |
| - // Derived classes should call this at the end of their implementation in |
| - // order to expose common native functions, like GetChromeHidden, to the |
| - // v8 extension. |
| - virtual v8::Handle<v8::FunctionTemplate> |
| - GetNativeFunction(v8::Handle<v8::String> name) OVERRIDE; |
| - |
| protected: |
| template<class T> |
| static T* GetFromArguments(const v8::Arguments& args) { |
| @@ -73,32 +60,12 @@ class ChromeV8Extension : public v8::Extension { |
| bool CheckCurrentContextAccessToExtensionAPI( |
| const std::string& function_name) const; |
| - // Create a handler for |context|. If a subclass of ChromeV8Extension wishes |
| - // to support handlers, it should override this. |
| - virtual ChromeV8ExtensionHandler* CreateHandler(ChromeV8Context* context); |
| - |
| // Returns the chromeHidden object for the current context. |
| static v8::Handle<v8::Value> GetChromeHidden(const v8::Arguments& args); |
| ExtensionDispatcher* extension_dispatcher_; |
| private: |
| - static base::StringPiece GetStringResource(int resource_id); |
| - |
| - // Helper to print from bindings javascript. |
| - static v8::Handle<v8::Value> Print(const v8::Arguments& args); |
| - |
| - // Handle a native function call from JavaScript. |
| - static v8::Handle<v8::Value> HandleNativeFunction(const v8::Arguments& args); |
| - |
| - // Get the handler instance for |context|, or NULL if no such context exists. |
| - ChromeV8ExtensionHandler* GetHandler(ChromeV8Context* context) const; |
| - |
| - // Map of all current handlers. |
| - typedef std::map<ChromeV8Context*, |
| - linked_ptr<ChromeV8ExtensionHandler> > HandlerMap; |
| - HandlerMap handlers_; |
| - |
| DISALLOW_COPY_AND_ASSIGN(ChromeV8Extension); |
| }; |