diff options
Diffstat (limited to 'chrome/renderer/extensions/tts_custom_bindings.cc')
-rw-r--r-- | chrome/renderer/extensions/tts_custom_bindings.cc | 26 |
1 files changed, 19 insertions, 7 deletions
diff --git a/chrome/renderer/extensions/tts_custom_bindings.cc b/chrome/renderer/extensions/tts_custom_bindings.cc index 33e1887..dca526a 100644 --- a/chrome/renderer/extensions/tts_custom_bindings.cc +++ b/chrome/renderer/extensions/tts_custom_bindings.cc @@ -13,18 +13,30 @@ namespace extensions { -TTSCustomBindings::TTSCustomBindings() - : ChromeV8Extension(NULL) { - RouteStaticFunction("GetNextTTSEventId", &GetNextTTSEventId); -} +TTSCustomBindings::TTSCustomBindings( + int dependency_count, + const char** dependencies) + : ChromeV8Extension( + "extensions/tts_custom_bindings.js", + IDR_TTS_CUSTOM_BINDINGS_JS, + dependency_count, + dependencies, + NULL) {} -// static -v8::Handle<v8::Value> TTSCustomBindings::GetNextTTSEventId( - const v8::Arguments& args) { +static v8::Handle<v8::Value> GetNextTTSEventId(const v8::Arguments& args) { // Note: this works because the TTS API only works in the // extension process, not content scripts. static int next_tts_event_id = 1; return v8::Integer::New(next_tts_event_id++); } +v8::Handle<v8::FunctionTemplate> +TTSCustomBindings::GetNativeFunction( + v8::Handle<v8::String> name) { + if (name->Equals(v8::String::New("GetNextTTSEventId"))) + return v8::FunctionTemplate::New(GetNextTTSEventId); + + return ChromeV8Extension::GetNativeFunction(name); +} + } // extensions |