/* 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. */ #include "config.h" #if ENABLE(VIDEO) #include "JSHTMLMediaElement.h" #include "ExceptionCode.h" #include "HTMLMediaElement.h" #include "HTMLNames.h" #include "JSDOMBinding.h" #include "JSMediaError.h" #include "JSTimeRanges.h" #include "KURL.h" #include "MediaError.h" #include "TimeRanges.h" #include #include #include using namespace JSC; namespace WebCore { ASSERT_CLASS_FITS_IN_CELL(JSHTMLMediaElement); /* Hash table */ #if ENABLE(JIT) #define THUNK_GENERATOR(generator) , generator #else #define THUNK_GENERATOR(generator) #endif static const HashTableValue JSHTMLMediaElementTableValues[27] = { { "error", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementError), (intptr_t)0 THUNK_GENERATOR(0) }, { "src", DontDelete, (intptr_t)static_cast(jsHTMLMediaElementSrc), (intptr_t)setJSHTMLMediaElementSrc THUNK_GENERATOR(0) }, { "currentSrc", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementCurrentSrc), (intptr_t)0 THUNK_GENERATOR(0) }, { "networkState", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementNetworkState), (intptr_t)0 THUNK_GENERATOR(0) }, { "preload", DontDelete, (intptr_t)static_cast(jsHTMLMediaElementPreload), (intptr_t)setJSHTMLMediaElementPreload THUNK_GENERATOR(0) }, { "buffered", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementBuffered), (intptr_t)0 THUNK_GENERATOR(0) }, { "readyState", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementReadyState), (intptr_t)0 THUNK_GENERATOR(0) }, { "seeking", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementSeeking), (intptr_t)0 THUNK_GENERATOR(0) }, { "currentTime", DontDelete, (intptr_t)static_cast(jsHTMLMediaElementCurrentTime), (intptr_t)setJSHTMLMediaElementCurrentTime THUNK_GENERATOR(0) }, { "startTime", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementStartTime), (intptr_t)0 THUNK_GENERATOR(0) }, { "duration", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementDuration), (intptr_t)0 THUNK_GENERATOR(0) }, { "paused", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementPaused), (intptr_t)0 THUNK_GENERATOR(0) }, { "defaultPlaybackRate", DontDelete, (intptr_t)static_cast(jsHTMLMediaElementDefaultPlaybackRate), (intptr_t)setJSHTMLMediaElementDefaultPlaybackRate THUNK_GENERATOR(0) }, { "playbackRate", DontDelete, (intptr_t)static_cast(jsHTMLMediaElementPlaybackRate), (intptr_t)setJSHTMLMediaElementPlaybackRate THUNK_GENERATOR(0) }, { "played", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementPlayed), (intptr_t)0 THUNK_GENERATOR(0) }, { "seekable", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementSeekable), (intptr_t)0 THUNK_GENERATOR(0) }, { "ended", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementEnded), (intptr_t)0 THUNK_GENERATOR(0) }, { "autoplay", DontDelete, (intptr_t)static_cast(jsHTMLMediaElementAutoplay), (intptr_t)setJSHTMLMediaElementAutoplay THUNK_GENERATOR(0) }, { "loop", DontDelete, (intptr_t)static_cast(jsHTMLMediaElementLoop), (intptr_t)setJSHTMLMediaElementLoop THUNK_GENERATOR(0) }, { "controls", DontDelete, (intptr_t)static_cast(jsHTMLMediaElementControls), (intptr_t)setJSHTMLMediaElementControls THUNK_GENERATOR(0) }, { "volume", DontDelete, (intptr_t)static_cast(jsHTMLMediaElementVolume), (intptr_t)setJSHTMLMediaElementVolume THUNK_GENERATOR(0) }, { "muted", DontDelete, (intptr_t)static_cast(jsHTMLMediaElementMuted), (intptr_t)setJSHTMLMediaElementMuted THUNK_GENERATOR(0) }, { "webkitPreservesPitch", DontDelete, (intptr_t)static_cast(jsHTMLMediaElementWebkitPreservesPitch), (intptr_t)setJSHTMLMediaElementWebkitPreservesPitch THUNK_GENERATOR(0) }, { "webkitHasClosedCaptions", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementWebkitHasClosedCaptions), (intptr_t)0 THUNK_GENERATOR(0) }, { "webkitClosedCaptionsVisible", DontDelete, (intptr_t)static_cast(jsHTMLMediaElementWebkitClosedCaptionsVisible), (intptr_t)setJSHTMLMediaElementWebkitClosedCaptionsVisible THUNK_GENERATOR(0) }, { "constructor", DontEnum | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementConstructor), (intptr_t)0 THUNK_GENERATOR(0) }, { 0, 0, 0, 0 THUNK_GENERATOR(0) } }; #undef THUNK_GENERATOR static JSC_CONST_HASHTABLE HashTable JSHTMLMediaElementTable = { 69, 63, JSHTMLMediaElementTableValues, 0 }; /* Hash table for constructor */ #if ENABLE(JIT) #define THUNK_GENERATOR(generator) , generator #else #define THUNK_GENERATOR(generator) #endif static const HashTableValue JSHTMLMediaElementConstructorTableValues[10] = { { "NETWORK_EMPTY", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementNETWORK_EMPTY), (intptr_t)0 THUNK_GENERATOR(0) }, { "NETWORK_IDLE", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementNETWORK_IDLE), (intptr_t)0 THUNK_GENERATOR(0) }, { "NETWORK_LOADING", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementNETWORK_LOADING), (intptr_t)0 THUNK_GENERATOR(0) }, { "NETWORK_NO_SOURCE", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementNETWORK_NO_SOURCE), (intptr_t)0 THUNK_GENERATOR(0) }, { "HAVE_NOTHING", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementHAVE_NOTHING), (intptr_t)0 THUNK_GENERATOR(0) }, { "HAVE_METADATA", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementHAVE_METADATA), (intptr_t)0 THUNK_GENERATOR(0) }, { "HAVE_CURRENT_DATA", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementHAVE_CURRENT_DATA), (intptr_t)0 THUNK_GENERATOR(0) }, { "HAVE_FUTURE_DATA", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementHAVE_FUTURE_DATA), (intptr_t)0 THUNK_GENERATOR(0) }, { "HAVE_ENOUGH_DATA", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementHAVE_ENOUGH_DATA), (intptr_t)0 THUNK_GENERATOR(0) }, { 0, 0, 0, 0 THUNK_GENERATOR(0) } }; #undef THUNK_GENERATOR static JSC_CONST_HASHTABLE HashTable JSHTMLMediaElementConstructorTable = { 32, 31, JSHTMLMediaElementConstructorTableValues, 0 }; COMPILE_ASSERT(0 == HTMLMediaElement::NETWORK_EMPTY, HTMLMediaElementEnumNETWORK_EMPTYIsWrongUseDontCheckEnums); COMPILE_ASSERT(1 == HTMLMediaElement::NETWORK_IDLE, HTMLMediaElementEnumNETWORK_IDLEIsWrongUseDontCheckEnums); COMPILE_ASSERT(2 == HTMLMediaElement::NETWORK_LOADING, HTMLMediaElementEnumNETWORK_LOADINGIsWrongUseDontCheckEnums); COMPILE_ASSERT(3 == HTMLMediaElement::NETWORK_NO_SOURCE, HTMLMediaElementEnumNETWORK_NO_SOURCEIsWrongUseDontCheckEnums); COMPILE_ASSERT(0 == HTMLMediaElement::HAVE_NOTHING, HTMLMediaElementEnumHAVE_NOTHINGIsWrongUseDontCheckEnums); COMPILE_ASSERT(1 == HTMLMediaElement::HAVE_METADATA, HTMLMediaElementEnumHAVE_METADATAIsWrongUseDontCheckEnums); COMPILE_ASSERT(2 == HTMLMediaElement::HAVE_CURRENT_DATA, HTMLMediaElementEnumHAVE_CURRENT_DATAIsWrongUseDontCheckEnums); COMPILE_ASSERT(3 == HTMLMediaElement::HAVE_FUTURE_DATA, HTMLMediaElementEnumHAVE_FUTURE_DATAIsWrongUseDontCheckEnums); COMPILE_ASSERT(4 == HTMLMediaElement::HAVE_ENOUGH_DATA, HTMLMediaElementEnumHAVE_ENOUGH_DATAIsWrongUseDontCheckEnums); class JSHTMLMediaElementConstructor : public DOMConstructorObject { public: JSHTMLMediaElementConstructor(JSC::ExecState*, JSC::Structure*, JSDOMGlobalObject*); virtual bool getOwnPropertySlot(JSC::ExecState*, const JSC::Identifier&, JSC::PropertySlot&); virtual bool getOwnPropertyDescriptor(JSC::ExecState*, const JSC::Identifier&, JSC::PropertyDescriptor&); static const JSC::ClassInfo s_info; static JSC::Structure* createStructure(JSC::JSGlobalData& globalData, JSC::JSValue prototype) { return JSC::Structure::create(globalData, prototype, JSC::TypeInfo(JSC::ObjectType, StructureFlags), AnonymousSlotCount, &s_info); } protected: static const unsigned StructureFlags = JSC::OverridesGetOwnPropertySlot | JSC::ImplementsHasInstance | DOMConstructorObject::StructureFlags; }; const ClassInfo JSHTMLMediaElementConstructor::s_info = { "HTMLMediaElementConstructor", &DOMConstructorObject::s_info, &JSHTMLMediaElementConstructorTable, 0 }; JSHTMLMediaElementConstructor::JSHTMLMediaElementConstructor(ExecState* exec, Structure* structure, JSDOMGlobalObject* globalObject) : DOMConstructorObject(structure, globalObject) { ASSERT(inherits(&s_info)); putDirect(exec->globalData(), exec->propertyNames().prototype, JSHTMLMediaElementPrototype::self(exec, globalObject), DontDelete | ReadOnly); } bool JSHTMLMediaElementConstructor::getOwnPropertySlot(ExecState* exec, const Identifier& propertyName, PropertySlot& slot) { return getStaticValueSlot(exec, &JSHTMLMediaElementConstructorTable, this, propertyName, slot); } bool JSHTMLMediaElementConstructor::getOwnPropertyDescriptor(ExecState* exec, const Identifier& propertyName, PropertyDescriptor& descriptor) { return getStaticValueDescriptor(exec, &JSHTMLMediaElementConstructorTable, this, propertyName, descriptor); } /* Hash table for prototype */ #if ENABLE(JIT) #define THUNK_GENERATOR(generator) , generator #else #define THUNK_GENERATOR(generator) #endif static const HashTableValue JSHTMLMediaElementPrototypeTableValues[14] = { { "NETWORK_EMPTY", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementNETWORK_EMPTY), (intptr_t)0 THUNK_GENERATOR(0) }, { "NETWORK_IDLE", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementNETWORK_IDLE), (intptr_t)0 THUNK_GENERATOR(0) }, { "NETWORK_LOADING", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementNETWORK_LOADING), (intptr_t)0 THUNK_GENERATOR(0) }, { "NETWORK_NO_SOURCE", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementNETWORK_NO_SOURCE), (intptr_t)0 THUNK_GENERATOR(0) }, { "HAVE_NOTHING", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementHAVE_NOTHING), (intptr_t)0 THUNK_GENERATOR(0) }, { "HAVE_METADATA", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementHAVE_METADATA), (intptr_t)0 THUNK_GENERATOR(0) }, { "HAVE_CURRENT_DATA", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementHAVE_CURRENT_DATA), (intptr_t)0 THUNK_GENERATOR(0) }, { "HAVE_FUTURE_DATA", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementHAVE_FUTURE_DATA), (intptr_t)0 THUNK_GENERATOR(0) }, { "HAVE_ENOUGH_DATA", DontDelete | ReadOnly, (intptr_t)static_cast(jsHTMLMediaElementHAVE_ENOUGH_DATA), (intptr_t)0 THUNK_GENERATOR(0) }, { "load", DontDelete | Function, (intptr_t)static_cast(jsHTMLMediaElementPrototypeFunctionLoad), (intptr_t)0 THUNK_GENERATOR(0) }, { "canPlayType", DontDelete | Function, (intptr_t)static_cast(jsHTMLMediaElementPrototypeFunctionCanPlayType), (intptr_t)1 THUNK_GENERATOR(0) }, { "play", DontDelete | Function, (intptr_t)static_cast(jsHTMLMediaElementPrototypeFunctionPlay), (intptr_t)0 THUNK_GENERATOR(0) }, { "pause", DontDelete | Function, (intptr_t)static_cast(jsHTMLMediaElementPrototypeFunctionPause), (intptr_t)0 THUNK_GENERATOR(0) }, { 0, 0, 0, 0 THUNK_GENERATOR(0) } }; #undef THUNK_GENERATOR static JSC_CONST_HASHTABLE HashTable JSHTMLMediaElementPrototypeTable = { 32, 31, JSHTMLMediaElementPrototypeTableValues, 0 }; const ClassInfo JSHTMLMediaElementPrototype::s_info = { "HTMLMediaElementPrototype", &JSC::JSObjectWithGlobalObject::s_info, &JSHTMLMediaElementPrototypeTable, 0 }; JSObject* JSHTMLMediaElementPrototype::self(ExecState* exec, JSGlobalObject* globalObject) { return getDOMPrototype(exec, globalObject); } bool JSHTMLMediaElementPrototype::getOwnPropertySlot(ExecState* exec, const Identifier& propertyName, PropertySlot& slot) { return getStaticPropertySlot(exec, &JSHTMLMediaElementPrototypeTable, this, propertyName, slot); } bool JSHTMLMediaElementPrototype::getOwnPropertyDescriptor(ExecState* exec, const Identifier& propertyName, PropertyDescriptor& descriptor) { return getStaticPropertyDescriptor(exec, &JSHTMLMediaElementPrototypeTable, this, propertyName, descriptor); } const ClassInfo JSHTMLMediaElement::s_info = { "HTMLMediaElement", &JSHTMLElement::s_info, &JSHTMLMediaElementTable, 0 }; JSHTMLMediaElement::JSHTMLMediaElement(Structure* structure, JSDOMGlobalObject* globalObject, PassRefPtr impl) : JSHTMLElement(structure, globalObject, impl) { ASSERT(inherits(&s_info)); } JSObject* JSHTMLMediaElement::createPrototype(ExecState* exec, JSGlobalObject* globalObject) { return new (exec) JSHTMLMediaElementPrototype(exec->globalData(), globalObject, JSHTMLMediaElementPrototype::createStructure(exec->globalData(), JSHTMLElementPrototype::self(exec, globalObject))); } bool JSHTMLMediaElement::getOwnPropertySlot(ExecState* exec, const Identifier& propertyName, PropertySlot& slot) { return getStaticValueSlot(exec, &JSHTMLMediaElementTable, this, propertyName, slot); } bool JSHTMLMediaElement::getOwnPropertyDescriptor(ExecState* exec, const Identifier& propertyName, PropertyDescriptor& descriptor) { return getStaticValueDescriptor(exec, &JSHTMLMediaElementTable, this, propertyName, descriptor); } JSValue jsHTMLMediaElementError(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = toJS(exec, castedThis->globalObject(), WTF::getPtr(imp->error())); return result; } JSValue jsHTMLMediaElementSrc(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsString(exec, imp->getURLAttribute(WebCore::HTMLNames::srcAttr)); return result; } JSValue jsHTMLMediaElementCurrentSrc(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsString(exec, imp->currentSrc()); return result; } JSValue jsHTMLMediaElementNetworkState(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->networkState()); return result; } JSValue jsHTMLMediaElementPreload(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsString(exec, imp->preload()); return result; } JSValue jsHTMLMediaElementBuffered(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = toJS(exec, castedThis->globalObject(), WTF::getPtr(imp->buffered())); return result; } JSValue jsHTMLMediaElementReadyState(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->readyState()); return result; } JSValue jsHTMLMediaElementSeeking(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsBoolean(imp->seeking()); return result; } JSValue jsHTMLMediaElementCurrentTime(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->currentTime()); return result; } JSValue jsHTMLMediaElementStartTime(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->startTime()); return result; } JSValue jsHTMLMediaElementDuration(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->duration()); return result; } JSValue jsHTMLMediaElementPaused(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsBoolean(imp->paused()); return result; } JSValue jsHTMLMediaElementDefaultPlaybackRate(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->defaultPlaybackRate()); return result; } JSValue jsHTMLMediaElementPlaybackRate(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->playbackRate()); return result; } JSValue jsHTMLMediaElementPlayed(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = toJS(exec, castedThis->globalObject(), WTF::getPtr(imp->played())); return result; } JSValue jsHTMLMediaElementSeekable(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = toJS(exec, castedThis->globalObject(), WTF::getPtr(imp->seekable())); return result; } JSValue jsHTMLMediaElementEnded(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsBoolean(imp->ended()); return result; } JSValue jsHTMLMediaElementAutoplay(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsBoolean(imp->hasAttribute(WebCore::HTMLNames::autoplayAttr)); return result; } JSValue jsHTMLMediaElementLoop(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsBoolean(imp->hasAttribute(WebCore::HTMLNames::loopAttr)); return result; } JSValue jsHTMLMediaElementControls(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsBoolean(imp->controls()); return result; } JSValue jsHTMLMediaElementVolume(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsNumber(imp->volume()); return result; } JSValue jsHTMLMediaElementMuted(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsBoolean(imp->muted()); return result; } JSValue jsHTMLMediaElementWebkitPreservesPitch(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsBoolean(imp->webkitPreservesPitch()); return result; } JSValue jsHTMLMediaElementWebkitHasClosedCaptions(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsBoolean(imp->webkitHasClosedCaptions()); return result; } JSValue jsHTMLMediaElementWebkitClosedCaptionsVisible(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* castedThis = static_cast(asObject(slotBase)); UNUSED_PARAM(exec); HTMLMediaElement* imp = static_cast(castedThis->impl()); JSValue result = jsBoolean(imp->webkitClosedCaptionsVisible()); return result; } JSValue jsHTMLMediaElementConstructor(ExecState* exec, JSValue slotBase, const Identifier&) { JSHTMLMediaElement* domObject = static_cast(asObject(slotBase)); return JSHTMLMediaElement::getConstructor(exec, domObject->globalObject()); } void JSHTMLMediaElement::put(ExecState* exec, const Identifier& propertyName, JSValue value, PutPropertySlot& slot) { lookupPut(exec, propertyName, value, &JSHTMLMediaElementTable, this, slot); } void setJSHTMLMediaElementSrc(ExecState* exec, JSObject* thisObject, JSValue value) { JSHTMLMediaElement* castedThis = static_cast(thisObject); HTMLMediaElement* imp = static_cast(castedThis->impl()); imp->setAttribute(WebCore::HTMLNames::srcAttr, valueToStringWithNullCheck(exec, value)); } void setJSHTMLMediaElementPreload(ExecState* exec, JSObject* thisObject, JSValue value) { JSHTMLMediaElement* castedThis = static_cast(thisObject); HTMLMediaElement* imp = static_cast(castedThis->impl()); imp->setPreload(ustringToString(value.toString(exec))); } void setJSHTMLMediaElementCurrentTime(ExecState* exec, JSObject* thisObject, JSValue value) { JSHTMLMediaElement* castedThis = static_cast(thisObject); HTMLMediaElement* imp = static_cast(castedThis->impl()); ExceptionCode ec = 0; imp->setCurrentTime(value.toFloat(exec), ec); setDOMException(exec, ec); } void setJSHTMLMediaElementDefaultPlaybackRate(ExecState* exec, JSObject* thisObject, JSValue value) { JSHTMLMediaElement* castedThis = static_cast(thisObject); HTMLMediaElement* imp = static_cast(castedThis->impl()); imp->setDefaultPlaybackRate(value.toFloat(exec)); } void setJSHTMLMediaElementPlaybackRate(ExecState* exec, JSObject* thisObject, JSValue value) { JSHTMLMediaElement* castedThis = static_cast(thisObject); HTMLMediaElement* imp = static_cast(castedThis->impl()); imp->setPlaybackRate(value.toFloat(exec)); } void setJSHTMLMediaElementAutoplay(ExecState* exec, JSObject* thisObject, JSValue value) { JSHTMLMediaElement* castedThis = static_cast(thisObject); HTMLMediaElement* imp = static_cast(castedThis->impl()); imp->setBooleanAttribute(WebCore::HTMLNames::autoplayAttr, value.toBoolean(exec)); } void setJSHTMLMediaElementLoop(ExecState* exec, JSObject* thisObject, JSValue value) { JSHTMLMediaElement* castedThis = static_cast(thisObject); HTMLMediaElement* imp = static_cast(castedThis->impl()); imp->setBooleanAttribute(WebCore::HTMLNames::loopAttr, value.toBoolean(exec)); } void setJSHTMLMediaElementControls(ExecState* exec, JSObject* thisObject, JSValue value) { JSHTMLMediaElement* castedThis = static_cast(thisObject); HTMLMediaElement* imp = static_cast(castedThis->impl()); imp->setControls(value.toBoolean(exec)); } void setJSHTMLMediaElementVolume(ExecState* exec, JSObject* thisObject, JSValue value) { JSHTMLMediaElement* castedThis = static_cast(thisObject); HTMLMediaElement* imp = static_cast(castedThis->impl()); ExceptionCode ec = 0; imp->setVolume(value.toFloat(exec), ec); setDOMException(exec, ec); } void setJSHTMLMediaElementMuted(ExecState* exec, JSObject* thisObject, JSValue value) { JSHTMLMediaElement* castedThis = static_cast(thisObject); HTMLMediaElement* imp = static_cast(castedThis->impl()); imp->setMuted(value.toBoolean(exec)); } void setJSHTMLMediaElementWebkitPreservesPitch(ExecState* exec, JSObject* thisObject, JSValue value) { JSHTMLMediaElement* castedThis = static_cast(thisObject); HTMLMediaElement* imp = static_cast(castedThis->impl()); imp->setWebkitPreservesPitch(value.toBoolean(exec)); } void setJSHTMLMediaElementWebkitClosedCaptionsVisible(ExecState* exec, JSObject* thisObject, JSValue value) { JSHTMLMediaElement* castedThis = static_cast(thisObject); HTMLMediaElement* imp = static_cast(castedThis->impl()); imp->setWebkitClosedCaptionsVisible(value.toBoolean(exec)); } JSValue JSHTMLMediaElement::getConstructor(ExecState* exec, JSGlobalObject* globalObject) { return getDOMConstructor(exec, static_cast(globalObject)); } EncodedJSValue JSC_HOST_CALL jsHTMLMediaElementPrototypeFunctionLoad(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSHTMLMediaElement::s_info)) return throwVMTypeError(exec); JSHTMLMediaElement* castedThis = static_cast(asObject(thisValue)); HTMLMediaElement* imp = static_cast(castedThis->impl()); ExceptionCode ec = 0; imp->load(processingUserGesture(), ec); setDOMException(exec, ec); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsHTMLMediaElementPrototypeFunctionCanPlayType(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSHTMLMediaElement::s_info)) return throwVMTypeError(exec); JSHTMLMediaElement* castedThis = static_cast(asObject(thisValue)); HTMLMediaElement* imp = static_cast(castedThis->impl()); const String& type(ustringToString(exec->argument(0).toString(exec))); if (exec->hadException()) return JSValue::encode(jsUndefined()); JSC::JSValue result = jsString(exec, imp->canPlayType(type)); return JSValue::encode(result); } EncodedJSValue JSC_HOST_CALL jsHTMLMediaElementPrototypeFunctionPlay(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSHTMLMediaElement::s_info)) return throwVMTypeError(exec); JSHTMLMediaElement* castedThis = static_cast(asObject(thisValue)); HTMLMediaElement* imp = static_cast(castedThis->impl()); imp->play(processingUserGesture()); return JSValue::encode(jsUndefined()); } EncodedJSValue JSC_HOST_CALL jsHTMLMediaElementPrototypeFunctionPause(ExecState* exec) { JSValue thisValue = exec->hostThisValue(); if (!thisValue.inherits(&JSHTMLMediaElement::s_info)) return throwVMTypeError(exec); JSHTMLMediaElement* castedThis = static_cast(asObject(thisValue)); HTMLMediaElement* imp = static_cast(castedThis->impl()); imp->pause(processingUserGesture()); return JSValue::encode(jsUndefined()); } // Constant getters JSValue jsHTMLMediaElementNETWORK_EMPTY(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(0)); } JSValue jsHTMLMediaElementNETWORK_IDLE(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(1)); } JSValue jsHTMLMediaElementNETWORK_LOADING(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(2)); } JSValue jsHTMLMediaElementNETWORK_NO_SOURCE(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(3)); } JSValue jsHTMLMediaElementHAVE_NOTHING(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(0)); } JSValue jsHTMLMediaElementHAVE_METADATA(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(1)); } JSValue jsHTMLMediaElementHAVE_CURRENT_DATA(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(2)); } JSValue jsHTMLMediaElementHAVE_FUTURE_DATA(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(3)); } JSValue jsHTMLMediaElementHAVE_ENOUGH_DATA(ExecState* exec, JSValue, const Identifier&) { UNUSED_PARAM(exec); return jsNumber(static_cast(4)); } } #endif // ENABLE(VIDEO)