/*
    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., 51 Franklin Street, Fifth Floor,
    Boston, MA 02110-1301, USA.
*/

#pragma once

#if ENABLE(TOUCH_EVENTS)

#include "JSUIEvent.h"
#include "TouchEvent.h"

namespace WebCore {

class JSDictionary;

class JSTouchEvent : public JSUIEvent {
public:
    typedef JSUIEvent Base;
    typedef TouchEvent DOMWrapped;
    static JSTouchEvent* create(JSC::Structure* structure, JSDOMGlobalObject* globalObject, Ref<TouchEvent>&& impl)
    {
        JSTouchEvent* ptr = new (NotNull, JSC::allocateCell<JSTouchEvent>(globalObject->vm().heap)) JSTouchEvent(structure, *globalObject, WTFMove(impl));
        ptr->finishCreation(globalObject->vm());
        return ptr;
    }

    static JSC::JSObject* createPrototype(JSC::VM&, JSC::JSGlobalObject*);
    static JSC::JSObject* prototype(JSC::VM&, JSC::JSGlobalObject*);

    DECLARE_INFO;

    static JSC::Structure* createStructure(JSC::VM& vm, JSC::JSGlobalObject* globalObject, JSC::JSValue prototype)
    {
        return JSC::Structure::create(vm, globalObject, prototype, JSC::TypeInfo(JSC::ObjectType, StructureFlags), info());
    }

    static JSC::JSValue getConstructor(JSC::VM&, const JSC::JSGlobalObject*);
    TouchEvent& wrapped() const
    {
        return static_cast<TouchEvent&>(Base::wrapped());
    }
protected:
    JSTouchEvent(JSC::Structure*, JSDOMGlobalObject&, Ref<TouchEvent>&&);

    void finishCreation(JSC::VM& vm)
    {
        Base::finishCreation(vm);
        ASSERT(inherits(info()));
    }

};


bool fillTouchEventInit(TouchEventInit&, JSDictionary&);

template<> struct JSDOMWrapperConverterTraits<TouchEvent> {
    using WrapperClass = JSTouchEvent;
};

} // namespace WebCore

#endif // ENABLE(TOUCH_EVENTS)
