| /* |
| This file is part of the WebKit open source project. |
| This file has been generated by generate-bindings.pl. DO NOT MODIFY! |
| |
| This library is free software; you can redistribute it and/or |
| modify it under the terms of the GNU Library General Public |
| License as published by the Free Software Foundation; either |
| version 2 of the License, or (at your option) any later version. |
| |
| This library is distributed in the hope that it will be useful, |
| but WITHOUT ANY WARRANTY; without even the implied warranty of |
| MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU |
| Library General Public License for more details. |
| |
| You should have received a copy of the GNU Library General Public License |
| along with this library; see the file COPYING.LIB. If not, write to |
| the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
| Boston, MA 02111-1307, USA. |
| */ |
| |
| #include "config.h" |
| #include "V8TestEventConstructor.h" |
| |
| #include "BindingState.h" |
| #include "ContextFeatures.h" |
| #include "Dictionary.h" |
| #include "Frame.h" |
| #include "RuntimeEnabledFeatures.h" |
| #include "V8Binding.h" |
| #include "V8DOMWrapper.h" |
| #include <wtf/UnusedParam.h> |
| |
| namespace WebCore { |
| |
| WrapperTypeInfo V8TestEventConstructor::info = { V8TestEventConstructor::GetTemplate, V8TestEventConstructor::derefObject, 0, 0, V8TestEventConstructor::installPerContextPrototypeProperties, 0, WrapperTypeObjectPrototype }; |
| |
| namespace TestEventConstructorV8Internal { |
| |
| template <typename T> void V8_USE(T) { } |
| |
| static v8::Handle<v8::Value> attr1AttrGetter(v8::Local<v8::String> name, const v8::AccessorInfo& info) |
| { |
| INC_STATS("DOM.TestEventConstructor.attr1._get"); |
| TestEventConstructor* imp = V8TestEventConstructor::toNative(info.Holder()); |
| return v8String(imp->attr1(), info.GetIsolate()); |
| } |
| |
| static v8::Handle<v8::Value> attr2AttrGetter(v8::Local<v8::String> name, const v8::AccessorInfo& info) |
| { |
| INC_STATS("DOM.TestEventConstructor.attr2._get"); |
| TestEventConstructor* imp = V8TestEventConstructor::toNative(info.Holder()); |
| return v8String(imp->attr2(), info.GetIsolate()); |
| } |
| |
| } // namespace TestEventConstructorV8Internal |
| |
| static const V8DOMConfiguration::BatchedAttribute V8TestEventConstructorAttrs[] = { |
| // Attribute 'attr1' (Type: 'readonly attribute' ExtAttr: '') |
| {"attr1", TestEventConstructorV8Internal::attr1AttrGetter, 0, 0 /* no data */, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}, |
| // Attribute 'attr2' (Type: 'readonly attribute' ExtAttr: 'InitializedByEventConstructor') |
| {"attr2", TestEventConstructorV8Internal::attr2AttrGetter, 0, 0 /* no data */, static_cast<v8::AccessControl>(v8::DEFAULT), static_cast<v8::PropertyAttribute>(v8::None), 0 /* on instance */}, |
| }; |
| |
| v8::Handle<v8::Value> V8TestEventConstructor::constructorCallback(const v8::Arguments& args) |
| { |
| INC_STATS("DOM.TestEventConstructor.Constructor"); |
| |
| if (!args.IsConstructCall()) |
| return throwTypeError("DOM object constructor cannot be called as a function."); |
| |
| if (ConstructorMode::current() == ConstructorMode::WrapExistingObject) |
| return args.Holder(); |
| |
| if (args.Length() < 1) |
| return throwNotEnoughArgumentsError(args.GetIsolate()); |
| |
| STRING_TO_V8PARAMETER_EXCEPTION_BLOCK(V8Parameter<>, type, args[0]); |
| TestEventConstructorInit eventInit; |
| if (args.Length() >= 2) { |
| EXCEPTION_BLOCK(Dictionary, options, Dictionary(args[1], args.GetIsolate())); |
| if (!fillTestEventConstructorInit(eventInit, options)) |
| return v8Undefined(); |
| } |
| |
| RefPtr<TestEventConstructor> event = TestEventConstructor::create(type, eventInit); |
| |
| v8::Handle<v8::Object> wrapper = args.Holder(); |
| V8DOMWrapper::setDOMWrapper(wrapper, &info, event.get()); |
| V8DOMWrapper::setJSWrapperForDOMObject(event.release(), wrapper, args.GetIsolate()); |
| return wrapper; |
| } |
| |
| bool fillTestEventConstructorInit(TestEventConstructorInit& eventInit, const Dictionary& options) |
| { |
| options.get("attr2", eventInit.attr2); |
| return true; |
| } |
| |
| static v8::Persistent<v8::FunctionTemplate> ConfigureV8TestEventConstructorTemplate(v8::Persistent<v8::FunctionTemplate> desc) |
| { |
| desc->ReadOnlyPrototype(); |
| |
| v8::Local<v8::Signature> defaultSignature; |
| defaultSignature = V8DOMConfiguration::configureTemplate(desc, "TestEventConstructor", v8::Persistent<v8::FunctionTemplate>(), V8TestEventConstructor::internalFieldCount, |
| V8TestEventConstructorAttrs, WTF_ARRAY_LENGTH(V8TestEventConstructorAttrs), |
| 0, 0); |
| UNUSED_PARAM(defaultSignature); // In some cases, it will not be used. |
| desc->SetCallHandler(V8TestEventConstructor::constructorCallback); |
| |
| |
| // Custom toString template |
| desc->Set(v8::String::NewSymbol("toString"), V8PerIsolateData::current()->toStringTemplate()); |
| return desc; |
| } |
| |
| v8::Persistent<v8::FunctionTemplate> V8TestEventConstructor::GetRawTemplate() |
| { |
| V8PerIsolateData* data = V8PerIsolateData::current(); |
| V8PerIsolateData::TemplateMap::iterator result = data->rawTemplateMap().find(&info); |
| if (result != data->rawTemplateMap().end()) |
| return result->value; |
| |
| v8::HandleScope handleScope; |
| v8::Persistent<v8::FunctionTemplate> templ = createRawTemplate(); |
| data->rawTemplateMap().add(&info, templ); |
| return templ; |
| } |
| |
| v8::Persistent<v8::FunctionTemplate> V8TestEventConstructor::GetTemplate() |
| { |
| V8PerIsolateData* data = V8PerIsolateData::current(); |
| V8PerIsolateData::TemplateMap::iterator result = data->templateMap().find(&info); |
| if (result != data->templateMap().end()) |
| return result->value; |
| |
| v8::HandleScope handleScope; |
| v8::Persistent<v8::FunctionTemplate> templ = |
| ConfigureV8TestEventConstructorTemplate(GetRawTemplate()); |
| data->templateMap().add(&info, templ); |
| return templ; |
| } |
| |
| bool V8TestEventConstructor::HasInstance(v8::Handle<v8::Value> value) |
| { |
| return GetRawTemplate()->HasInstance(value); |
| } |
| |
| |
| v8::Handle<v8::Object> V8TestEventConstructor::wrapSlow(PassRefPtr<TestEventConstructor> impl, v8::Handle<v8::Object> creationContext, v8::Isolate* isolate) |
| { |
| v8::Handle<v8::Object> wrapper; |
| // Please don't add any more uses of this variable. |
| Document* deprecatedDocument = 0; |
| UNUSED_PARAM(deprecatedDocument); |
| |
| v8::Handle<v8::Context> context; |
| if (!creationContext.IsEmpty() && creationContext->CreationContext() != v8::Context::GetCurrent()) { |
| // For performance, we enter the context only if the currently running context |
| // is different from the context that we are about to enter. |
| context = v8::Local<v8::Context>::New(creationContext->CreationContext()); |
| ASSERT(!context.IsEmpty()); |
| context->Enter(); |
| } |
| |
| wrapper = V8DOMWrapper::instantiateV8Object(deprecatedDocument, &info, impl.get()); |
| |
| if (!context.IsEmpty()) |
| context->Exit(); |
| |
| if (UNLIKELY(wrapper.IsEmpty())) |
| return wrapper; |
| |
| installPerContextProperties(wrapper, impl.get()); |
| v8::Persistent<v8::Object> wrapperHandle = V8DOMWrapper::setJSWrapperForDOMObject(impl, wrapper, isolate); |
| if (!hasDependentLifetime) |
| wrapperHandle.MarkIndependent(); |
| return wrapper; |
| } |
| |
| void V8TestEventConstructor::derefObject(void* object) |
| { |
| static_cast<TestEventConstructor*>(object)->deref(); |
| } |
| |
| } // namespace WebCore |